diff --git a/stage0/src/Init/Control/Monad.lean b/stage0/src/Init/Control/Monad.lean index d62b3f9163..dcb0eb6bbc 100644 --- a/stage0/src/Init/Control/Monad.lean +++ b/stage0/src/Init/Control/Monad.lean @@ -15,7 +15,7 @@ class HasBind (m : Type u → Type v) := export HasBind (bind) -infixr `>>=` := bind +infixl `>>=` := bind @[inline] def mcomp {α : Type u} {β δ : Type v} {m : Type v → Type w} [HasBind m] (f : α → m β) (g : β → m δ) : α → m δ := fun a => f a >>= g diff --git a/stage0/src/Init/Core.lean b/stage0/src/Init/Core.lean index ac4b615a14..deffdce7c5 100644 --- a/stage0/src/Init/Core.lean +++ b/stage0/src/Init/Core.lean @@ -66,7 +66,7 @@ reserve infixr ` :: `:67 /- Control -/ reserve infixr ` <|> `:2 -reserve infixr ` >>= `:55 +reserve infixl ` >>= `:55 reserve infixr ` >=> `:55 reserve infixl ` <*> `:60 reserve infixl ` <* ` :60 diff --git a/stage0/src/Lean/Elab/Term.lean b/stage0/src/Lean/Elab/Term.lean index 53c94d6c24..f06b2c1194 100644 --- a/stage0/src/Lean/Elab/Term.lean +++ b/stage0/src/Lean/Elab/Term.lean @@ -996,9 +996,10 @@ opts ← getOptions; mctx ← getMCtx; lctx ← getLCtx; match Lean.mkAuxDefinition env opts mctx lctx declName type value zeta with -| Except.error ex => throwError ref (ex.toMessageData opts) -| Except.ok (r, env) => do +| Except.error ex => throwError ref (ex.toMessageData opts) +| Except.ok (r, env, mctx) => do setEnv env; + setMCtx mctx; pure r private partial def mkAuxNameAux (env : Environment) (base : Name) : Nat → Name diff --git a/stage0/src/Lean/Expr.lean b/stage0/src/Lean/Expr.lean index 49ec3aa07b..2744d3df7d 100644 --- a/stage0/src/Lean/Expr.lean +++ b/stage0/src/Lean/Expr.lean @@ -638,8 +638,8 @@ constant abstractRange (e : @& Expr) (n : @& Nat) (xs : @& Array Expr) : Expr := def replaceFVar (e : Expr) (fvar : Expr) (v : Expr) : Expr := (e.abstract #[fvar]).instantiate1 v -def replaceFVarId (e : Expr) (fvarId : FVarId) (v : Expr) : Expr := -replaceFVar e (mkFVar fvarId) v +def replaceFVarId (e : Expr) (fvarId : FVarId) (newFVarId : FVarId) : Expr := +replaceFVar e (mkFVar fvarId) (mkFVar newFVarId) instance : HasToString Expr := ⟨Expr.dbgToString⟩ diff --git a/stage0/src/Lean/Meta/Basic.lean b/stage0/src/Lean/Meta/Basic.lean index 9dfe5d8475..af3bd84f03 100644 --- a/stage0/src/Lean/Meta/Basic.lean +++ b/stage0/src/Lean/Meta/Basic.lean @@ -110,6 +110,7 @@ structure Cache := (funInfo : PersistentHashMap InfoCacheKey FunInfo := {}) (synthInstance : PersistentHashMap Expr (Option Expr) := {}) (whnfDefault : PersistentExprStructMap Expr := {}) -- cache for closed terms and `TransparencyMode.default` +(whnfAll : PersistentExprStructMap Expr := {}) -- cache for closed terms and `TransparencyMode.all` structure Context := (config : Config := {}) @@ -152,10 +153,13 @@ ctx ← read; pure ctx.config @[inline] def getMCtx : MetaM MetavarContext := do s ← get; pure s.mctx +def setMCtx (mctx : MetavarContext) : MetaM Unit := do +modify $ fun s => { s with mctx := mctx } + @[inline] def getEnv : MetaM Environment := do s ← get; pure s.env -@[inline] def setEnv (env : Environment) : MetaM Unit := do +def setEnv (env : Environment) : MetaM Unit := do modify $ fun s => { s with env := env } def mkWHNFRef : IO (IO.Ref (Expr → MetaM Expr)) := @@ -250,6 +254,11 @@ ctx ← read; s ← get; throw (f { env := s.env, mctx := s.mctx, lctx := ctx.lctx, opts := ctx.config.opts }) +def throwOther {α} (msg : MessageData) : MetaM α := do +ctx ← read; +s ← get; +throw (Exception.other (MessageData.withContext { env := s.env, mctx := s.mctx, lctx := ctx.lctx, opts := ctx.config.opts } msg)) + def throwBug {α} (b : Bug) : MetaM α := throwEx $ Exception.bug b @@ -837,13 +846,13 @@ finally x (modify $ fun s => { s with mctx := mctx' }) returned where `u_i`s are universe parameters and metavariables `type` and `value` depend on, and `t_j`s are free and meta variables `type` and `value` depend on. -/ def mkAuxDefinition (name : Name) (type : Expr) (value : Expr) : MetaM Expr := do -env ← getEnv; -opts ← getOptions; -mctx ← getMCtx; -lctx ← getLCtx; +env ← getEnv; +opts ← getOptions; +mctx ← getMCtx; +lctx ← getLCtx; match Lean.mkAuxDefinition env opts mctx lctx name type value with -| Except.error ex => throw $ Exception.kernel ex opts -| Except.ok (e, env) => do setEnv env; pure e +| Except.error ex => throw $ Exception.kernel ex opts +| Except.ok (e, env, mctx) => do setEnv env; setMCtx mctx; pure e /-- Similar to `mkAuxDefinition`, but infers the type of `value`. -/ def mkAuxDefinitionFor (name : Name) (value : Expr) : MetaM Expr := do diff --git a/stage0/src/Lean/Meta/Tactic/Cases.lean b/stage0/src/Lean/Meta/Tactic/Cases.lean index a838529734..abcae8cfd4 100644 --- a/stage0/src/Lean/Meta/Tactic/Cases.lean +++ b/stage0/src/Lean/Meta/Tactic/Cases.lean @@ -174,10 +174,10 @@ s.mapIdx $ fun i s => { ctorName := ctorNames.get! i, toInductionSubgoal := s } private partial def unifyEqsAux : Nat → CasesSubgoal → MetaM (Option CasesSubgoal) | 0, s => do - trace! `Meta.cases ("unifyEqs " ++ MessageData.ofGoal s.mvarId); + trace! `Meta.Tactic.cases ("unifyEqs " ++ MessageData.ofGoal s.mvarId); pure (some s) | n+1, s => do - trace! `Meta.cases ("unifyEqs [" ++ toString (n+1) ++ "] " ++ MessageData.ofGoal s.mvarId); + trace! `Meta.Tactic.cases ("unifyEqs [" ++ toString (n+1) ++ "] " ++ MessageData.ofGoal s.mvarId); (eqFVarId, mvarId) ← intro1 s.mvarId; withMVarContext mvarId $ do eqDecl ← getLocalDecl eqFVarId; @@ -243,7 +243,7 @@ withMVarContext mvarId $ do pure $ toCasesSubgoals s ctors) (do s₁ ← generalizeIndices mvarId majorFVarId; - trace! `Meta.cases ("after generalizeIndices" ++ Format.line ++ MessageData.ofGoal s₁.mvarId); + trace! `Meta.Tactic.cases ("after generalizeIndices" ++ Format.line ++ MessageData.ofGoal s₁.mvarId); s₂ ← induction s₁.mvarId s₁.fvarId casesOn givenNames useUnusedNames; s₂ ← elimAuxIndices s₁ s₂; let s₂ := toCasesSubgoals s₂ ctors; @@ -254,5 +254,8 @@ end Cases def cases (mvarId : MVarId) (majorFVarId : FVarId) (givenNames : Array (List Name) := #[]) (useUnusedNames := false) : MetaM (Array CasesSubgoal) := Cases.cases mvarId majorFVarId givenNames useUnusedNames +@[init] private def regTraceClasses : IO Unit := do +registerTraceClass `Meta.Tactic.cases + end Meta end Lean diff --git a/stage0/src/Lean/Meta/Tactic/FVarSubst.lean b/stage0/src/Lean/Meta/Tactic/FVarSubst.lean index 17eb391c96..29a4872a65 100644 --- a/stage0/src/Lean/Meta/Tactic/FVarSubst.lean +++ b/stage0/src/Lean/Meta/Tactic/FVarSubst.lean @@ -4,6 +4,7 @@ Released under Apache 2.0 license as described in the file LICENSE. Authors: Leonardo de Moura -/ import Lean.Expr +import Lean.LocalContext import Lean.Util.ReplaceExpr namespace Lean @@ -62,6 +63,17 @@ else oldS.map.fold | some fvarId'' => m.insert fvarId fvarId'') newS +def domain (s : FVarSubst) : List FVarId := +s.map.fold (fun r k v => k :: r) [] + end FVarSubst end Meta + +def LocalDecl.applyFVarSubst (s : Meta.FVarSubst) : LocalDecl → LocalDecl +| LocalDecl.cdecl i id n t bi => LocalDecl.cdecl i id n (s.apply t) bi +| LocalDecl.ldecl i id n t v => LocalDecl.ldecl i id n (s.apply t) (s.apply v) + +abbrev Expr.applyFVarSubst (s : Meta.FVarSubst) (e : Expr) : Expr := +s.apply e + end Lean diff --git a/stage0/src/Lean/Meta/Tactic/Subst.lean b/stage0/src/Lean/Meta/Tactic/Subst.lean index 1b96253852..107e816d58 100644 --- a/stage0/src/Lean/Meta/Tactic/Subst.lean +++ b/stage0/src/Lean/Meta/Tactic/Subst.lean @@ -27,12 +27,14 @@ withMVarContext mvarId $ do a ← whnf a; match a with | Expr.fvar aFVarId _ => do + trace! `Meta.Tactic.subst ("substituting " ++ a ++ " (id: " ++ aFVarId ++ ") with " ++ b); mctx ← getMCtx; when (mctx.exprDependsOn b aFVarId) $ throwTacticEx `subst mvarId ("'" ++ a ++ "' occurs at" ++ indentExpr b); aLocalDecl ← getLocalDecl aFVarId; (vars, mvarId) ← revert mvarId #[aFVarId, hFVarId] true; (twoVars, mvarId) ← introN mvarId 2 [] false; + trace! `Meta.Tactic.subst ("reverted variables " ++ toString vars); let aFVarId := twoVars.get! 0; let a := mkFVar aFVarId; let hFVarId := twoVars.get! 1; @@ -59,7 +61,7 @@ withMVarContext mvarId $ do (newFVars, mvarId) ← introN mvarId (vars.size - 2) [] false; fvarSubst ← newFVars.size.foldM (fun i (fvarSubst : FVarSubst) => - let var := vars.get! i; + let var := vars.get! (i+2); let newFVar := newFVars.get! i; pure $ fvarSubst.insert var newFVar) FVarSubst.empty; diff --git a/stage0/src/Lean/Meta/WHNF.lean b/stage0/src/Lean/Meta/WHNF.lean index 4418e26604..7b139c4ff0 100644 --- a/stage0/src/Lean/Meta/WHNF.lean +++ b/stage0/src/Lean/Meta/WHNF.lean @@ -23,7 +23,7 @@ Lean.WHNF.whnfCore getConstNoEx isAuxDef? whnf inferType isExprDefEqAux getLocal unsafe def reduceNativeConst (α : Type) (typeName : Name) (constName : Name) : MetaM α := do env ← getEnv; match env.evalConstCheck α typeName constName with -| Except.error ex => throw $ Exception.other ex +| Except.error ex => throwOther ex | Except.ok v => pure v unsafe def reduceBoolNativeUnsafe (constName : Name) : MetaM Bool := reduceNativeConst Bool `Bool constName @@ -86,22 +86,30 @@ else match e with @[inline] private def useWHNFCache (e : Expr) : MetaM Bool := do --- We cache only consed terms +-- We cache only closed terms if e.hasFVar then pure false else do ctx ← read; - pure $ ctx.config.transparency == TransparencyMode.default + pure $ ctx.config.transparency != TransparencyMode.reducible @[inline] private def cached? (useCache : Bool) (e : Expr) : MetaM (Option Expr) := do if useCache then do - s ← get; - pure $ s.cache.whnfDefault.find? e + ctx ← read; + s ← get; + match ctx.config.transparency with + | TransparencyMode.default => pure $ s.cache.whnfDefault.find? e + | TransparencyMode.all => pure $ s.cache.whnfAll.find? e + | _ => unreachable! else pure none private def cache (useCache : Bool) (e r : Expr) : MetaM Expr := do +ctx ← read; when useCache $ - modify $ fun s => { s with cache := { s.cache with whnfDefault := s.cache.whnfDefault.insert e r } }; + match ctx.config.transparency with + | TransparencyMode.default => modify $ fun s => { s with cache := { s.cache with whnfDefault := s.cache.whnfDefault.insert e r } } + | TransparencyMode.all => modify $ fun s => { s with cache := { s.cache with whnfAll := s.cache.whnfAll.insert e r } } + | _ => unreachable!; pure r partial def whnfImpl : Expr → MetaM Expr diff --git a/stage0/src/Lean/Parser/Term.lean b/stage0/src/Lean/Parser/Term.lean index 45146926f2..83e89c8cb1 100644 --- a/stage0/src/Lean/Parser/Term.lean +++ b/stage0/src/Lean/Parser/Term.lean @@ -196,7 +196,7 @@ def namedArgument := parser! try ("(" >> ident >> " := ") >> termParser >> ")" @[builtinTermParser] def orM := tparser! infixR " <||> " 30 @[builtinTermParser] def andM := tparser! infixR " <&&> " 35 @[builtinTermParser] def andthen := tparser! infixR " >> " 60 -@[builtinTermParser] def bindOp := tparser! infixR " >>= " 55 +@[builtinTermParser] def bindOp := tparser! infixL " >>= " 55 @[builtinTermParser] def mapRev := tparser! infixR " <&> " 100 @[builtinTermParser] def seq := tparser! infixL " <*> " 60 @[builtinTermParser] def seqLeft := tparser! infixL " <* " 60 diff --git a/stage0/src/Lean/Util/Closure.lean b/stage0/src/Lean/Util/Closure.lean index 9d783fc655..5c051a3bb6 100644 --- a/stage0/src/Lean/Util/Closure.lean +++ b/stage0/src/Lean/Util/Closure.lean @@ -12,11 +12,11 @@ namespace Lean namespace Closure structure Context := -(mctx : MetavarContext) (lctxInput : LocalContext) (zeta : Bool) -- if `true` let-variables are expanded structure State := +(mctx : MetavarContext) (lctxOutput : LocalContext := {}) (ngen : NameGenerator := { namePrefix := `_closure }) (visitedLevel : LevelMap Level := {}) @@ -48,15 +48,19 @@ let p := (`u).appendIndexAfter s.nextLevelIdx; modify $ fun s => { s with levelParams := s.levelParams.push p, nextLevelIdx := s.nextLevelIdx + 1, levelClosure := s.levelClosure.push u }; pure $ mkLevelParam p +def getMCtx : ClosureM MetavarContext := do +s ← get; pure s.mctx + +def instantiateMVars (e : Expr) : ClosureM Expr := do +modifyGet fun s => + let (e, mctx) := s.mctx.instantiateMVars e; + (e, { s with mctx := mctx }) + partial def collectLevelAux : Level → ClosureM Level | u@(Level.succ v _) => do v ← visitLevel collectLevelAux v; pure $ u.updateSucc! v | u@(Level.max v w _) => do v ← visitLevel collectLevelAux v; w ← visitLevel collectLevelAux w; pure $ u.updateMax! v w | u@(Level.imax v w _) => do v ← visitLevel collectLevelAux v; w ← visitLevel collectLevelAux w; pure $ u.updateIMax! v w -| u@(Level.mvar mvarId _) => do - ctx ← read; - match ctx.mctx.getLevelAssignment? mvarId with - | none => mkNewLevelParam u - | some v => visitLevel collectLevelAux v +| u@(Level.mvar mvarId _) => mkNewLevelParam u | u@(Level.param _ _) => mkNewLevelParam u | u@(Level.zero _) => pure u @@ -119,37 +123,40 @@ partial def collectExprAux : Expr → ClosureM Expr | Expr.sort u _ => do u ← collectLevel u; pure (e.updateSort! u) | Expr.const c us _ => do us ← us.mapM collectLevel; pure (e.updateConst! us) | Expr.mvar mvarId _ => do - ctx ← read; - match ctx.mctx.findDecl? mvarId with + mctx ← getMCtx; + match mctx.findDecl? mvarId with | none => throw "unknown metavariable" - | some mvarDecl => - match ctx.mctx.getExprAssignment? mvarId with - | some v => collect v - | none => do - type ← collect mvarDecl.type; - x ← mkLocalDecl none type BinderInfo.default; - modify $ fun s => { s with exprClosure := s.exprClosure.push e }; - pure x + | some mvarDecl => do + type ← instantiateMVars mvarDecl.type; + type ← collect type; + x ← mkLocalDecl none type BinderInfo.default; + modify $ fun s => { s with exprClosure := s.exprClosure.push e }; + pure x | Expr.fvar fvarId _ => do ctx ← read; match ctx.lctxInput.find? fvarId with | none => throw "unknown free variable" | some (LocalDecl.cdecl _ _ userName type bi) => do + type ← instantiateMVars type; type ← collect type; x ← mkLocalDecl userName type bi; modify $ fun s => { s with exprClosure := s.exprClosure.push e }; pure x | some (LocalDecl.ldecl _ _ userName type value) => - if ctx.zeta then + if ctx.zeta then do + value ← instantiateMVars value; collect value else do + type ← instantiateMVars type; type ← collect type; + value ← instantiateMVars value; value ← collect value; -- Note that let-declarations do not need to be provided to the closure being constructed. mkLetDecl userName type value | e => pure e -def collectExpr (e : Expr) : ClosureM Expr := +def collectExpr (e : Expr) : ClosureM Expr := do +e ← instantiateMVars e; visitExpr collectExprAux e structure MkClosureResult := @@ -158,6 +165,7 @@ structure MkClosureResult := (value : Expr) (levelClosure : Array Level) (exprClosure : Array Expr) +(mctx : MetavarContext) def mkClosure (mctx : MetavarContext) (lctx : LocalContext) (type : Expr) (value : Expr) (zeta : Bool := false) : Except String MkClosureResult := let shareCommonTypeValue : Std.ShareCommonM (Expr × Expr) := do { @@ -166,13 +174,14 @@ let shareCommonTypeValue : Std.ShareCommonM (Expr × Expr) := do { pure (type, value) }; let (type, value) := shareCommonTypeValue.run; -let mkTypeValue : ClosureM (Expr × Expr) := do { +let mkTypeValue : ClosureM (Expr × Expr × MetavarContext) := do { type ← collectExpr type; value ← collectExpr value; - pure (type, value) + mctx ← getMCtx; + pure (type, value, mctx) }; -match (mkTypeValue { mctx := mctx, lctxInput := lctx, zeta := zeta }).run {} with -| EStateM.Result.ok (type, value) s => +match (mkTypeValue { lctxInput := lctx, zeta := zeta }).run { mctx := mctx } with +| EStateM.Result.ok (type, value, mctx) s => let fvars := s.lctxOutput.getFVars; let type := s.lctxOutput.mkForall fvars type; let value := s.lctxOutput.mkLambda fvars value; @@ -181,13 +190,14 @@ match (mkTypeValue { mctx := mctx, lctxInput := lctx, zeta := zeta }).run {} wit type := type, value := value, levelClosure := s.levelClosure, - exprClosure := s.exprClosure } + exprClosure := s.exprClosure, + mctx := mctx } | EStateM.Result.error ex s => Except.error ex end Closure def mkAuxDefinition (env : Environment) (opts : Options) (mctx : MetavarContext) (lctx : LocalContext) (name : Name) (type : Expr) (value : Expr) - (zeta : Bool := false) : Except KernelException (Expr × Environment) := + (zeta : Bool := false) : Except KernelException (Expr × Environment × MetavarContext) := match Closure.mkClosure mctx lctx type value zeta with | Except.error ex => throw $ KernelException.other ex | Except.ok result => do @@ -201,6 +211,6 @@ match Closure.mkClosure mctx lctx type value zeta with }; env ← env.addAndCompile opts decl; let c := mkAppN (mkConst name result.levelClosure.toList) result.exprClosure; - pure (c, env) + pure (c, env, result.mctx) end Lean diff --git a/stage0/stdlib/Lean/Elab/Binders.c b/stage0/stdlib/Lean/Elab/Binders.c index 3b5bdf8b87..19f5d8824a 100644 --- a/stage0/stdlib/Lean/Elab/Binders.c +++ b/stage0/stdlib/Lean/Elab/Binders.c @@ -4520,7 +4520,7 @@ return x_55; } else { -lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_154; lean_object* x_155; lean_object* x_156; uint8_t x_157; +lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_160; lean_object* x_161; lean_object* x_162; uint8_t x_163; x_56 = lean_ctor_get(x_17, 0); lean_inc(x_56); x_57 = lean_ctor_get(x_56, 2); @@ -4529,203 +4529,203 @@ lean_dec(x_56); x_58 = lean_ctor_get(x_57, 2); lean_inc(x_58); lean_dec(x_57); -x_154 = l_Lean_Elab_Term_resetSynthInstanceCache___rarg(x_17); -x_155 = lean_ctor_get(x_3, 0); -lean_inc(x_155); -x_156 = lean_ctor_get(x_154, 1); -lean_inc(x_156); -lean_dec(x_154); -x_157 = !lean_is_exclusive(x_3); -if (x_157 == 0) -{ -lean_object* x_158; uint8_t x_159; -x_158 = lean_ctor_get(x_3, 0); -lean_dec(x_158); -x_159 = !lean_is_exclusive(x_155); -if (x_159 == 0) -{ -lean_object* x_160; lean_object* x_161; lean_object* x_162; -x_160 = lean_ctor_get(x_155, 2); +x_160 = l_Lean_Elab_Term_resetSynthInstanceCache___rarg(x_17); +x_161 = lean_ctor_get(x_3, 0); +lean_inc(x_161); +x_162 = lean_ctor_get(x_160, 1); +lean_inc(x_162); lean_dec(x_160); -x_161 = lean_ctor_get(x_155, 1); -lean_dec(x_161); -lean_ctor_set(x_155, 2, x_21); -lean_ctor_set(x_155, 1, x_20); -x_162 = lean_apply_3(x_2, x_19, x_3, x_156); -if (lean_obj_tag(x_162) == 0) +x_163 = !lean_is_exclusive(x_3); +if (x_163 == 0) { -lean_object* x_163; lean_object* x_164; lean_object* x_165; -x_163 = lean_ctor_get(x_162, 0); -lean_inc(x_163); -x_164 = lean_ctor_get(x_162, 1); -lean_inc(x_164); -lean_dec(x_162); -x_165 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_165, 0, x_163); -x_59 = x_165; -x_60 = x_164; -goto block_153; -} -else +lean_object* x_164; uint8_t x_165; +x_164 = lean_ctor_get(x_3, 0); +lean_dec(x_164); +x_165 = !lean_is_exclusive(x_161); +if (x_165 == 0) { lean_object* x_166; lean_object* x_167; lean_object* x_168; -x_166 = lean_ctor_get(x_162, 0); -lean_inc(x_166); -x_167 = lean_ctor_get(x_162, 1); -lean_inc(x_167); -lean_dec(x_162); -x_168 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_168, 0, x_166); -x_59 = x_168; -x_60 = x_167; -goto block_153; -} -} -else +x_166 = lean_ctor_get(x_161, 2); +lean_dec(x_166); +x_167 = lean_ctor_get(x_161, 1); +lean_dec(x_167); +lean_ctor_set(x_161, 2, x_21); +lean_ctor_set(x_161, 1, x_20); +x_168 = lean_apply_3(x_2, x_19, x_3, x_162); +if (lean_obj_tag(x_168) == 0) { -lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; lean_object* x_173; -x_169 = lean_ctor_get(x_155, 0); -x_170 = lean_ctor_get(x_155, 3); -x_171 = lean_ctor_get(x_155, 4); -lean_inc(x_171); -lean_inc(x_170); +lean_object* x_169; lean_object* x_170; lean_object* x_171; +x_169 = lean_ctor_get(x_168, 0); lean_inc(x_169); -lean_dec(x_155); -x_172 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_172, 0, x_169); -lean_ctor_set(x_172, 1, x_20); -lean_ctor_set(x_172, 2, x_21); -lean_ctor_set(x_172, 3, x_170); -lean_ctor_set(x_172, 4, x_171); -lean_ctor_set(x_3, 0, x_172); -x_173 = lean_apply_3(x_2, x_19, x_3, x_156); -if (lean_obj_tag(x_173) == 0) -{ -lean_object* x_174; lean_object* x_175; lean_object* x_176; -x_174 = lean_ctor_get(x_173, 0); -lean_inc(x_174); -x_175 = lean_ctor_get(x_173, 1); -lean_inc(x_175); -lean_dec(x_173); -x_176 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_176, 0, x_174); -x_59 = x_176; -x_60 = x_175; -goto block_153; +x_170 = lean_ctor_get(x_168, 1); +lean_inc(x_170); +lean_dec(x_168); +x_171 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_171, 0, x_169); +x_59 = x_171; +x_60 = x_170; +goto block_159; } else { -lean_object* x_177; lean_object* x_178; lean_object* x_179; -x_177 = lean_ctor_get(x_173, 0); +lean_object* x_172; lean_object* x_173; lean_object* x_174; +x_172 = lean_ctor_get(x_168, 0); +lean_inc(x_172); +x_173 = lean_ctor_get(x_168, 1); +lean_inc(x_173); +lean_dec(x_168); +x_174 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_174, 0, x_172); +x_59 = x_174; +x_60 = x_173; +goto block_159; +} +} +else +{ +lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; +x_175 = lean_ctor_get(x_161, 0); +x_176 = lean_ctor_get(x_161, 3); +x_177 = lean_ctor_get(x_161, 4); lean_inc(x_177); -x_178 = lean_ctor_get(x_173, 1); -lean_inc(x_178); -lean_dec(x_173); -x_179 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_179, 0, x_177); -x_59 = x_179; -x_60 = x_178; -goto block_153; +lean_inc(x_176); +lean_inc(x_175); +lean_dec(x_161); +x_178 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_178, 0, x_175); +lean_ctor_set(x_178, 1, x_20); +lean_ctor_set(x_178, 2, x_21); +lean_ctor_set(x_178, 3, x_176); +lean_ctor_set(x_178, 4, x_177); +lean_ctor_set(x_3, 0, x_178); +x_179 = lean_apply_3(x_2, x_19, x_3, x_162); +if (lean_obj_tag(x_179) == 0) +{ +lean_object* x_180; lean_object* x_181; lean_object* x_182; +x_180 = lean_ctor_get(x_179, 0); +lean_inc(x_180); +x_181 = lean_ctor_get(x_179, 1); +lean_inc(x_181); +lean_dec(x_179); +x_182 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_182, 0, x_180); +x_59 = x_182; +x_60 = x_181; +goto block_159; +} +else +{ +lean_object* x_183; lean_object* x_184; lean_object* x_185; +x_183 = lean_ctor_get(x_179, 0); +lean_inc(x_183); +x_184 = lean_ctor_get(x_179, 1); +lean_inc(x_184); +lean_dec(x_179); +x_185 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_185, 0, x_183); +x_59 = x_185; +x_60 = x_184; +goto block_159; } } } else { -lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; uint8_t x_189; uint8_t x_190; uint8_t x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; -x_180 = lean_ctor_get(x_3, 1); -x_181 = lean_ctor_get(x_3, 2); -x_182 = lean_ctor_get(x_3, 3); -x_183 = lean_ctor_get(x_3, 4); -x_184 = lean_ctor_get(x_3, 5); -x_185 = lean_ctor_get(x_3, 6); -x_186 = lean_ctor_get(x_3, 7); -x_187 = lean_ctor_get(x_3, 8); -x_188 = lean_ctor_get(x_3, 9); -x_189 = lean_ctor_get_uint8(x_3, sizeof(void*)*10); -x_190 = lean_ctor_get_uint8(x_3, sizeof(void*)*10 + 1); -x_191 = lean_ctor_get_uint8(x_3, sizeof(void*)*10 + 2); +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; uint8_t x_195; uint8_t x_196; uint8_t x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; +x_186 = lean_ctor_get(x_3, 1); +x_187 = lean_ctor_get(x_3, 2); +x_188 = lean_ctor_get(x_3, 3); +x_189 = lean_ctor_get(x_3, 4); +x_190 = lean_ctor_get(x_3, 5); +x_191 = lean_ctor_get(x_3, 6); +x_192 = lean_ctor_get(x_3, 7); +x_193 = lean_ctor_get(x_3, 8); +x_194 = lean_ctor_get(x_3, 9); +x_195 = lean_ctor_get_uint8(x_3, sizeof(void*)*10); +x_196 = lean_ctor_get_uint8(x_3, sizeof(void*)*10 + 1); +x_197 = lean_ctor_get_uint8(x_3, sizeof(void*)*10 + 2); +lean_inc(x_194); +lean_inc(x_193); +lean_inc(x_192); +lean_inc(x_191); +lean_inc(x_190); +lean_inc(x_189); lean_inc(x_188); lean_inc(x_187); lean_inc(x_186); -lean_inc(x_185); -lean_inc(x_184); -lean_inc(x_183); -lean_inc(x_182); -lean_inc(x_181); -lean_inc(x_180); lean_dec(x_3); -x_192 = lean_ctor_get(x_155, 0); -lean_inc(x_192); -x_193 = lean_ctor_get(x_155, 3); -lean_inc(x_193); -x_194 = lean_ctor_get(x_155, 4); -lean_inc(x_194); -if (lean_is_exclusive(x_155)) { - lean_ctor_release(x_155, 0); - lean_ctor_release(x_155, 1); - lean_ctor_release(x_155, 2); - lean_ctor_release(x_155, 3); - lean_ctor_release(x_155, 4); - x_195 = x_155; -} else { - lean_dec_ref(x_155); - x_195 = lean_box(0); -} -if (lean_is_scalar(x_195)) { - x_196 = lean_alloc_ctor(0, 5, 0); -} else { - x_196 = x_195; -} -lean_ctor_set(x_196, 0, x_192); -lean_ctor_set(x_196, 1, x_20); -lean_ctor_set(x_196, 2, x_21); -lean_ctor_set(x_196, 3, x_193); -lean_ctor_set(x_196, 4, x_194); -x_197 = lean_alloc_ctor(0, 10, 3); -lean_ctor_set(x_197, 0, x_196); -lean_ctor_set(x_197, 1, x_180); -lean_ctor_set(x_197, 2, x_181); -lean_ctor_set(x_197, 3, x_182); -lean_ctor_set(x_197, 4, x_183); -lean_ctor_set(x_197, 5, x_184); -lean_ctor_set(x_197, 6, x_185); -lean_ctor_set(x_197, 7, x_186); -lean_ctor_set(x_197, 8, x_187); -lean_ctor_set(x_197, 9, x_188); -lean_ctor_set_uint8(x_197, sizeof(void*)*10, x_189); -lean_ctor_set_uint8(x_197, sizeof(void*)*10 + 1, x_190); -lean_ctor_set_uint8(x_197, sizeof(void*)*10 + 2, x_191); -x_198 = lean_apply_3(x_2, x_19, x_197, x_156); -if (lean_obj_tag(x_198) == 0) -{ -lean_object* x_199; lean_object* x_200; lean_object* x_201; -x_199 = lean_ctor_get(x_198, 0); +x_198 = lean_ctor_get(x_161, 0); +lean_inc(x_198); +x_199 = lean_ctor_get(x_161, 3); lean_inc(x_199); -x_200 = lean_ctor_get(x_198, 1); +x_200 = lean_ctor_get(x_161, 4); lean_inc(x_200); -lean_dec(x_198); -x_201 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_201, 0, x_199); -x_59 = x_201; -x_60 = x_200; -goto block_153; +if (lean_is_exclusive(x_161)) { + lean_ctor_release(x_161, 0); + lean_ctor_release(x_161, 1); + lean_ctor_release(x_161, 2); + lean_ctor_release(x_161, 3); + lean_ctor_release(x_161, 4); + x_201 = x_161; +} else { + lean_dec_ref(x_161); + x_201 = lean_box(0); +} +if (lean_is_scalar(x_201)) { + x_202 = lean_alloc_ctor(0, 5, 0); +} else { + x_202 = x_201; +} +lean_ctor_set(x_202, 0, x_198); +lean_ctor_set(x_202, 1, x_20); +lean_ctor_set(x_202, 2, x_21); +lean_ctor_set(x_202, 3, x_199); +lean_ctor_set(x_202, 4, x_200); +x_203 = lean_alloc_ctor(0, 10, 3); +lean_ctor_set(x_203, 0, x_202); +lean_ctor_set(x_203, 1, x_186); +lean_ctor_set(x_203, 2, x_187); +lean_ctor_set(x_203, 3, x_188); +lean_ctor_set(x_203, 4, x_189); +lean_ctor_set(x_203, 5, x_190); +lean_ctor_set(x_203, 6, x_191); +lean_ctor_set(x_203, 7, x_192); +lean_ctor_set(x_203, 8, x_193); +lean_ctor_set(x_203, 9, x_194); +lean_ctor_set_uint8(x_203, sizeof(void*)*10, x_195); +lean_ctor_set_uint8(x_203, sizeof(void*)*10 + 1, x_196); +lean_ctor_set_uint8(x_203, sizeof(void*)*10 + 2, x_197); +x_204 = lean_apply_3(x_2, x_19, x_203, x_162); +if (lean_obj_tag(x_204) == 0) +{ +lean_object* x_205; lean_object* x_206; lean_object* x_207; +x_205 = lean_ctor_get(x_204, 0); +lean_inc(x_205); +x_206 = lean_ctor_get(x_204, 1); +lean_inc(x_206); +lean_dec(x_204); +x_207 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_207, 0, x_205); +x_59 = x_207; +x_60 = x_206; +goto block_159; } else { -lean_object* x_202; lean_object* x_203; lean_object* x_204; -x_202 = lean_ctor_get(x_198, 0); -lean_inc(x_202); -x_203 = lean_ctor_get(x_198, 1); -lean_inc(x_203); -lean_dec(x_198); -x_204 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_204, 0, x_202); -x_59 = x_204; -x_60 = x_203; -goto block_153; +lean_object* x_208; lean_object* x_209; lean_object* x_210; +x_208 = lean_ctor_get(x_204, 0); +lean_inc(x_208); +x_209 = lean_ctor_get(x_204, 1); +lean_inc(x_209); +lean_dec(x_204); +x_210 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_210, 0, x_208); +x_59 = x_210; +x_60 = x_209; +goto block_159; } } -block_153: +block_159: { if (lean_obj_tag(x_59) == 0) { @@ -4768,113 +4768,120 @@ return x_70; } else { -lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; +lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; x_71 = lean_ctor_get(x_62, 0); x_72 = lean_ctor_get(x_62, 1); x_73 = lean_ctor_get(x_62, 3); +x_74 = lean_ctor_get(x_62, 4); +lean_inc(x_74); lean_inc(x_73); lean_inc(x_72); lean_inc(x_71); lean_dec(x_62); -x_74 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_74, 0, x_71); -lean_ctor_set(x_74, 1, x_72); -lean_ctor_set(x_74, 2, x_58); -lean_ctor_set(x_74, 3, x_73); -lean_ctor_set(x_61, 2, x_74); +x_75 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_75, 0, x_71); +lean_ctor_set(x_75, 1, x_72); +lean_ctor_set(x_75, 2, x_58); +lean_ctor_set(x_75, 3, x_73); +lean_ctor_set(x_75, 4, x_74); +lean_ctor_set(x_61, 2, x_75); if (lean_is_scalar(x_18)) { - x_75 = lean_alloc_ctor(1, 2, 0); + x_76 = lean_alloc_ctor(1, 2, 0); } else { - x_75 = x_18; - lean_ctor_set_tag(x_75, 1); + x_76 = x_18; + lean_ctor_set_tag(x_76, 1); } -lean_ctor_set(x_75, 0, x_63); -lean_ctor_set(x_75, 1, x_60); -return x_75; +lean_ctor_set(x_76, 0, x_63); +lean_ctor_set(x_76, 1, x_60); +return x_76; } } else { -lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; -x_76 = lean_ctor_get(x_61, 0); -x_77 = lean_ctor_get(x_61, 1); -x_78 = lean_ctor_get(x_61, 3); -x_79 = lean_ctor_get(x_61, 4); -x_80 = lean_ctor_get(x_61, 5); +lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; +x_77 = lean_ctor_get(x_61, 0); +x_78 = lean_ctor_get(x_61, 1); +x_79 = lean_ctor_get(x_61, 3); +x_80 = lean_ctor_get(x_61, 4); +x_81 = lean_ctor_get(x_61, 5); +lean_inc(x_81); lean_inc(x_80); lean_inc(x_79); lean_inc(x_78); lean_inc(x_77); -lean_inc(x_76); lean_dec(x_61); -x_81 = lean_ctor_get(x_62, 0); -lean_inc(x_81); -x_82 = lean_ctor_get(x_62, 1); +x_82 = lean_ctor_get(x_62, 0); lean_inc(x_82); -x_83 = lean_ctor_get(x_62, 3); +x_83 = lean_ctor_get(x_62, 1); lean_inc(x_83); +x_84 = lean_ctor_get(x_62, 3); +lean_inc(x_84); +x_85 = lean_ctor_get(x_62, 4); +lean_inc(x_85); if (lean_is_exclusive(x_62)) { lean_ctor_release(x_62, 0); lean_ctor_release(x_62, 1); lean_ctor_release(x_62, 2); lean_ctor_release(x_62, 3); - x_84 = x_62; + lean_ctor_release(x_62, 4); + x_86 = x_62; } else { lean_dec_ref(x_62); - x_84 = lean_box(0); + x_86 = lean_box(0); } -if (lean_is_scalar(x_84)) { - x_85 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_86)) { + x_87 = lean_alloc_ctor(0, 5, 0); } else { - x_85 = x_84; + x_87 = x_86; } -lean_ctor_set(x_85, 0, x_81); -lean_ctor_set(x_85, 1, x_82); -lean_ctor_set(x_85, 2, x_58); -lean_ctor_set(x_85, 3, x_83); -x_86 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_86, 0, x_76); -lean_ctor_set(x_86, 1, x_77); -lean_ctor_set(x_86, 2, x_85); -lean_ctor_set(x_86, 3, x_78); -lean_ctor_set(x_86, 4, x_79); -lean_ctor_set(x_86, 5, x_80); -lean_ctor_set(x_60, 0, x_86); +lean_ctor_set(x_87, 0, x_82); +lean_ctor_set(x_87, 1, x_83); +lean_ctor_set(x_87, 2, x_58); +lean_ctor_set(x_87, 3, x_84); +lean_ctor_set(x_87, 4, x_85); +x_88 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_88, 0, x_77); +lean_ctor_set(x_88, 1, x_78); +lean_ctor_set(x_88, 2, x_87); +lean_ctor_set(x_88, 3, x_79); +lean_ctor_set(x_88, 4, x_80); +lean_ctor_set(x_88, 5, x_81); +lean_ctor_set(x_60, 0, x_88); if (lean_is_scalar(x_18)) { - x_87 = lean_alloc_ctor(1, 2, 0); + x_89 = lean_alloc_ctor(1, 2, 0); } else { - x_87 = x_18; - lean_ctor_set_tag(x_87, 1); + x_89 = x_18; + lean_ctor_set_tag(x_89, 1); } -lean_ctor_set(x_87, 0, x_63); -lean_ctor_set(x_87, 1, x_60); -return x_87; +lean_ctor_set(x_89, 0, x_63); +lean_ctor_set(x_89, 1, x_60); +return x_89; } } else { -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; -x_88 = lean_ctor_get(x_60, 1); -x_89 = lean_ctor_get(x_60, 2); -x_90 = lean_ctor_get(x_60, 3); -x_91 = lean_ctor_get(x_60, 4); -x_92 = lean_ctor_get(x_60, 5); +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; +x_90 = lean_ctor_get(x_60, 1); +x_91 = lean_ctor_get(x_60, 2); +x_92 = lean_ctor_get(x_60, 3); +x_93 = lean_ctor_get(x_60, 4); +x_94 = lean_ctor_get(x_60, 5); +lean_inc(x_94); +lean_inc(x_93); lean_inc(x_92); lean_inc(x_91); lean_inc(x_90); -lean_inc(x_89); -lean_inc(x_88); lean_dec(x_60); -x_93 = lean_ctor_get(x_61, 0); -lean_inc(x_93); -x_94 = lean_ctor_get(x_61, 1); -lean_inc(x_94); -x_95 = lean_ctor_get(x_61, 3); +x_95 = lean_ctor_get(x_61, 0); lean_inc(x_95); -x_96 = lean_ctor_get(x_61, 4); +x_96 = lean_ctor_get(x_61, 1); lean_inc(x_96); -x_97 = lean_ctor_get(x_61, 5); +x_97 = lean_ctor_get(x_61, 3); lean_inc(x_97); +x_98 = lean_ctor_get(x_61, 4); +lean_inc(x_98); +x_99 = lean_ctor_get(x_61, 5); +lean_inc(x_99); if (lean_is_exclusive(x_61)) { lean_ctor_release(x_61, 0); lean_ctor_release(x_61, 1); @@ -4882,273 +4889,288 @@ if (lean_is_exclusive(x_61)) { lean_ctor_release(x_61, 3); lean_ctor_release(x_61, 4); lean_ctor_release(x_61, 5); - x_98 = x_61; + x_100 = x_61; } else { lean_dec_ref(x_61); - x_98 = lean_box(0); + x_100 = lean_box(0); } -x_99 = lean_ctor_get(x_62, 0); -lean_inc(x_99); -x_100 = lean_ctor_get(x_62, 1); -lean_inc(x_100); -x_101 = lean_ctor_get(x_62, 3); +x_101 = lean_ctor_get(x_62, 0); lean_inc(x_101); +x_102 = lean_ctor_get(x_62, 1); +lean_inc(x_102); +x_103 = lean_ctor_get(x_62, 3); +lean_inc(x_103); +x_104 = lean_ctor_get(x_62, 4); +lean_inc(x_104); if (lean_is_exclusive(x_62)) { lean_ctor_release(x_62, 0); lean_ctor_release(x_62, 1); lean_ctor_release(x_62, 2); lean_ctor_release(x_62, 3); - x_102 = x_62; + lean_ctor_release(x_62, 4); + x_105 = x_62; } else { lean_dec_ref(x_62); - x_102 = lean_box(0); + x_105 = lean_box(0); } -if (lean_is_scalar(x_102)) { - x_103 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_105)) { + x_106 = lean_alloc_ctor(0, 5, 0); } else { - x_103 = x_102; + x_106 = x_105; } -lean_ctor_set(x_103, 0, x_99); -lean_ctor_set(x_103, 1, x_100); -lean_ctor_set(x_103, 2, x_58); -lean_ctor_set(x_103, 3, x_101); -if (lean_is_scalar(x_98)) { - x_104 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_106, 0, x_101); +lean_ctor_set(x_106, 1, x_102); +lean_ctor_set(x_106, 2, x_58); +lean_ctor_set(x_106, 3, x_103); +lean_ctor_set(x_106, 4, x_104); +if (lean_is_scalar(x_100)) { + x_107 = lean_alloc_ctor(0, 6, 0); } else { - x_104 = x_98; + x_107 = x_100; } -lean_ctor_set(x_104, 0, x_93); -lean_ctor_set(x_104, 1, x_94); -lean_ctor_set(x_104, 2, x_103); -lean_ctor_set(x_104, 3, x_95); -lean_ctor_set(x_104, 4, x_96); -lean_ctor_set(x_104, 5, x_97); -x_105 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_105, 0, x_104); -lean_ctor_set(x_105, 1, x_88); -lean_ctor_set(x_105, 2, x_89); -lean_ctor_set(x_105, 3, x_90); -lean_ctor_set(x_105, 4, x_91); -lean_ctor_set(x_105, 5, x_92); +lean_ctor_set(x_107, 0, x_95); +lean_ctor_set(x_107, 1, x_96); +lean_ctor_set(x_107, 2, x_106); +lean_ctor_set(x_107, 3, x_97); +lean_ctor_set(x_107, 4, x_98); +lean_ctor_set(x_107, 5, x_99); +x_108 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_108, 0, x_107); +lean_ctor_set(x_108, 1, x_90); +lean_ctor_set(x_108, 2, x_91); +lean_ctor_set(x_108, 3, x_92); +lean_ctor_set(x_108, 4, x_93); +lean_ctor_set(x_108, 5, x_94); if (lean_is_scalar(x_18)) { - x_106 = lean_alloc_ctor(1, 2, 0); + x_109 = lean_alloc_ctor(1, 2, 0); } else { - x_106 = x_18; - lean_ctor_set_tag(x_106, 1); + x_109 = x_18; + lean_ctor_set_tag(x_109, 1); } -lean_ctor_set(x_106, 0, x_63); -lean_ctor_set(x_106, 1, x_105); -return x_106; +lean_ctor_set(x_109, 0, x_63); +lean_ctor_set(x_109, 1, x_108); +return x_109; } } else { -lean_object* x_107; lean_object* x_108; lean_object* x_109; uint8_t x_110; -x_107 = lean_ctor_get(x_60, 0); -lean_inc(x_107); -x_108 = lean_ctor_get(x_107, 2); -lean_inc(x_108); -x_109 = lean_ctor_get(x_59, 0); -lean_inc(x_109); +lean_object* x_110; lean_object* x_111; lean_object* x_112; uint8_t x_113; +x_110 = lean_ctor_get(x_60, 0); +lean_inc(x_110); +x_111 = lean_ctor_get(x_110, 2); +lean_inc(x_111); +x_112 = lean_ctor_get(x_59, 0); +lean_inc(x_112); lean_dec(x_59); -x_110 = !lean_is_exclusive(x_60); -if (x_110 == 0) +x_113 = !lean_is_exclusive(x_60); +if (x_113 == 0) { -lean_object* x_111; uint8_t x_112; -x_111 = lean_ctor_get(x_60, 0); -lean_dec(x_111); -x_112 = !lean_is_exclusive(x_107); -if (x_112 == 0) +lean_object* x_114; uint8_t x_115; +x_114 = lean_ctor_get(x_60, 0); +lean_dec(x_114); +x_115 = !lean_is_exclusive(x_110); +if (x_115 == 0) { -lean_object* x_113; uint8_t x_114; -x_113 = lean_ctor_get(x_107, 2); -lean_dec(x_113); -x_114 = !lean_is_exclusive(x_108); -if (x_114 == 0) +lean_object* x_116; uint8_t x_117; +x_116 = lean_ctor_get(x_110, 2); +lean_dec(x_116); +x_117 = !lean_is_exclusive(x_111); +if (x_117 == 0) { -lean_object* x_115; lean_object* x_116; -x_115 = lean_ctor_get(x_108, 2); -lean_dec(x_115); -lean_ctor_set(x_108, 2, x_58); +lean_object* x_118; lean_object* x_119; +x_118 = lean_ctor_get(x_111, 2); +lean_dec(x_118); +lean_ctor_set(x_111, 2, x_58); if (lean_is_scalar(x_18)) { - x_116 = lean_alloc_ctor(0, 2, 0); + x_119 = lean_alloc_ctor(0, 2, 0); } else { - x_116 = x_18; + x_119 = x_18; } -lean_ctor_set(x_116, 0, x_109); -lean_ctor_set(x_116, 1, x_60); -return x_116; +lean_ctor_set(x_119, 0, x_112); +lean_ctor_set(x_119, 1, x_60); +return x_119; } else { -lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; -x_117 = lean_ctor_get(x_108, 0); -x_118 = lean_ctor_get(x_108, 1); -x_119 = lean_ctor_get(x_108, 3); -lean_inc(x_119); -lean_inc(x_118); -lean_inc(x_117); -lean_dec(x_108); -x_120 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_120, 0, x_117); -lean_ctor_set(x_120, 1, x_118); -lean_ctor_set(x_120, 2, x_58); -lean_ctor_set(x_120, 3, x_119); -lean_ctor_set(x_107, 2, x_120); -if (lean_is_scalar(x_18)) { - x_121 = lean_alloc_ctor(0, 2, 0); -} else { - x_121 = x_18; -} -lean_ctor_set(x_121, 0, x_109); -lean_ctor_set(x_121, 1, x_60); -return x_121; -} -} -else -{ -lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; -x_122 = lean_ctor_get(x_107, 0); -x_123 = lean_ctor_get(x_107, 1); -x_124 = lean_ctor_get(x_107, 3); -x_125 = lean_ctor_get(x_107, 4); -x_126 = lean_ctor_get(x_107, 5); -lean_inc(x_126); -lean_inc(x_125); -lean_inc(x_124); +lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; +x_120 = lean_ctor_get(x_111, 0); +x_121 = lean_ctor_get(x_111, 1); +x_122 = lean_ctor_get(x_111, 3); +x_123 = lean_ctor_get(x_111, 4); lean_inc(x_123); lean_inc(x_122); -lean_dec(x_107); -x_127 = lean_ctor_get(x_108, 0); -lean_inc(x_127); -x_128 = lean_ctor_get(x_108, 1); -lean_inc(x_128); -x_129 = lean_ctor_get(x_108, 3); +lean_inc(x_121); +lean_inc(x_120); +lean_dec(x_111); +x_124 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_124, 0, x_120); +lean_ctor_set(x_124, 1, x_121); +lean_ctor_set(x_124, 2, x_58); +lean_ctor_set(x_124, 3, x_122); +lean_ctor_set(x_124, 4, x_123); +lean_ctor_set(x_110, 2, x_124); +if (lean_is_scalar(x_18)) { + x_125 = lean_alloc_ctor(0, 2, 0); +} else { + x_125 = x_18; +} +lean_ctor_set(x_125, 0, x_112); +lean_ctor_set(x_125, 1, x_60); +return x_125; +} +} +else +{ +lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; +x_126 = lean_ctor_get(x_110, 0); +x_127 = lean_ctor_get(x_110, 1); +x_128 = lean_ctor_get(x_110, 3); +x_129 = lean_ctor_get(x_110, 4); +x_130 = lean_ctor_get(x_110, 5); +lean_inc(x_130); lean_inc(x_129); -if (lean_is_exclusive(x_108)) { - lean_ctor_release(x_108, 0); - lean_ctor_release(x_108, 1); - lean_ctor_release(x_108, 2); - lean_ctor_release(x_108, 3); - x_130 = x_108; -} else { - lean_dec_ref(x_108); - x_130 = lean_box(0); -} -if (lean_is_scalar(x_130)) { - x_131 = lean_alloc_ctor(0, 4, 0); -} else { - x_131 = x_130; -} -lean_ctor_set(x_131, 0, x_127); -lean_ctor_set(x_131, 1, x_128); -lean_ctor_set(x_131, 2, x_58); -lean_ctor_set(x_131, 3, x_129); -x_132 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_132, 0, x_122); -lean_ctor_set(x_132, 1, x_123); -lean_ctor_set(x_132, 2, x_131); -lean_ctor_set(x_132, 3, x_124); -lean_ctor_set(x_132, 4, x_125); -lean_ctor_set(x_132, 5, x_126); -lean_ctor_set(x_60, 0, x_132); -if (lean_is_scalar(x_18)) { - x_133 = lean_alloc_ctor(0, 2, 0); -} else { - x_133 = x_18; -} -lean_ctor_set(x_133, 0, x_109); -lean_ctor_set(x_133, 1, x_60); -return x_133; -} -} -else -{ -lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; -x_134 = lean_ctor_get(x_60, 1); -x_135 = lean_ctor_get(x_60, 2); -x_136 = lean_ctor_get(x_60, 3); -x_137 = lean_ctor_get(x_60, 4); -x_138 = lean_ctor_get(x_60, 5); -lean_inc(x_138); -lean_inc(x_137); -lean_inc(x_136); -lean_inc(x_135); +lean_inc(x_128); +lean_inc(x_127); +lean_inc(x_126); +lean_dec(x_110); +x_131 = lean_ctor_get(x_111, 0); +lean_inc(x_131); +x_132 = lean_ctor_get(x_111, 1); +lean_inc(x_132); +x_133 = lean_ctor_get(x_111, 3); +lean_inc(x_133); +x_134 = lean_ctor_get(x_111, 4); lean_inc(x_134); -lean_dec(x_60); -x_139 = lean_ctor_get(x_107, 0); -lean_inc(x_139); -x_140 = lean_ctor_get(x_107, 1); -lean_inc(x_140); -x_141 = lean_ctor_get(x_107, 3); -lean_inc(x_141); -x_142 = lean_ctor_get(x_107, 4); -lean_inc(x_142); -x_143 = lean_ctor_get(x_107, 5); -lean_inc(x_143); -if (lean_is_exclusive(x_107)) { - lean_ctor_release(x_107, 0); - lean_ctor_release(x_107, 1); - lean_ctor_release(x_107, 2); - lean_ctor_release(x_107, 3); - lean_ctor_release(x_107, 4); - lean_ctor_release(x_107, 5); - x_144 = x_107; +if (lean_is_exclusive(x_111)) { + lean_ctor_release(x_111, 0); + lean_ctor_release(x_111, 1); + lean_ctor_release(x_111, 2); + lean_ctor_release(x_111, 3); + lean_ctor_release(x_111, 4); + x_135 = x_111; } else { - lean_dec_ref(x_107); - x_144 = lean_box(0); + lean_dec_ref(x_111); + x_135 = lean_box(0); } -x_145 = lean_ctor_get(x_108, 0); -lean_inc(x_145); -x_146 = lean_ctor_get(x_108, 1); -lean_inc(x_146); -x_147 = lean_ctor_get(x_108, 3); -lean_inc(x_147); -if (lean_is_exclusive(x_108)) { - lean_ctor_release(x_108, 0); - lean_ctor_release(x_108, 1); - lean_ctor_release(x_108, 2); - lean_ctor_release(x_108, 3); - x_148 = x_108; +if (lean_is_scalar(x_135)) { + x_136 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_108); - x_148 = lean_box(0); + x_136 = x_135; } -if (lean_is_scalar(x_148)) { - x_149 = lean_alloc_ctor(0, 4, 0); -} else { - x_149 = x_148; -} -lean_ctor_set(x_149, 0, x_145); -lean_ctor_set(x_149, 1, x_146); -lean_ctor_set(x_149, 2, x_58); -lean_ctor_set(x_149, 3, x_147); -if (lean_is_scalar(x_144)) { - x_150 = lean_alloc_ctor(0, 6, 0); -} else { - x_150 = x_144; -} -lean_ctor_set(x_150, 0, x_139); -lean_ctor_set(x_150, 1, x_140); -lean_ctor_set(x_150, 2, x_149); -lean_ctor_set(x_150, 3, x_141); -lean_ctor_set(x_150, 4, x_142); -lean_ctor_set(x_150, 5, x_143); -x_151 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_151, 0, x_150); -lean_ctor_set(x_151, 1, x_134); -lean_ctor_set(x_151, 2, x_135); -lean_ctor_set(x_151, 3, x_136); -lean_ctor_set(x_151, 4, x_137); -lean_ctor_set(x_151, 5, x_138); +lean_ctor_set(x_136, 0, x_131); +lean_ctor_set(x_136, 1, x_132); +lean_ctor_set(x_136, 2, x_58); +lean_ctor_set(x_136, 3, x_133); +lean_ctor_set(x_136, 4, x_134); +x_137 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_137, 0, x_126); +lean_ctor_set(x_137, 1, x_127); +lean_ctor_set(x_137, 2, x_136); +lean_ctor_set(x_137, 3, x_128); +lean_ctor_set(x_137, 4, x_129); +lean_ctor_set(x_137, 5, x_130); +lean_ctor_set(x_60, 0, x_137); if (lean_is_scalar(x_18)) { - x_152 = lean_alloc_ctor(0, 2, 0); + x_138 = lean_alloc_ctor(0, 2, 0); } else { - x_152 = x_18; + x_138 = x_18; } -lean_ctor_set(x_152, 0, x_109); -lean_ctor_set(x_152, 1, x_151); -return x_152; +lean_ctor_set(x_138, 0, x_112); +lean_ctor_set(x_138, 1, x_60); +return x_138; +} +} +else +{ +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; +x_139 = lean_ctor_get(x_60, 1); +x_140 = lean_ctor_get(x_60, 2); +x_141 = lean_ctor_get(x_60, 3); +x_142 = lean_ctor_get(x_60, 4); +x_143 = lean_ctor_get(x_60, 5); +lean_inc(x_143); +lean_inc(x_142); +lean_inc(x_141); +lean_inc(x_140); +lean_inc(x_139); +lean_dec(x_60); +x_144 = lean_ctor_get(x_110, 0); +lean_inc(x_144); +x_145 = lean_ctor_get(x_110, 1); +lean_inc(x_145); +x_146 = lean_ctor_get(x_110, 3); +lean_inc(x_146); +x_147 = lean_ctor_get(x_110, 4); +lean_inc(x_147); +x_148 = lean_ctor_get(x_110, 5); +lean_inc(x_148); +if (lean_is_exclusive(x_110)) { + lean_ctor_release(x_110, 0); + lean_ctor_release(x_110, 1); + lean_ctor_release(x_110, 2); + lean_ctor_release(x_110, 3); + lean_ctor_release(x_110, 4); + lean_ctor_release(x_110, 5); + x_149 = x_110; +} else { + lean_dec_ref(x_110); + x_149 = lean_box(0); +} +x_150 = lean_ctor_get(x_111, 0); +lean_inc(x_150); +x_151 = lean_ctor_get(x_111, 1); +lean_inc(x_151); +x_152 = lean_ctor_get(x_111, 3); +lean_inc(x_152); +x_153 = lean_ctor_get(x_111, 4); +lean_inc(x_153); +if (lean_is_exclusive(x_111)) { + lean_ctor_release(x_111, 0); + lean_ctor_release(x_111, 1); + lean_ctor_release(x_111, 2); + lean_ctor_release(x_111, 3); + lean_ctor_release(x_111, 4); + x_154 = x_111; +} else { + lean_dec_ref(x_111); + x_154 = lean_box(0); +} +if (lean_is_scalar(x_154)) { + x_155 = lean_alloc_ctor(0, 5, 0); +} else { + x_155 = x_154; +} +lean_ctor_set(x_155, 0, x_150); +lean_ctor_set(x_155, 1, x_151); +lean_ctor_set(x_155, 2, x_58); +lean_ctor_set(x_155, 3, x_152); +lean_ctor_set(x_155, 4, x_153); +if (lean_is_scalar(x_149)) { + x_156 = lean_alloc_ctor(0, 6, 0); +} else { + x_156 = x_149; +} +lean_ctor_set(x_156, 0, x_144); +lean_ctor_set(x_156, 1, x_145); +lean_ctor_set(x_156, 2, x_155); +lean_ctor_set(x_156, 3, x_146); +lean_ctor_set(x_156, 4, x_147); +lean_ctor_set(x_156, 5, x_148); +x_157 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_157, 0, x_156); +lean_ctor_set(x_157, 1, x_139); +lean_ctor_set(x_157, 2, x_140); +lean_ctor_set(x_157, 3, x_141); +lean_ctor_set(x_157, 4, x_142); +lean_ctor_set(x_157, 5, x_143); +if (lean_is_scalar(x_18)) { + x_158 = lean_alloc_ctor(0, 2, 0); +} else { + x_158 = x_18; +} +lean_ctor_set(x_158, 0, x_112); +lean_ctor_set(x_158, 1, x_157); +return x_158; } } } @@ -5156,36 +5178,36 @@ return x_152; } else { -uint8_t x_205; +uint8_t x_211; lean_dec(x_10); lean_dec(x_3); lean_dec(x_2); -x_205 = !lean_is_exclusive(x_14); -if (x_205 == 0) +x_211 = !lean_is_exclusive(x_14); +if (x_211 == 0) { return x_14; } else { -lean_object* x_206; lean_object* x_207; lean_object* x_208; -x_206 = lean_ctor_get(x_14, 0); -x_207 = lean_ctor_get(x_14, 1); -lean_inc(x_207); -lean_inc(x_206); +lean_object* x_212; lean_object* x_213; lean_object* x_214; +x_212 = lean_ctor_get(x_14, 0); +x_213 = lean_ctor_get(x_14, 1); +lean_inc(x_213); +lean_inc(x_212); lean_dec(x_14); -x_208 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_208, 0, x_206); -lean_ctor_set(x_208, 1, x_207); -return x_208; +x_214 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_214, 0, x_212); +lean_ctor_set(x_214, 1, x_213); +return x_214; } } } else { -lean_object* x_209; lean_object* x_210; -x_209 = l_Array_empty___closed__1; -x_210 = lean_apply_3(x_2, x_209, x_3, x_4); -return x_210; +lean_object* x_215; lean_object* x_216; +x_215 = l_Array_empty___closed__1; +x_216 = lean_apply_3(x_2, x_215, x_3, x_4); +return x_216; } } } @@ -21181,7 +21203,7 @@ return x_57; } else { -lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_156; lean_object* x_157; lean_object* x_158; uint8_t x_159; +lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_162; lean_object* x_163; lean_object* x_164; uint8_t x_165; x_58 = lean_ctor_get(x_18, 0); lean_inc(x_58); x_59 = lean_ctor_get(x_58, 2); @@ -21190,203 +21212,203 @@ lean_dec(x_58); x_60 = lean_ctor_get(x_59, 2); lean_inc(x_60); lean_dec(x_59); -x_156 = l_Lean_Elab_Term_resetSynthInstanceCache___rarg(x_18); -x_157 = lean_ctor_get(x_4, 0); -lean_inc(x_157); -x_158 = lean_ctor_get(x_156, 1); -lean_inc(x_158); -lean_dec(x_156); -x_159 = !lean_is_exclusive(x_4); -if (x_159 == 0) -{ -lean_object* x_160; uint8_t x_161; -x_160 = lean_ctor_get(x_4, 0); -lean_dec(x_160); -x_161 = !lean_is_exclusive(x_157); -if (x_161 == 0) -{ -lean_object* x_162; lean_object* x_163; lean_object* x_164; -x_162 = lean_ctor_get(x_157, 2); +x_162 = l_Lean_Elab_Term_resetSynthInstanceCache___rarg(x_18); +x_163 = lean_ctor_get(x_4, 0); +lean_inc(x_163); +x_164 = lean_ctor_get(x_162, 1); +lean_inc(x_164); lean_dec(x_162); -x_163 = lean_ctor_get(x_157, 1); -lean_dec(x_163); -lean_ctor_set(x_157, 2, x_23); -lean_ctor_set(x_157, 1, x_22); -x_164 = lean_apply_4(x_3, x_21, x_24, x_4, x_158); -if (lean_obj_tag(x_164) == 0) +x_165 = !lean_is_exclusive(x_4); +if (x_165 == 0) { -lean_object* x_165; lean_object* x_166; lean_object* x_167; -x_165 = lean_ctor_get(x_164, 0); -lean_inc(x_165); -x_166 = lean_ctor_get(x_164, 1); -lean_inc(x_166); -lean_dec(x_164); -x_167 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_167, 0, x_165); -x_61 = x_167; -x_62 = x_166; -goto block_155; -} -else +lean_object* x_166; uint8_t x_167; +x_166 = lean_ctor_get(x_4, 0); +lean_dec(x_166); +x_167 = !lean_is_exclusive(x_163); +if (x_167 == 0) { lean_object* x_168; lean_object* x_169; lean_object* x_170; -x_168 = lean_ctor_get(x_164, 0); -lean_inc(x_168); -x_169 = lean_ctor_get(x_164, 1); -lean_inc(x_169); -lean_dec(x_164); -x_170 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_170, 0, x_168); -x_61 = x_170; -x_62 = x_169; -goto block_155; -} -} -else +x_168 = lean_ctor_get(x_163, 2); +lean_dec(x_168); +x_169 = lean_ctor_get(x_163, 1); +lean_dec(x_169); +lean_ctor_set(x_163, 2, x_23); +lean_ctor_set(x_163, 1, x_22); +x_170 = lean_apply_4(x_3, x_21, x_24, x_4, x_164); +if (lean_obj_tag(x_170) == 0) { -lean_object* x_171; lean_object* x_172; lean_object* x_173; lean_object* x_174; lean_object* x_175; -x_171 = lean_ctor_get(x_157, 0); -x_172 = lean_ctor_get(x_157, 3); -x_173 = lean_ctor_get(x_157, 4); -lean_inc(x_173); -lean_inc(x_172); +lean_object* x_171; lean_object* x_172; lean_object* x_173; +x_171 = lean_ctor_get(x_170, 0); lean_inc(x_171); -lean_dec(x_157); -x_174 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_174, 0, x_171); -lean_ctor_set(x_174, 1, x_22); -lean_ctor_set(x_174, 2, x_23); -lean_ctor_set(x_174, 3, x_172); -lean_ctor_set(x_174, 4, x_173); -lean_ctor_set(x_4, 0, x_174); -x_175 = lean_apply_4(x_3, x_21, x_24, x_4, x_158); -if (lean_obj_tag(x_175) == 0) -{ -lean_object* x_176; lean_object* x_177; lean_object* x_178; -x_176 = lean_ctor_get(x_175, 0); -lean_inc(x_176); -x_177 = lean_ctor_get(x_175, 1); -lean_inc(x_177); -lean_dec(x_175); -x_178 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_178, 0, x_176); -x_61 = x_178; -x_62 = x_177; -goto block_155; +x_172 = lean_ctor_get(x_170, 1); +lean_inc(x_172); +lean_dec(x_170); +x_173 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_173, 0, x_171); +x_61 = x_173; +x_62 = x_172; +goto block_161; } else { -lean_object* x_179; lean_object* x_180; lean_object* x_181; -x_179 = lean_ctor_get(x_175, 0); +lean_object* x_174; lean_object* x_175; lean_object* x_176; +x_174 = lean_ctor_get(x_170, 0); +lean_inc(x_174); +x_175 = lean_ctor_get(x_170, 1); +lean_inc(x_175); +lean_dec(x_170); +x_176 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_176, 0, x_174); +x_61 = x_176; +x_62 = x_175; +goto block_161; +} +} +else +{ +lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; +x_177 = lean_ctor_get(x_163, 0); +x_178 = lean_ctor_get(x_163, 3); +x_179 = lean_ctor_get(x_163, 4); lean_inc(x_179); -x_180 = lean_ctor_get(x_175, 1); -lean_inc(x_180); -lean_dec(x_175); -x_181 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_181, 0, x_179); -x_61 = x_181; -x_62 = x_180; -goto block_155; +lean_inc(x_178); +lean_inc(x_177); +lean_dec(x_163); +x_180 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_180, 0, x_177); +lean_ctor_set(x_180, 1, x_22); +lean_ctor_set(x_180, 2, x_23); +lean_ctor_set(x_180, 3, x_178); +lean_ctor_set(x_180, 4, x_179); +lean_ctor_set(x_4, 0, x_180); +x_181 = lean_apply_4(x_3, x_21, x_24, x_4, x_164); +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_inc(x_183); +lean_dec(x_181); +x_184 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_184, 0, x_182); +x_61 = x_184; +x_62 = x_183; +goto block_161; +} +else +{ +lean_object* x_185; lean_object* x_186; lean_object* x_187; +x_185 = lean_ctor_get(x_181, 0); +lean_inc(x_185); +x_186 = lean_ctor_get(x_181, 1); +lean_inc(x_186); +lean_dec(x_181); +x_187 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_187, 0, x_185); +x_61 = x_187; +x_62 = x_186; +goto block_161; } } } else { -lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; uint8_t x_191; uint8_t x_192; uint8_t x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; -x_182 = lean_ctor_get(x_4, 1); -x_183 = lean_ctor_get(x_4, 2); -x_184 = lean_ctor_get(x_4, 3); -x_185 = lean_ctor_get(x_4, 4); -x_186 = lean_ctor_get(x_4, 5); -x_187 = lean_ctor_get(x_4, 6); -x_188 = lean_ctor_get(x_4, 7); -x_189 = lean_ctor_get(x_4, 8); -x_190 = lean_ctor_get(x_4, 9); -x_191 = lean_ctor_get_uint8(x_4, sizeof(void*)*10); -x_192 = lean_ctor_get_uint8(x_4, sizeof(void*)*10 + 1); -x_193 = lean_ctor_get_uint8(x_4, sizeof(void*)*10 + 2); +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; uint8_t x_197; uint8_t x_198; uint8_t x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; +x_188 = lean_ctor_get(x_4, 1); +x_189 = lean_ctor_get(x_4, 2); +x_190 = lean_ctor_get(x_4, 3); +x_191 = lean_ctor_get(x_4, 4); +x_192 = lean_ctor_get(x_4, 5); +x_193 = lean_ctor_get(x_4, 6); +x_194 = lean_ctor_get(x_4, 7); +x_195 = lean_ctor_get(x_4, 8); +x_196 = lean_ctor_get(x_4, 9); +x_197 = lean_ctor_get_uint8(x_4, sizeof(void*)*10); +x_198 = lean_ctor_get_uint8(x_4, sizeof(void*)*10 + 1); +x_199 = lean_ctor_get_uint8(x_4, sizeof(void*)*10 + 2); +lean_inc(x_196); +lean_inc(x_195); +lean_inc(x_194); +lean_inc(x_193); +lean_inc(x_192); +lean_inc(x_191); lean_inc(x_190); lean_inc(x_189); lean_inc(x_188); -lean_inc(x_187); -lean_inc(x_186); -lean_inc(x_185); -lean_inc(x_184); -lean_inc(x_183); -lean_inc(x_182); lean_dec(x_4); -x_194 = lean_ctor_get(x_157, 0); -lean_inc(x_194); -x_195 = lean_ctor_get(x_157, 3); -lean_inc(x_195); -x_196 = lean_ctor_get(x_157, 4); -lean_inc(x_196); -if (lean_is_exclusive(x_157)) { - lean_ctor_release(x_157, 0); - lean_ctor_release(x_157, 1); - lean_ctor_release(x_157, 2); - lean_ctor_release(x_157, 3); - lean_ctor_release(x_157, 4); - x_197 = x_157; -} else { - lean_dec_ref(x_157); - x_197 = lean_box(0); -} -if (lean_is_scalar(x_197)) { - x_198 = lean_alloc_ctor(0, 5, 0); -} else { - x_198 = x_197; -} -lean_ctor_set(x_198, 0, x_194); -lean_ctor_set(x_198, 1, x_22); -lean_ctor_set(x_198, 2, x_23); -lean_ctor_set(x_198, 3, x_195); -lean_ctor_set(x_198, 4, x_196); -x_199 = lean_alloc_ctor(0, 10, 3); -lean_ctor_set(x_199, 0, x_198); -lean_ctor_set(x_199, 1, x_182); -lean_ctor_set(x_199, 2, x_183); -lean_ctor_set(x_199, 3, x_184); -lean_ctor_set(x_199, 4, x_185); -lean_ctor_set(x_199, 5, x_186); -lean_ctor_set(x_199, 6, x_187); -lean_ctor_set(x_199, 7, x_188); -lean_ctor_set(x_199, 8, x_189); -lean_ctor_set(x_199, 9, x_190); -lean_ctor_set_uint8(x_199, sizeof(void*)*10, x_191); -lean_ctor_set_uint8(x_199, sizeof(void*)*10 + 1, x_192); -lean_ctor_set_uint8(x_199, sizeof(void*)*10 + 2, x_193); -x_200 = lean_apply_4(x_3, x_21, x_24, x_199, x_158); -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); +x_200 = lean_ctor_get(x_163, 0); +lean_inc(x_200); +x_201 = lean_ctor_get(x_163, 3); lean_inc(x_201); -x_202 = lean_ctor_get(x_200, 1); +x_202 = lean_ctor_get(x_163, 4); lean_inc(x_202); -lean_dec(x_200); -x_203 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_203, 0, x_201); -x_61 = x_203; -x_62 = x_202; -goto block_155; +if (lean_is_exclusive(x_163)) { + lean_ctor_release(x_163, 0); + lean_ctor_release(x_163, 1); + lean_ctor_release(x_163, 2); + lean_ctor_release(x_163, 3); + lean_ctor_release(x_163, 4); + x_203 = x_163; +} else { + lean_dec_ref(x_163); + x_203 = lean_box(0); +} +if (lean_is_scalar(x_203)) { + x_204 = lean_alloc_ctor(0, 5, 0); +} else { + x_204 = x_203; +} +lean_ctor_set(x_204, 0, x_200); +lean_ctor_set(x_204, 1, x_22); +lean_ctor_set(x_204, 2, x_23); +lean_ctor_set(x_204, 3, x_201); +lean_ctor_set(x_204, 4, x_202); +x_205 = lean_alloc_ctor(0, 10, 3); +lean_ctor_set(x_205, 0, x_204); +lean_ctor_set(x_205, 1, x_188); +lean_ctor_set(x_205, 2, x_189); +lean_ctor_set(x_205, 3, x_190); +lean_ctor_set(x_205, 4, x_191); +lean_ctor_set(x_205, 5, x_192); +lean_ctor_set(x_205, 6, x_193); +lean_ctor_set(x_205, 7, x_194); +lean_ctor_set(x_205, 8, x_195); +lean_ctor_set(x_205, 9, x_196); +lean_ctor_set_uint8(x_205, sizeof(void*)*10, x_197); +lean_ctor_set_uint8(x_205, sizeof(void*)*10 + 1, x_198); +lean_ctor_set_uint8(x_205, sizeof(void*)*10 + 2, x_199); +x_206 = lean_apply_4(x_3, x_21, x_24, x_205, x_164); +if (lean_obj_tag(x_206) == 0) +{ +lean_object* x_207; lean_object* x_208; lean_object* x_209; +x_207 = lean_ctor_get(x_206, 0); +lean_inc(x_207); +x_208 = lean_ctor_get(x_206, 1); +lean_inc(x_208); +lean_dec(x_206); +x_209 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_209, 0, x_207); +x_61 = x_209; +x_62 = x_208; +goto block_161; } else { -lean_object* x_204; lean_object* x_205; lean_object* x_206; -x_204 = lean_ctor_get(x_200, 0); -lean_inc(x_204); -x_205 = lean_ctor_get(x_200, 1); -lean_inc(x_205); -lean_dec(x_200); -x_206 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_206, 0, x_204); -x_61 = x_206; -x_62 = x_205; -goto block_155; +lean_object* x_210; lean_object* x_211; lean_object* x_212; +x_210 = lean_ctor_get(x_206, 0); +lean_inc(x_210); +x_211 = lean_ctor_get(x_206, 1); +lean_inc(x_211); +lean_dec(x_206); +x_212 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_212, 0, x_210); +x_61 = x_212; +x_62 = x_211; +goto block_161; } } -block_155: +block_161: { if (lean_obj_tag(x_61) == 0) { @@ -21429,113 +21451,120 @@ return x_72; } else { -lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; +lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; x_73 = lean_ctor_get(x_64, 0); x_74 = lean_ctor_get(x_64, 1); x_75 = lean_ctor_get(x_64, 3); +x_76 = lean_ctor_get(x_64, 4); +lean_inc(x_76); lean_inc(x_75); lean_inc(x_74); lean_inc(x_73); lean_dec(x_64); -x_76 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_76, 0, x_73); -lean_ctor_set(x_76, 1, x_74); -lean_ctor_set(x_76, 2, x_60); -lean_ctor_set(x_76, 3, x_75); -lean_ctor_set(x_63, 2, x_76); +x_77 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_77, 0, x_73); +lean_ctor_set(x_77, 1, x_74); +lean_ctor_set(x_77, 2, x_60); +lean_ctor_set(x_77, 3, x_75); +lean_ctor_set(x_77, 4, x_76); +lean_ctor_set(x_63, 2, x_77); if (lean_is_scalar(x_19)) { - x_77 = lean_alloc_ctor(1, 2, 0); + x_78 = lean_alloc_ctor(1, 2, 0); } else { - x_77 = x_19; - lean_ctor_set_tag(x_77, 1); + x_78 = x_19; + lean_ctor_set_tag(x_78, 1); } -lean_ctor_set(x_77, 0, x_65); -lean_ctor_set(x_77, 1, x_62); -return x_77; +lean_ctor_set(x_78, 0, x_65); +lean_ctor_set(x_78, 1, x_62); +return x_78; } } else { -lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; -x_78 = lean_ctor_get(x_63, 0); -x_79 = lean_ctor_get(x_63, 1); -x_80 = lean_ctor_get(x_63, 3); -x_81 = lean_ctor_get(x_63, 4); -x_82 = lean_ctor_get(x_63, 5); +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; +x_79 = lean_ctor_get(x_63, 0); +x_80 = lean_ctor_get(x_63, 1); +x_81 = lean_ctor_get(x_63, 3); +x_82 = lean_ctor_get(x_63, 4); +x_83 = lean_ctor_get(x_63, 5); +lean_inc(x_83); lean_inc(x_82); lean_inc(x_81); lean_inc(x_80); lean_inc(x_79); -lean_inc(x_78); lean_dec(x_63); -x_83 = lean_ctor_get(x_64, 0); -lean_inc(x_83); -x_84 = lean_ctor_get(x_64, 1); +x_84 = lean_ctor_get(x_64, 0); lean_inc(x_84); -x_85 = lean_ctor_get(x_64, 3); +x_85 = lean_ctor_get(x_64, 1); lean_inc(x_85); +x_86 = lean_ctor_get(x_64, 3); +lean_inc(x_86); +x_87 = lean_ctor_get(x_64, 4); +lean_inc(x_87); if (lean_is_exclusive(x_64)) { lean_ctor_release(x_64, 0); lean_ctor_release(x_64, 1); lean_ctor_release(x_64, 2); lean_ctor_release(x_64, 3); - x_86 = x_64; + lean_ctor_release(x_64, 4); + x_88 = x_64; } else { lean_dec_ref(x_64); - x_86 = lean_box(0); + x_88 = lean_box(0); } -if (lean_is_scalar(x_86)) { - x_87 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_88)) { + x_89 = lean_alloc_ctor(0, 5, 0); } else { - x_87 = x_86; + x_89 = x_88; } -lean_ctor_set(x_87, 0, x_83); -lean_ctor_set(x_87, 1, x_84); -lean_ctor_set(x_87, 2, x_60); -lean_ctor_set(x_87, 3, x_85); -x_88 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_88, 0, x_78); -lean_ctor_set(x_88, 1, x_79); -lean_ctor_set(x_88, 2, x_87); -lean_ctor_set(x_88, 3, x_80); -lean_ctor_set(x_88, 4, x_81); -lean_ctor_set(x_88, 5, x_82); -lean_ctor_set(x_62, 0, x_88); +lean_ctor_set(x_89, 0, x_84); +lean_ctor_set(x_89, 1, x_85); +lean_ctor_set(x_89, 2, x_60); +lean_ctor_set(x_89, 3, x_86); +lean_ctor_set(x_89, 4, x_87); +x_90 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_90, 0, x_79); +lean_ctor_set(x_90, 1, x_80); +lean_ctor_set(x_90, 2, x_89); +lean_ctor_set(x_90, 3, x_81); +lean_ctor_set(x_90, 4, x_82); +lean_ctor_set(x_90, 5, x_83); +lean_ctor_set(x_62, 0, x_90); if (lean_is_scalar(x_19)) { - x_89 = lean_alloc_ctor(1, 2, 0); + x_91 = lean_alloc_ctor(1, 2, 0); } else { - x_89 = x_19; - lean_ctor_set_tag(x_89, 1); + x_91 = x_19; + lean_ctor_set_tag(x_91, 1); } -lean_ctor_set(x_89, 0, x_65); -lean_ctor_set(x_89, 1, x_62); -return x_89; +lean_ctor_set(x_91, 0, x_65); +lean_ctor_set(x_91, 1, x_62); +return x_91; } } else { -lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; 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; -x_90 = lean_ctor_get(x_62, 1); -x_91 = lean_ctor_get(x_62, 2); -x_92 = lean_ctor_get(x_62, 3); -x_93 = lean_ctor_get(x_62, 4); -x_94 = lean_ctor_get(x_62, 5); +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; +x_92 = lean_ctor_get(x_62, 1); +x_93 = lean_ctor_get(x_62, 2); +x_94 = lean_ctor_get(x_62, 3); +x_95 = lean_ctor_get(x_62, 4); +x_96 = lean_ctor_get(x_62, 5); +lean_inc(x_96); +lean_inc(x_95); lean_inc(x_94); lean_inc(x_93); lean_inc(x_92); -lean_inc(x_91); -lean_inc(x_90); lean_dec(x_62); -x_95 = lean_ctor_get(x_63, 0); -lean_inc(x_95); -x_96 = lean_ctor_get(x_63, 1); -lean_inc(x_96); -x_97 = lean_ctor_get(x_63, 3); +x_97 = lean_ctor_get(x_63, 0); lean_inc(x_97); -x_98 = lean_ctor_get(x_63, 4); +x_98 = lean_ctor_get(x_63, 1); lean_inc(x_98); -x_99 = lean_ctor_get(x_63, 5); +x_99 = lean_ctor_get(x_63, 3); lean_inc(x_99); +x_100 = lean_ctor_get(x_63, 4); +lean_inc(x_100); +x_101 = lean_ctor_get(x_63, 5); +lean_inc(x_101); if (lean_is_exclusive(x_63)) { lean_ctor_release(x_63, 0); lean_ctor_release(x_63, 1); @@ -21543,273 +21572,288 @@ if (lean_is_exclusive(x_63)) { lean_ctor_release(x_63, 3); lean_ctor_release(x_63, 4); lean_ctor_release(x_63, 5); - x_100 = x_63; + x_102 = x_63; } else { lean_dec_ref(x_63); - x_100 = lean_box(0); + x_102 = lean_box(0); } -x_101 = lean_ctor_get(x_64, 0); -lean_inc(x_101); -x_102 = lean_ctor_get(x_64, 1); -lean_inc(x_102); -x_103 = lean_ctor_get(x_64, 3); +x_103 = lean_ctor_get(x_64, 0); lean_inc(x_103); +x_104 = lean_ctor_get(x_64, 1); +lean_inc(x_104); +x_105 = lean_ctor_get(x_64, 3); +lean_inc(x_105); +x_106 = lean_ctor_get(x_64, 4); +lean_inc(x_106); if (lean_is_exclusive(x_64)) { lean_ctor_release(x_64, 0); lean_ctor_release(x_64, 1); lean_ctor_release(x_64, 2); lean_ctor_release(x_64, 3); - x_104 = x_64; + lean_ctor_release(x_64, 4); + x_107 = x_64; } else { lean_dec_ref(x_64); - x_104 = lean_box(0); + x_107 = lean_box(0); } -if (lean_is_scalar(x_104)) { - x_105 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_107)) { + x_108 = lean_alloc_ctor(0, 5, 0); } else { - x_105 = x_104; + x_108 = x_107; } -lean_ctor_set(x_105, 0, x_101); -lean_ctor_set(x_105, 1, x_102); -lean_ctor_set(x_105, 2, x_60); -lean_ctor_set(x_105, 3, x_103); -if (lean_is_scalar(x_100)) { - x_106 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_108, 0, x_103); +lean_ctor_set(x_108, 1, x_104); +lean_ctor_set(x_108, 2, x_60); +lean_ctor_set(x_108, 3, x_105); +lean_ctor_set(x_108, 4, x_106); +if (lean_is_scalar(x_102)) { + x_109 = lean_alloc_ctor(0, 6, 0); } else { - x_106 = x_100; + x_109 = x_102; } -lean_ctor_set(x_106, 0, x_95); -lean_ctor_set(x_106, 1, x_96); -lean_ctor_set(x_106, 2, x_105); -lean_ctor_set(x_106, 3, x_97); -lean_ctor_set(x_106, 4, x_98); -lean_ctor_set(x_106, 5, x_99); -x_107 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_107, 0, x_106); -lean_ctor_set(x_107, 1, x_90); -lean_ctor_set(x_107, 2, x_91); -lean_ctor_set(x_107, 3, x_92); -lean_ctor_set(x_107, 4, x_93); -lean_ctor_set(x_107, 5, x_94); +lean_ctor_set(x_109, 0, x_97); +lean_ctor_set(x_109, 1, x_98); +lean_ctor_set(x_109, 2, x_108); +lean_ctor_set(x_109, 3, x_99); +lean_ctor_set(x_109, 4, x_100); +lean_ctor_set(x_109, 5, x_101); +x_110 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_110, 0, x_109); +lean_ctor_set(x_110, 1, x_92); +lean_ctor_set(x_110, 2, x_93); +lean_ctor_set(x_110, 3, x_94); +lean_ctor_set(x_110, 4, x_95); +lean_ctor_set(x_110, 5, x_96); if (lean_is_scalar(x_19)) { - x_108 = lean_alloc_ctor(1, 2, 0); + x_111 = lean_alloc_ctor(1, 2, 0); } else { - x_108 = x_19; - lean_ctor_set_tag(x_108, 1); + x_111 = x_19; + lean_ctor_set_tag(x_111, 1); } -lean_ctor_set(x_108, 0, x_65); -lean_ctor_set(x_108, 1, x_107); -return x_108; +lean_ctor_set(x_111, 0, x_65); +lean_ctor_set(x_111, 1, x_110); +return x_111; } } else { -lean_object* x_109; lean_object* x_110; lean_object* x_111; uint8_t x_112; -x_109 = lean_ctor_get(x_62, 0); -lean_inc(x_109); -x_110 = lean_ctor_get(x_109, 2); -lean_inc(x_110); -x_111 = lean_ctor_get(x_61, 0); -lean_inc(x_111); +lean_object* x_112; lean_object* x_113; lean_object* x_114; uint8_t x_115; +x_112 = lean_ctor_get(x_62, 0); +lean_inc(x_112); +x_113 = lean_ctor_get(x_112, 2); +lean_inc(x_113); +x_114 = lean_ctor_get(x_61, 0); +lean_inc(x_114); lean_dec(x_61); -x_112 = !lean_is_exclusive(x_62); -if (x_112 == 0) +x_115 = !lean_is_exclusive(x_62); +if (x_115 == 0) { -lean_object* x_113; uint8_t x_114; -x_113 = lean_ctor_get(x_62, 0); -lean_dec(x_113); -x_114 = !lean_is_exclusive(x_109); -if (x_114 == 0) +lean_object* x_116; uint8_t x_117; +x_116 = lean_ctor_get(x_62, 0); +lean_dec(x_116); +x_117 = !lean_is_exclusive(x_112); +if (x_117 == 0) { -lean_object* x_115; uint8_t x_116; -x_115 = lean_ctor_get(x_109, 2); -lean_dec(x_115); -x_116 = !lean_is_exclusive(x_110); -if (x_116 == 0) +lean_object* x_118; uint8_t x_119; +x_118 = lean_ctor_get(x_112, 2); +lean_dec(x_118); +x_119 = !lean_is_exclusive(x_113); +if (x_119 == 0) { -lean_object* x_117; lean_object* x_118; -x_117 = lean_ctor_get(x_110, 2); -lean_dec(x_117); -lean_ctor_set(x_110, 2, x_60); +lean_object* x_120; lean_object* x_121; +x_120 = lean_ctor_get(x_113, 2); +lean_dec(x_120); +lean_ctor_set(x_113, 2, x_60); if (lean_is_scalar(x_19)) { - x_118 = lean_alloc_ctor(0, 2, 0); + x_121 = lean_alloc_ctor(0, 2, 0); } else { - x_118 = x_19; + x_121 = x_19; } -lean_ctor_set(x_118, 0, x_111); -lean_ctor_set(x_118, 1, x_62); -return x_118; +lean_ctor_set(x_121, 0, x_114); +lean_ctor_set(x_121, 1, x_62); +return x_121; } else { -lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; -x_119 = lean_ctor_get(x_110, 0); -x_120 = lean_ctor_get(x_110, 1); -x_121 = lean_ctor_get(x_110, 3); -lean_inc(x_121); -lean_inc(x_120); -lean_inc(x_119); -lean_dec(x_110); -x_122 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_122, 0, x_119); -lean_ctor_set(x_122, 1, x_120); -lean_ctor_set(x_122, 2, x_60); -lean_ctor_set(x_122, 3, x_121); -lean_ctor_set(x_109, 2, x_122); -if (lean_is_scalar(x_19)) { - x_123 = lean_alloc_ctor(0, 2, 0); -} else { - x_123 = x_19; -} -lean_ctor_set(x_123, 0, x_111); -lean_ctor_set(x_123, 1, x_62); -return x_123; -} -} -else -{ -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; -x_124 = lean_ctor_get(x_109, 0); -x_125 = lean_ctor_get(x_109, 1); -x_126 = lean_ctor_get(x_109, 3); -x_127 = lean_ctor_get(x_109, 4); -x_128 = lean_ctor_get(x_109, 5); -lean_inc(x_128); -lean_inc(x_127); -lean_inc(x_126); +lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; +x_122 = lean_ctor_get(x_113, 0); +x_123 = lean_ctor_get(x_113, 1); +x_124 = lean_ctor_get(x_113, 3); +x_125 = lean_ctor_get(x_113, 4); lean_inc(x_125); lean_inc(x_124); -lean_dec(x_109); -x_129 = lean_ctor_get(x_110, 0); -lean_inc(x_129); -x_130 = lean_ctor_get(x_110, 1); -lean_inc(x_130); -x_131 = lean_ctor_get(x_110, 3); +lean_inc(x_123); +lean_inc(x_122); +lean_dec(x_113); +x_126 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_126, 0, x_122); +lean_ctor_set(x_126, 1, x_123); +lean_ctor_set(x_126, 2, x_60); +lean_ctor_set(x_126, 3, x_124); +lean_ctor_set(x_126, 4, x_125); +lean_ctor_set(x_112, 2, x_126); +if (lean_is_scalar(x_19)) { + x_127 = lean_alloc_ctor(0, 2, 0); +} else { + x_127 = x_19; +} +lean_ctor_set(x_127, 0, x_114); +lean_ctor_set(x_127, 1, x_62); +return x_127; +} +} +else +{ +lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; +x_128 = lean_ctor_get(x_112, 0); +x_129 = lean_ctor_get(x_112, 1); +x_130 = lean_ctor_get(x_112, 3); +x_131 = lean_ctor_get(x_112, 4); +x_132 = lean_ctor_get(x_112, 5); +lean_inc(x_132); lean_inc(x_131); -if (lean_is_exclusive(x_110)) { - lean_ctor_release(x_110, 0); - lean_ctor_release(x_110, 1); - lean_ctor_release(x_110, 2); - lean_ctor_release(x_110, 3); - x_132 = x_110; -} else { - lean_dec_ref(x_110); - x_132 = lean_box(0); -} -if (lean_is_scalar(x_132)) { - x_133 = lean_alloc_ctor(0, 4, 0); -} else { - x_133 = x_132; -} -lean_ctor_set(x_133, 0, x_129); -lean_ctor_set(x_133, 1, x_130); -lean_ctor_set(x_133, 2, x_60); -lean_ctor_set(x_133, 3, x_131); -x_134 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_134, 0, x_124); -lean_ctor_set(x_134, 1, x_125); -lean_ctor_set(x_134, 2, x_133); -lean_ctor_set(x_134, 3, x_126); -lean_ctor_set(x_134, 4, x_127); -lean_ctor_set(x_134, 5, x_128); -lean_ctor_set(x_62, 0, x_134); -if (lean_is_scalar(x_19)) { - x_135 = lean_alloc_ctor(0, 2, 0); -} else { - x_135 = x_19; -} -lean_ctor_set(x_135, 0, x_111); -lean_ctor_set(x_135, 1, x_62); -return x_135; -} -} -else -{ -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; -x_136 = lean_ctor_get(x_62, 1); -x_137 = lean_ctor_get(x_62, 2); -x_138 = lean_ctor_get(x_62, 3); -x_139 = lean_ctor_get(x_62, 4); -x_140 = lean_ctor_get(x_62, 5); -lean_inc(x_140); -lean_inc(x_139); -lean_inc(x_138); -lean_inc(x_137); +lean_inc(x_130); +lean_inc(x_129); +lean_inc(x_128); +lean_dec(x_112); +x_133 = lean_ctor_get(x_113, 0); +lean_inc(x_133); +x_134 = lean_ctor_get(x_113, 1); +lean_inc(x_134); +x_135 = lean_ctor_get(x_113, 3); +lean_inc(x_135); +x_136 = lean_ctor_get(x_113, 4); lean_inc(x_136); -lean_dec(x_62); -x_141 = lean_ctor_get(x_109, 0); -lean_inc(x_141); -x_142 = lean_ctor_get(x_109, 1); -lean_inc(x_142); -x_143 = lean_ctor_get(x_109, 3); -lean_inc(x_143); -x_144 = lean_ctor_get(x_109, 4); -lean_inc(x_144); -x_145 = lean_ctor_get(x_109, 5); -lean_inc(x_145); -if (lean_is_exclusive(x_109)) { - lean_ctor_release(x_109, 0); - lean_ctor_release(x_109, 1); - lean_ctor_release(x_109, 2); - lean_ctor_release(x_109, 3); - lean_ctor_release(x_109, 4); - lean_ctor_release(x_109, 5); - x_146 = x_109; +if (lean_is_exclusive(x_113)) { + lean_ctor_release(x_113, 0); + lean_ctor_release(x_113, 1); + lean_ctor_release(x_113, 2); + lean_ctor_release(x_113, 3); + lean_ctor_release(x_113, 4); + x_137 = x_113; } else { - lean_dec_ref(x_109); - x_146 = lean_box(0); + lean_dec_ref(x_113); + x_137 = lean_box(0); } -x_147 = lean_ctor_get(x_110, 0); -lean_inc(x_147); -x_148 = lean_ctor_get(x_110, 1); -lean_inc(x_148); -x_149 = lean_ctor_get(x_110, 3); -lean_inc(x_149); -if (lean_is_exclusive(x_110)) { - lean_ctor_release(x_110, 0); - lean_ctor_release(x_110, 1); - lean_ctor_release(x_110, 2); - lean_ctor_release(x_110, 3); - x_150 = x_110; +if (lean_is_scalar(x_137)) { + x_138 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_110); - x_150 = lean_box(0); + x_138 = x_137; } -if (lean_is_scalar(x_150)) { - x_151 = lean_alloc_ctor(0, 4, 0); -} else { - x_151 = x_150; -} -lean_ctor_set(x_151, 0, x_147); -lean_ctor_set(x_151, 1, x_148); -lean_ctor_set(x_151, 2, x_60); -lean_ctor_set(x_151, 3, x_149); -if (lean_is_scalar(x_146)) { - x_152 = lean_alloc_ctor(0, 6, 0); -} else { - x_152 = x_146; -} -lean_ctor_set(x_152, 0, x_141); -lean_ctor_set(x_152, 1, x_142); -lean_ctor_set(x_152, 2, x_151); -lean_ctor_set(x_152, 3, x_143); -lean_ctor_set(x_152, 4, x_144); -lean_ctor_set(x_152, 5, x_145); -x_153 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_153, 0, x_152); -lean_ctor_set(x_153, 1, x_136); -lean_ctor_set(x_153, 2, x_137); -lean_ctor_set(x_153, 3, x_138); -lean_ctor_set(x_153, 4, x_139); -lean_ctor_set(x_153, 5, x_140); +lean_ctor_set(x_138, 0, x_133); +lean_ctor_set(x_138, 1, x_134); +lean_ctor_set(x_138, 2, x_60); +lean_ctor_set(x_138, 3, x_135); +lean_ctor_set(x_138, 4, x_136); +x_139 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_139, 0, x_128); +lean_ctor_set(x_139, 1, x_129); +lean_ctor_set(x_139, 2, x_138); +lean_ctor_set(x_139, 3, x_130); +lean_ctor_set(x_139, 4, x_131); +lean_ctor_set(x_139, 5, x_132); +lean_ctor_set(x_62, 0, x_139); if (lean_is_scalar(x_19)) { - x_154 = lean_alloc_ctor(0, 2, 0); + x_140 = lean_alloc_ctor(0, 2, 0); } else { - x_154 = x_19; + x_140 = x_19; } -lean_ctor_set(x_154, 0, x_111); -lean_ctor_set(x_154, 1, x_153); -return x_154; +lean_ctor_set(x_140, 0, x_114); +lean_ctor_set(x_140, 1, x_62); +return x_140; +} +} +else +{ +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; +x_141 = lean_ctor_get(x_62, 1); +x_142 = lean_ctor_get(x_62, 2); +x_143 = lean_ctor_get(x_62, 3); +x_144 = lean_ctor_get(x_62, 4); +x_145 = lean_ctor_get(x_62, 5); +lean_inc(x_145); +lean_inc(x_144); +lean_inc(x_143); +lean_inc(x_142); +lean_inc(x_141); +lean_dec(x_62); +x_146 = lean_ctor_get(x_112, 0); +lean_inc(x_146); +x_147 = lean_ctor_get(x_112, 1); +lean_inc(x_147); +x_148 = lean_ctor_get(x_112, 3); +lean_inc(x_148); +x_149 = lean_ctor_get(x_112, 4); +lean_inc(x_149); +x_150 = lean_ctor_get(x_112, 5); +lean_inc(x_150); +if (lean_is_exclusive(x_112)) { + lean_ctor_release(x_112, 0); + lean_ctor_release(x_112, 1); + lean_ctor_release(x_112, 2); + lean_ctor_release(x_112, 3); + lean_ctor_release(x_112, 4); + lean_ctor_release(x_112, 5); + x_151 = x_112; +} else { + lean_dec_ref(x_112); + x_151 = lean_box(0); +} +x_152 = lean_ctor_get(x_113, 0); +lean_inc(x_152); +x_153 = lean_ctor_get(x_113, 1); +lean_inc(x_153); +x_154 = lean_ctor_get(x_113, 3); +lean_inc(x_154); +x_155 = lean_ctor_get(x_113, 4); +lean_inc(x_155); +if (lean_is_exclusive(x_113)) { + lean_ctor_release(x_113, 0); + lean_ctor_release(x_113, 1); + lean_ctor_release(x_113, 2); + lean_ctor_release(x_113, 3); + lean_ctor_release(x_113, 4); + x_156 = x_113; +} else { + lean_dec_ref(x_113); + x_156 = lean_box(0); +} +if (lean_is_scalar(x_156)) { + x_157 = lean_alloc_ctor(0, 5, 0); +} else { + x_157 = x_156; +} +lean_ctor_set(x_157, 0, x_152); +lean_ctor_set(x_157, 1, x_153); +lean_ctor_set(x_157, 2, x_60); +lean_ctor_set(x_157, 3, x_154); +lean_ctor_set(x_157, 4, x_155); +if (lean_is_scalar(x_151)) { + x_158 = lean_alloc_ctor(0, 6, 0); +} else { + x_158 = x_151; +} +lean_ctor_set(x_158, 0, x_146); +lean_ctor_set(x_158, 1, x_147); +lean_ctor_set(x_158, 2, x_157); +lean_ctor_set(x_158, 3, x_148); +lean_ctor_set(x_158, 4, x_149); +lean_ctor_set(x_158, 5, x_150); +x_159 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_159, 0, x_158); +lean_ctor_set(x_159, 1, x_141); +lean_ctor_set(x_159, 2, x_142); +lean_ctor_set(x_159, 3, x_143); +lean_ctor_set(x_159, 4, x_144); +lean_ctor_set(x_159, 5, x_145); +if (lean_is_scalar(x_19)) { + x_160 = lean_alloc_ctor(0, 2, 0); +} else { + x_160 = x_19; +} +lean_ctor_set(x_160, 0, x_114); +lean_ctor_set(x_160, 1, x_159); +return x_160; } } } @@ -21817,36 +21861,36 @@ return x_154; } else { -uint8_t x_207; +uint8_t x_213; lean_dec(x_11); lean_dec(x_4); lean_dec(x_3); -x_207 = !lean_is_exclusive(x_16); -if (x_207 == 0) +x_213 = !lean_is_exclusive(x_16); +if (x_213 == 0) { return x_16; } else { -lean_object* x_208; lean_object* x_209; lean_object* x_210; -x_208 = lean_ctor_get(x_16, 0); -x_209 = lean_ctor_get(x_16, 1); -lean_inc(x_209); -lean_inc(x_208); +lean_object* x_214; lean_object* x_215; lean_object* x_216; +x_214 = lean_ctor_get(x_16, 0); +x_215 = lean_ctor_get(x_16, 1); +lean_inc(x_215); +lean_inc(x_214); lean_dec(x_16); -x_210 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_210, 0, x_208); -lean_ctor_set(x_210, 1, x_209); -return x_210; +x_216 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_216, 0, x_214); +lean_ctor_set(x_216, 1, x_215); +return x_216; } } } else { -lean_object* x_211; lean_object* x_212; -x_211 = l_Array_empty___closed__1; -x_212 = lean_apply_4(x_3, x_211, x_2, x_4, x_5); -return x_212; +lean_object* x_217; lean_object* x_218; +x_217 = l_Array_empty___closed__1; +x_218 = lean_apply_4(x_3, x_217, x_2, x_4, x_5); +return x_218; } } } diff --git a/stage0/stdlib/Lean/Elab/Inductive.c b/stage0/stdlib/Lean/Elab/Inductive.c index 25fcf5a2cd..5392acd0ed 100644 --- a/stage0/stdlib/Lean/Elab/Inductive.c +++ b/stage0/stdlib/Lean/Elab/Inductive.c @@ -10517,105 +10517,105 @@ x_32 = lean_ctor_get(x_26, 2); x_33 = !lean_is_exclusive(x_32); if (x_33 == 0) { -lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_86; uint8_t x_87; +lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_90; uint8_t x_91; x_34 = lean_ctor_get(x_32, 2); -x_86 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_32, 2, x_86); -x_87 = !lean_is_exclusive(x_6); -if (x_87 == 0) +x_90 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_32, 2, x_90); +x_91 = !lean_is_exclusive(x_6); +if (x_91 == 0) { -lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; -x_88 = lean_ctor_get(x_6, 2); -x_89 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_89, 0, x_28); -lean_ctor_set(x_89, 1, x_15); -x_90 = lean_array_push(x_88, x_89); -lean_ctor_set(x_6, 2, x_90); -x_91 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_30__replaceIndFVarsWithConsts___spec__4(x_1, x_2, x_3, x_4, x_30, x_6, x_26); -if (lean_obj_tag(x_91) == 0) +lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; +x_92 = lean_ctor_get(x_6, 2); +x_93 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_93, 0, x_28); +lean_ctor_set(x_93, 1, x_15); +x_94 = lean_array_push(x_92, x_93); +lean_ctor_set(x_6, 2, x_94); +x_95 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_30__replaceIndFVarsWithConsts___spec__4(x_1, x_2, x_3, x_4, x_30, x_6, x_26); +if (lean_obj_tag(x_95) == 0) { -lean_object* x_92; lean_object* x_93; lean_object* x_94; -x_92 = lean_ctor_get(x_91, 0); -lean_inc(x_92); -x_93 = lean_ctor_get(x_91, 1); -lean_inc(x_93); -lean_dec(x_91); -x_94 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_94, 0, x_92); -x_35 = x_94; -x_36 = x_93; -goto block_85; -} -else -{ -lean_object* x_95; lean_object* x_96; lean_object* x_97; -x_95 = lean_ctor_get(x_91, 0); -lean_inc(x_95); -x_96 = lean_ctor_get(x_91, 1); +lean_object* x_96; lean_object* x_97; lean_object* x_98; +x_96 = lean_ctor_get(x_95, 0); lean_inc(x_96); -lean_dec(x_91); -x_97 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_97, 0, x_95); -x_35 = x_97; -x_36 = x_96; -goto block_85; -} +x_97 = lean_ctor_get(x_95, 1); +lean_inc(x_97); +lean_dec(x_95); +x_98 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_98, 0, x_96); +x_35 = x_98; +x_36 = x_97; +goto block_89; } else { -lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; -x_98 = lean_ctor_get(x_6, 0); -x_99 = lean_ctor_get(x_6, 1); -x_100 = lean_ctor_get(x_6, 2); -x_101 = lean_ctor_get(x_6, 3); -x_102 = lean_ctor_get(x_6, 4); -lean_inc(x_102); -lean_inc(x_101); -lean_inc(x_100); +lean_object* x_99; lean_object* x_100; lean_object* x_101; +x_99 = lean_ctor_get(x_95, 0); lean_inc(x_99); -lean_inc(x_98); -lean_dec(x_6); -x_103 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_103, 0, x_28); -lean_ctor_set(x_103, 1, x_15); -x_104 = lean_array_push(x_100, x_103); -x_105 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_105, 0, x_98); -lean_ctor_set(x_105, 1, x_99); -lean_ctor_set(x_105, 2, x_104); -lean_ctor_set(x_105, 3, x_101); -lean_ctor_set(x_105, 4, x_102); -x_106 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_30__replaceIndFVarsWithConsts___spec__4(x_1, x_2, x_3, x_4, x_30, x_105, x_26); -if (lean_obj_tag(x_106) == 0) -{ -lean_object* x_107; lean_object* x_108; lean_object* x_109; -x_107 = lean_ctor_get(x_106, 0); -lean_inc(x_107); -x_108 = lean_ctor_get(x_106, 1); -lean_inc(x_108); -lean_dec(x_106); -x_109 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_109, 0, x_107); -x_35 = x_109; -x_36 = x_108; -goto block_85; +x_100 = lean_ctor_get(x_95, 1); +lean_inc(x_100); +lean_dec(x_95); +x_101 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_101, 0, x_99); +x_35 = x_101; +x_36 = x_100; +goto block_89; +} } else { -lean_object* x_110; lean_object* x_111; lean_object* x_112; -x_110 = lean_ctor_get(x_106, 0); -lean_inc(x_110); -x_111 = lean_ctor_get(x_106, 1); +lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; +x_102 = lean_ctor_get(x_6, 0); +x_103 = lean_ctor_get(x_6, 1); +x_104 = lean_ctor_get(x_6, 2); +x_105 = lean_ctor_get(x_6, 3); +x_106 = lean_ctor_get(x_6, 4); +lean_inc(x_106); +lean_inc(x_105); +lean_inc(x_104); +lean_inc(x_103); +lean_inc(x_102); +lean_dec(x_6); +x_107 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_107, 0, x_28); +lean_ctor_set(x_107, 1, x_15); +x_108 = lean_array_push(x_104, x_107); +x_109 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_109, 0, x_102); +lean_ctor_set(x_109, 1, x_103); +lean_ctor_set(x_109, 2, x_108); +lean_ctor_set(x_109, 3, x_105); +lean_ctor_set(x_109, 4, x_106); +x_110 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_30__replaceIndFVarsWithConsts___spec__4(x_1, x_2, x_3, x_4, x_30, x_109, x_26); +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); -lean_dec(x_106); -x_112 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_112, 0, x_110); -x_35 = x_112; -x_36 = x_111; -goto block_85; +x_112 = lean_ctor_get(x_110, 1); +lean_inc(x_112); +lean_dec(x_110); +x_113 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_113, 0, x_111); +x_35 = x_113; +x_36 = x_112; +goto block_89; +} +else +{ +lean_object* x_114; lean_object* x_115; lean_object* x_116; +x_114 = lean_ctor_get(x_110, 0); +lean_inc(x_114); +x_115 = lean_ctor_get(x_110, 1); +lean_inc(x_115); +lean_dec(x_110); +x_116 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_116, 0, x_114); +x_35 = x_116; +x_36 = x_115; +goto block_89; } } -block_85: +block_89: { if (lean_obj_tag(x_35) == 0) { @@ -10650,1284 +10650,1262 @@ return x_43; } else { -lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; +lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; x_44 = lean_ctor_get(x_37, 0); x_45 = lean_ctor_get(x_37, 1); x_46 = lean_ctor_get(x_37, 3); +x_47 = lean_ctor_get(x_37, 4); +lean_inc(x_47); lean_inc(x_46); lean_inc(x_45); lean_inc(x_44); lean_dec(x_37); -x_47 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_47, 0, x_44); -lean_ctor_set(x_47, 1, x_45); -lean_ctor_set(x_47, 2, x_34); -lean_ctor_set(x_47, 3, x_46); -lean_ctor_set(x_36, 2, x_47); +x_48 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_48, 0, x_44); +lean_ctor_set(x_48, 1, x_45); +lean_ctor_set(x_48, 2, x_34); +lean_ctor_set(x_48, 3, x_46); +lean_ctor_set(x_48, 4, x_47); +lean_ctor_set(x_36, 2, x_48); if (lean_is_scalar(x_27)) { - x_48 = lean_alloc_ctor(1, 2, 0); + x_49 = lean_alloc_ctor(1, 2, 0); } else { - x_48 = x_27; - lean_ctor_set_tag(x_48, 1); + x_49 = x_27; + lean_ctor_set_tag(x_49, 1); } -lean_ctor_set(x_48, 0, x_38); -lean_ctor_set(x_48, 1, x_36); -return x_48; +lean_ctor_set(x_49, 0, x_38); +lean_ctor_set(x_49, 1, x_36); +return x_49; } } else { -lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; -x_49 = lean_ctor_get(x_36, 0); -x_50 = lean_ctor_get(x_36, 1); -x_51 = lean_ctor_get(x_36, 3); -x_52 = lean_ctor_get(x_36, 4); -x_53 = lean_ctor_get(x_36, 5); +lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; +x_50 = lean_ctor_get(x_36, 0); +x_51 = lean_ctor_get(x_36, 1); +x_52 = lean_ctor_get(x_36, 3); +x_53 = lean_ctor_get(x_36, 4); +x_54 = lean_ctor_get(x_36, 5); +lean_inc(x_54); lean_inc(x_53); lean_inc(x_52); lean_inc(x_51); lean_inc(x_50); -lean_inc(x_49); lean_dec(x_36); -x_54 = lean_ctor_get(x_37, 0); -lean_inc(x_54); -x_55 = lean_ctor_get(x_37, 1); +x_55 = lean_ctor_get(x_37, 0); lean_inc(x_55); -x_56 = lean_ctor_get(x_37, 3); +x_56 = lean_ctor_get(x_37, 1); lean_inc(x_56); +x_57 = lean_ctor_get(x_37, 3); +lean_inc(x_57); +x_58 = lean_ctor_get(x_37, 4); +lean_inc(x_58); if (lean_is_exclusive(x_37)) { lean_ctor_release(x_37, 0); lean_ctor_release(x_37, 1); lean_ctor_release(x_37, 2); lean_ctor_release(x_37, 3); - x_57 = x_37; + lean_ctor_release(x_37, 4); + x_59 = x_37; } else { lean_dec_ref(x_37); - x_57 = lean_box(0); + x_59 = lean_box(0); } -if (lean_is_scalar(x_57)) { - x_58 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_59)) { + x_60 = lean_alloc_ctor(0, 5, 0); } else { - x_58 = x_57; + x_60 = x_59; } -lean_ctor_set(x_58, 0, x_54); -lean_ctor_set(x_58, 1, x_55); -lean_ctor_set(x_58, 2, x_34); -lean_ctor_set(x_58, 3, x_56); -x_59 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_59, 0, x_49); -lean_ctor_set(x_59, 1, x_50); -lean_ctor_set(x_59, 2, x_58); -lean_ctor_set(x_59, 3, x_51); -lean_ctor_set(x_59, 4, x_52); -lean_ctor_set(x_59, 5, x_53); +lean_ctor_set(x_60, 0, x_55); +lean_ctor_set(x_60, 1, x_56); +lean_ctor_set(x_60, 2, x_34); +lean_ctor_set(x_60, 3, x_57); +lean_ctor_set(x_60, 4, x_58); +x_61 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_61, 0, x_50); +lean_ctor_set(x_61, 1, x_51); +lean_ctor_set(x_61, 2, x_60); +lean_ctor_set(x_61, 3, x_52); +lean_ctor_set(x_61, 4, x_53); +lean_ctor_set(x_61, 5, x_54); if (lean_is_scalar(x_27)) { - x_60 = lean_alloc_ctor(1, 2, 0); + x_62 = lean_alloc_ctor(1, 2, 0); } else { - x_60 = x_27; - lean_ctor_set_tag(x_60, 1); + x_62 = x_27; + lean_ctor_set_tag(x_62, 1); } -lean_ctor_set(x_60, 0, x_38); -lean_ctor_set(x_60, 1, x_59); -return x_60; +lean_ctor_set(x_62, 0, x_38); +lean_ctor_set(x_62, 1, x_61); +return x_62; } } else { -lean_object* x_61; lean_object* x_62; uint8_t x_63; -x_61 = lean_ctor_get(x_36, 2); -lean_inc(x_61); -x_62 = lean_ctor_get(x_35, 0); -lean_inc(x_62); +lean_object* x_63; lean_object* x_64; uint8_t x_65; +x_63 = lean_ctor_get(x_36, 2); +lean_inc(x_63); +x_64 = lean_ctor_get(x_35, 0); +lean_inc(x_64); lean_dec(x_35); -x_63 = !lean_is_exclusive(x_36); -if (x_63 == 0) -{ -lean_object* x_64; uint8_t x_65; -x_64 = lean_ctor_get(x_36, 2); -lean_dec(x_64); -x_65 = !lean_is_exclusive(x_61); +x_65 = !lean_is_exclusive(x_36); if (x_65 == 0) { -lean_object* x_66; lean_object* x_67; -x_66 = lean_ctor_get(x_61, 2); +lean_object* x_66; uint8_t x_67; +x_66 = lean_ctor_get(x_36, 2); lean_dec(x_66); -lean_ctor_set(x_61, 2, x_34); +x_67 = !lean_is_exclusive(x_63); +if (x_67 == 0) +{ +lean_object* x_68; lean_object* x_69; +x_68 = lean_ctor_get(x_63, 2); +lean_dec(x_68); +lean_ctor_set(x_63, 2, x_34); if (lean_is_scalar(x_27)) { - x_67 = lean_alloc_ctor(0, 2, 0); + x_69 = lean_alloc_ctor(0, 2, 0); } else { - x_67 = x_27; + x_69 = x_27; } -lean_ctor_set(x_67, 0, x_62); -lean_ctor_set(x_67, 1, x_36); -return x_67; +lean_ctor_set(x_69, 0, x_64); +lean_ctor_set(x_69, 1, x_36); +return x_69; } else { -lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; -x_68 = lean_ctor_get(x_61, 0); -x_69 = lean_ctor_get(x_61, 1); -x_70 = lean_ctor_get(x_61, 3); +lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; +x_70 = lean_ctor_get(x_63, 0); +x_71 = lean_ctor_get(x_63, 1); +x_72 = lean_ctor_get(x_63, 3); +x_73 = lean_ctor_get(x_63, 4); +lean_inc(x_73); +lean_inc(x_72); +lean_inc(x_71); lean_inc(x_70); -lean_inc(x_69); -lean_inc(x_68); -lean_dec(x_61); -x_71 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_71, 0, x_68); -lean_ctor_set(x_71, 1, x_69); -lean_ctor_set(x_71, 2, x_34); -lean_ctor_set(x_71, 3, x_70); -lean_ctor_set(x_36, 2, x_71); +lean_dec(x_63); +x_74 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_74, 0, x_70); +lean_ctor_set(x_74, 1, x_71); +lean_ctor_set(x_74, 2, x_34); +lean_ctor_set(x_74, 3, x_72); +lean_ctor_set(x_74, 4, x_73); +lean_ctor_set(x_36, 2, x_74); if (lean_is_scalar(x_27)) { - x_72 = lean_alloc_ctor(0, 2, 0); + x_75 = lean_alloc_ctor(0, 2, 0); } else { - x_72 = x_27; + x_75 = x_27; } -lean_ctor_set(x_72, 0, x_62); -lean_ctor_set(x_72, 1, x_36); -return x_72; +lean_ctor_set(x_75, 0, x_64); +lean_ctor_set(x_75, 1, x_36); +return x_75; } } else { -lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; -x_73 = lean_ctor_get(x_36, 0); -x_74 = lean_ctor_get(x_36, 1); -x_75 = lean_ctor_get(x_36, 3); -x_76 = lean_ctor_get(x_36, 4); -x_77 = lean_ctor_get(x_36, 5); +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; +x_76 = lean_ctor_get(x_36, 0); +x_77 = lean_ctor_get(x_36, 1); +x_78 = lean_ctor_get(x_36, 3); +x_79 = lean_ctor_get(x_36, 4); +x_80 = lean_ctor_get(x_36, 5); +lean_inc(x_80); +lean_inc(x_79); +lean_inc(x_78); lean_inc(x_77); lean_inc(x_76); -lean_inc(x_75); -lean_inc(x_74); -lean_inc(x_73); lean_dec(x_36); -x_78 = lean_ctor_get(x_61, 0); -lean_inc(x_78); -x_79 = lean_ctor_get(x_61, 1); -lean_inc(x_79); -x_80 = lean_ctor_get(x_61, 3); -lean_inc(x_80); -if (lean_is_exclusive(x_61)) { - lean_ctor_release(x_61, 0); - lean_ctor_release(x_61, 1); - lean_ctor_release(x_61, 2); - lean_ctor_release(x_61, 3); - x_81 = x_61; +x_81 = lean_ctor_get(x_63, 0); +lean_inc(x_81); +x_82 = lean_ctor_get(x_63, 1); +lean_inc(x_82); +x_83 = lean_ctor_get(x_63, 3); +lean_inc(x_83); +x_84 = lean_ctor_get(x_63, 4); +lean_inc(x_84); +if (lean_is_exclusive(x_63)) { + lean_ctor_release(x_63, 0); + lean_ctor_release(x_63, 1); + lean_ctor_release(x_63, 2); + lean_ctor_release(x_63, 3); + lean_ctor_release(x_63, 4); + x_85 = x_63; } else { - lean_dec_ref(x_61); - x_81 = lean_box(0); + lean_dec_ref(x_63); + x_85 = lean_box(0); } -if (lean_is_scalar(x_81)) { - x_82 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_85)) { + x_86 = lean_alloc_ctor(0, 5, 0); } else { - x_82 = x_81; + x_86 = x_85; } -lean_ctor_set(x_82, 0, x_78); -lean_ctor_set(x_82, 1, x_79); -lean_ctor_set(x_82, 2, x_34); -lean_ctor_set(x_82, 3, x_80); -x_83 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_83, 0, x_73); -lean_ctor_set(x_83, 1, x_74); -lean_ctor_set(x_83, 2, x_82); -lean_ctor_set(x_83, 3, x_75); -lean_ctor_set(x_83, 4, x_76); -lean_ctor_set(x_83, 5, x_77); +lean_ctor_set(x_86, 0, x_81); +lean_ctor_set(x_86, 1, x_82); +lean_ctor_set(x_86, 2, x_34); +lean_ctor_set(x_86, 3, x_83); +lean_ctor_set(x_86, 4, x_84); +x_87 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_87, 0, x_76); +lean_ctor_set(x_87, 1, x_77); +lean_ctor_set(x_87, 2, x_86); +lean_ctor_set(x_87, 3, x_78); +lean_ctor_set(x_87, 4, x_79); +lean_ctor_set(x_87, 5, x_80); if (lean_is_scalar(x_27)) { - x_84 = lean_alloc_ctor(0, 2, 0); + x_88 = lean_alloc_ctor(0, 2, 0); } else { - x_84 = x_27; + x_88 = x_27; } -lean_ctor_set(x_84, 0, x_62); -lean_ctor_set(x_84, 1, x_83); -return x_84; +lean_ctor_set(x_88, 0, x_64); +lean_ctor_set(x_88, 1, x_87); +return x_88; } } } } else { -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_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; -x_113 = lean_ctor_get(x_32, 0); -x_114 = lean_ctor_get(x_32, 1); -x_115 = lean_ctor_get(x_32, 2); -x_116 = lean_ctor_get(x_32, 3); -lean_inc(x_116); -lean_inc(x_115); -lean_inc(x_114); -lean_inc(x_113); -lean_dec(x_32); -x_150 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_151 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_151, 0, x_113); -lean_ctor_set(x_151, 1, x_114); -lean_ctor_set(x_151, 2, x_150); -lean_ctor_set(x_151, 3, x_116); -lean_ctor_set(x_26, 2, x_151); -x_152 = lean_ctor_get(x_6, 0); -lean_inc(x_152); -x_153 = lean_ctor_get(x_6, 1); -lean_inc(x_153); -x_154 = lean_ctor_get(x_6, 2); -lean_inc(x_154); -x_155 = lean_ctor_get(x_6, 3); -lean_inc(x_155); -x_156 = lean_ctor_get(x_6, 4); -lean_inc(x_156); -if (lean_is_exclusive(x_6)) { - lean_ctor_release(x_6, 0); - lean_ctor_release(x_6, 1); - lean_ctor_release(x_6, 2); - lean_ctor_release(x_6, 3); - lean_ctor_release(x_6, 4); - x_157 = x_6; -} else { - lean_dec_ref(x_6); - x_157 = lean_box(0); -} -x_158 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_158, 0, x_28); -lean_ctor_set(x_158, 1, x_15); -x_159 = lean_array_push(x_154, x_158); -if (lean_is_scalar(x_157)) { - x_160 = lean_alloc_ctor(0, 5, 0); -} else { - x_160 = x_157; -} -lean_ctor_set(x_160, 0, x_152); -lean_ctor_set(x_160, 1, x_153); -lean_ctor_set(x_160, 2, x_159); -lean_ctor_set(x_160, 3, x_155); -lean_ctor_set(x_160, 4, x_156); -x_161 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_30__replaceIndFVarsWithConsts___spec__4(x_1, x_2, x_3, x_4, x_30, x_160, x_26); -if (lean_obj_tag(x_161) == 0) -{ -lean_object* x_162; lean_object* x_163; lean_object* x_164; -x_162 = lean_ctor_get(x_161, 0); -lean_inc(x_162); -x_163 = lean_ctor_get(x_161, 1); -lean_inc(x_163); -lean_dec(x_161); -x_164 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_164, 0, x_162); -x_117 = x_164; -x_118 = x_163; -goto block_149; -} -else -{ -lean_object* x_165; lean_object* x_166; lean_object* x_167; -x_165 = lean_ctor_get(x_161, 0); -lean_inc(x_165); -x_166 = lean_ctor_get(x_161, 1); -lean_inc(x_166); -lean_dec(x_161); -x_167 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_167, 0, x_165); -x_117 = x_167; -x_118 = x_166; -goto block_149; -} -block_149: -{ -if (lean_obj_tag(x_117) == 0) -{ -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; -x_119 = lean_ctor_get(x_118, 2); -lean_inc(x_119); -x_120 = lean_ctor_get(x_117, 0); -lean_inc(x_120); -lean_dec(x_117); -x_121 = lean_ctor_get(x_118, 0); +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_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_117 = lean_ctor_get(x_32, 0); +x_118 = lean_ctor_get(x_32, 1); +x_119 = lean_ctor_get(x_32, 2); +x_120 = lean_ctor_get(x_32, 3); +x_121 = lean_ctor_get(x_32, 4); lean_inc(x_121); -x_122 = lean_ctor_get(x_118, 1); -lean_inc(x_122); -x_123 = lean_ctor_get(x_118, 3); -lean_inc(x_123); -x_124 = lean_ctor_get(x_118, 4); -lean_inc(x_124); -x_125 = lean_ctor_get(x_118, 5); -lean_inc(x_125); -if (lean_is_exclusive(x_118)) { - lean_ctor_release(x_118, 0); - lean_ctor_release(x_118, 1); - lean_ctor_release(x_118, 2); - lean_ctor_release(x_118, 3); - lean_ctor_release(x_118, 4); - lean_ctor_release(x_118, 5); - x_126 = x_118; -} else { - lean_dec_ref(x_118); - x_126 = lean_box(0); -} -x_127 = lean_ctor_get(x_119, 0); -lean_inc(x_127); -x_128 = lean_ctor_get(x_119, 1); -lean_inc(x_128); -x_129 = lean_ctor_get(x_119, 3); -lean_inc(x_129); -if (lean_is_exclusive(x_119)) { - lean_ctor_release(x_119, 0); - lean_ctor_release(x_119, 1); - lean_ctor_release(x_119, 2); - lean_ctor_release(x_119, 3); - x_130 = x_119; -} else { - lean_dec_ref(x_119); - x_130 = lean_box(0); -} -if (lean_is_scalar(x_130)) { - x_131 = lean_alloc_ctor(0, 4, 0); -} else { - x_131 = x_130; -} -lean_ctor_set(x_131, 0, x_127); -lean_ctor_set(x_131, 1, x_128); -lean_ctor_set(x_131, 2, x_115); -lean_ctor_set(x_131, 3, x_129); -if (lean_is_scalar(x_126)) { - x_132 = lean_alloc_ctor(0, 6, 0); -} else { - x_132 = x_126; -} -lean_ctor_set(x_132, 0, x_121); -lean_ctor_set(x_132, 1, x_122); -lean_ctor_set(x_132, 2, x_131); -lean_ctor_set(x_132, 3, x_123); -lean_ctor_set(x_132, 4, x_124); -lean_ctor_set(x_132, 5, x_125); -if (lean_is_scalar(x_27)) { - x_133 = lean_alloc_ctor(1, 2, 0); -} else { - x_133 = x_27; - lean_ctor_set_tag(x_133, 1); -} -lean_ctor_set(x_133, 0, x_120); -lean_ctor_set(x_133, 1, x_132); -return x_133; -} -else -{ -lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; 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; -x_134 = lean_ctor_get(x_118, 2); -lean_inc(x_134); -x_135 = lean_ctor_get(x_117, 0); -lean_inc(x_135); -lean_dec(x_117); -x_136 = lean_ctor_get(x_118, 0); -lean_inc(x_136); -x_137 = lean_ctor_get(x_118, 1); -lean_inc(x_137); -x_138 = lean_ctor_get(x_118, 3); -lean_inc(x_138); -x_139 = lean_ctor_get(x_118, 4); -lean_inc(x_139); -x_140 = lean_ctor_get(x_118, 5); -lean_inc(x_140); -if (lean_is_exclusive(x_118)) { - lean_ctor_release(x_118, 0); - lean_ctor_release(x_118, 1); - lean_ctor_release(x_118, 2); - lean_ctor_release(x_118, 3); - lean_ctor_release(x_118, 4); - lean_ctor_release(x_118, 5); - x_141 = x_118; -} else { - lean_dec_ref(x_118); - x_141 = lean_box(0); -} -x_142 = lean_ctor_get(x_134, 0); -lean_inc(x_142); -x_143 = lean_ctor_get(x_134, 1); -lean_inc(x_143); -x_144 = lean_ctor_get(x_134, 3); -lean_inc(x_144); -if (lean_is_exclusive(x_134)) { - lean_ctor_release(x_134, 0); - lean_ctor_release(x_134, 1); - lean_ctor_release(x_134, 2); - lean_ctor_release(x_134, 3); - x_145 = x_134; -} else { - lean_dec_ref(x_134); - x_145 = lean_box(0); -} -if (lean_is_scalar(x_145)) { - x_146 = lean_alloc_ctor(0, 4, 0); -} else { - x_146 = x_145; -} -lean_ctor_set(x_146, 0, x_142); -lean_ctor_set(x_146, 1, x_143); -lean_ctor_set(x_146, 2, x_115); -lean_ctor_set(x_146, 3, x_144); -if (lean_is_scalar(x_141)) { - x_147 = lean_alloc_ctor(0, 6, 0); -} else { - x_147 = x_141; -} -lean_ctor_set(x_147, 0, x_136); -lean_ctor_set(x_147, 1, x_137); -lean_ctor_set(x_147, 2, x_146); -lean_ctor_set(x_147, 3, x_138); -lean_ctor_set(x_147, 4, x_139); -lean_ctor_set(x_147, 5, x_140); -if (lean_is_scalar(x_27)) { - x_148 = lean_alloc_ctor(0, 2, 0); -} else { - x_148 = x_27; -} -lean_ctor_set(x_148, 0, x_135); -lean_ctor_set(x_148, 1, x_147); -return x_148; -} -} -} -} -else -{ -lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; lean_object* x_173; lean_object* x_174; lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; lean_object* x_224; -x_168 = lean_ctor_get(x_26, 2); -x_169 = lean_ctor_get(x_26, 0); -x_170 = lean_ctor_get(x_26, 1); -x_171 = lean_ctor_get(x_26, 3); -x_172 = lean_ctor_get(x_26, 4); -x_173 = lean_ctor_get(x_26, 5); -lean_inc(x_173); -lean_inc(x_172); -lean_inc(x_171); -lean_inc(x_168); -lean_inc(x_170); -lean_inc(x_169); -lean_dec(x_26); -x_174 = lean_ctor_get(x_168, 0); -lean_inc(x_174); -x_175 = lean_ctor_get(x_168, 1); -lean_inc(x_175); -x_176 = lean_ctor_get(x_168, 2); -lean_inc(x_176); -x_177 = lean_ctor_get(x_168, 3); -lean_inc(x_177); -if (lean_is_exclusive(x_168)) { - lean_ctor_release(x_168, 0); - lean_ctor_release(x_168, 1); - lean_ctor_release(x_168, 2); - lean_ctor_release(x_168, 3); - x_178 = x_168; -} else { - lean_dec_ref(x_168); - x_178 = lean_box(0); -} -x_212 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_178)) { - x_213 = lean_alloc_ctor(0, 4, 0); -} else { - x_213 = x_178; -} -lean_ctor_set(x_213, 0, x_174); -lean_ctor_set(x_213, 1, x_175); -lean_ctor_set(x_213, 2, x_212); -lean_ctor_set(x_213, 3, x_177); -x_214 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_214, 0, x_169); -lean_ctor_set(x_214, 1, x_170); -lean_ctor_set(x_214, 2, x_213); -lean_ctor_set(x_214, 3, x_171); -lean_ctor_set(x_214, 4, x_172); -lean_ctor_set(x_214, 5, x_173); -x_215 = lean_ctor_get(x_6, 0); -lean_inc(x_215); -x_216 = lean_ctor_get(x_6, 1); -lean_inc(x_216); -x_217 = lean_ctor_get(x_6, 2); -lean_inc(x_217); -x_218 = lean_ctor_get(x_6, 3); -lean_inc(x_218); -x_219 = lean_ctor_get(x_6, 4); -lean_inc(x_219); +lean_inc(x_120); +lean_inc(x_119); +lean_inc(x_118); +lean_inc(x_117); +lean_dec(x_32); +x_157 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_158 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_158, 0, x_117); +lean_ctor_set(x_158, 1, x_118); +lean_ctor_set(x_158, 2, x_157); +lean_ctor_set(x_158, 3, x_120); +lean_ctor_set(x_158, 4, x_121); +lean_ctor_set(x_26, 2, x_158); +x_159 = lean_ctor_get(x_6, 0); +lean_inc(x_159); +x_160 = lean_ctor_get(x_6, 1); +lean_inc(x_160); +x_161 = lean_ctor_get(x_6, 2); +lean_inc(x_161); +x_162 = lean_ctor_get(x_6, 3); +lean_inc(x_162); +x_163 = lean_ctor_get(x_6, 4); +lean_inc(x_163); if (lean_is_exclusive(x_6)) { lean_ctor_release(x_6, 0); lean_ctor_release(x_6, 1); lean_ctor_release(x_6, 2); lean_ctor_release(x_6, 3); lean_ctor_release(x_6, 4); - x_220 = x_6; + x_164 = x_6; } else { lean_dec_ref(x_6); - x_220 = lean_box(0); + x_164 = lean_box(0); } -x_221 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_221, 0, x_28); -lean_ctor_set(x_221, 1, x_15); -x_222 = lean_array_push(x_217, x_221); -if (lean_is_scalar(x_220)) { +x_165 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_165, 0, x_28); +lean_ctor_set(x_165, 1, x_15); +x_166 = lean_array_push(x_161, x_165); +if (lean_is_scalar(x_164)) { + x_167 = lean_alloc_ctor(0, 5, 0); +} else { + x_167 = x_164; +} +lean_ctor_set(x_167, 0, x_159); +lean_ctor_set(x_167, 1, x_160); +lean_ctor_set(x_167, 2, x_166); +lean_ctor_set(x_167, 3, x_162); +lean_ctor_set(x_167, 4, x_163); +x_168 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_30__replaceIndFVarsWithConsts___spec__4(x_1, x_2, x_3, x_4, x_30, x_167, x_26); +if (lean_obj_tag(x_168) == 0) +{ +lean_object* x_169; lean_object* x_170; lean_object* x_171; +x_169 = lean_ctor_get(x_168, 0); +lean_inc(x_169); +x_170 = lean_ctor_get(x_168, 1); +lean_inc(x_170); +lean_dec(x_168); +x_171 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_171, 0, x_169); +x_122 = x_171; +x_123 = x_170; +goto block_156; +} +else +{ +lean_object* x_172; lean_object* x_173; lean_object* x_174; +x_172 = lean_ctor_get(x_168, 0); +lean_inc(x_172); +x_173 = lean_ctor_get(x_168, 1); +lean_inc(x_173); +lean_dec(x_168); +x_174 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_174, 0, x_172); +x_122 = x_174; +x_123 = x_173; +goto block_156; +} +block_156: +{ +if (lean_obj_tag(x_122) == 0) +{ +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; +x_124 = lean_ctor_get(x_123, 2); +lean_inc(x_124); +x_125 = lean_ctor_get(x_122, 0); +lean_inc(x_125); +lean_dec(x_122); +x_126 = lean_ctor_get(x_123, 0); +lean_inc(x_126); +x_127 = lean_ctor_get(x_123, 1); +lean_inc(x_127); +x_128 = lean_ctor_get(x_123, 3); +lean_inc(x_128); +x_129 = lean_ctor_get(x_123, 4); +lean_inc(x_129); +x_130 = lean_ctor_get(x_123, 5); +lean_inc(x_130); +if (lean_is_exclusive(x_123)) { + lean_ctor_release(x_123, 0); + lean_ctor_release(x_123, 1); + lean_ctor_release(x_123, 2); + lean_ctor_release(x_123, 3); + lean_ctor_release(x_123, 4); + lean_ctor_release(x_123, 5); + x_131 = x_123; +} else { + lean_dec_ref(x_123); + x_131 = lean_box(0); +} +x_132 = lean_ctor_get(x_124, 0); +lean_inc(x_132); +x_133 = lean_ctor_get(x_124, 1); +lean_inc(x_133); +x_134 = lean_ctor_get(x_124, 3); +lean_inc(x_134); +x_135 = lean_ctor_get(x_124, 4); +lean_inc(x_135); +if (lean_is_exclusive(x_124)) { + lean_ctor_release(x_124, 0); + lean_ctor_release(x_124, 1); + lean_ctor_release(x_124, 2); + lean_ctor_release(x_124, 3); + lean_ctor_release(x_124, 4); + x_136 = x_124; +} else { + lean_dec_ref(x_124); + x_136 = lean_box(0); +} +if (lean_is_scalar(x_136)) { + x_137 = lean_alloc_ctor(0, 5, 0); +} else { + x_137 = x_136; +} +lean_ctor_set(x_137, 0, x_132); +lean_ctor_set(x_137, 1, x_133); +lean_ctor_set(x_137, 2, x_119); +lean_ctor_set(x_137, 3, x_134); +lean_ctor_set(x_137, 4, x_135); +if (lean_is_scalar(x_131)) { + x_138 = lean_alloc_ctor(0, 6, 0); +} else { + x_138 = x_131; +} +lean_ctor_set(x_138, 0, x_126); +lean_ctor_set(x_138, 1, x_127); +lean_ctor_set(x_138, 2, x_137); +lean_ctor_set(x_138, 3, x_128); +lean_ctor_set(x_138, 4, x_129); +lean_ctor_set(x_138, 5, x_130); +if (lean_is_scalar(x_27)) { + x_139 = lean_alloc_ctor(1, 2, 0); +} else { + x_139 = x_27; + lean_ctor_set_tag(x_139, 1); +} +lean_ctor_set(x_139, 0, x_125); +lean_ctor_set(x_139, 1, x_138); +return x_139; +} +else +{ +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; +x_140 = lean_ctor_get(x_123, 2); +lean_inc(x_140); +x_141 = lean_ctor_get(x_122, 0); +lean_inc(x_141); +lean_dec(x_122); +x_142 = lean_ctor_get(x_123, 0); +lean_inc(x_142); +x_143 = lean_ctor_get(x_123, 1); +lean_inc(x_143); +x_144 = lean_ctor_get(x_123, 3); +lean_inc(x_144); +x_145 = lean_ctor_get(x_123, 4); +lean_inc(x_145); +x_146 = lean_ctor_get(x_123, 5); +lean_inc(x_146); +if (lean_is_exclusive(x_123)) { + lean_ctor_release(x_123, 0); + lean_ctor_release(x_123, 1); + lean_ctor_release(x_123, 2); + lean_ctor_release(x_123, 3); + lean_ctor_release(x_123, 4); + lean_ctor_release(x_123, 5); + x_147 = x_123; +} else { + lean_dec_ref(x_123); + x_147 = lean_box(0); +} +x_148 = lean_ctor_get(x_140, 0); +lean_inc(x_148); +x_149 = lean_ctor_get(x_140, 1); +lean_inc(x_149); +x_150 = lean_ctor_get(x_140, 3); +lean_inc(x_150); +x_151 = lean_ctor_get(x_140, 4); +lean_inc(x_151); +if (lean_is_exclusive(x_140)) { + lean_ctor_release(x_140, 0); + lean_ctor_release(x_140, 1); + lean_ctor_release(x_140, 2); + lean_ctor_release(x_140, 3); + lean_ctor_release(x_140, 4); + x_152 = x_140; +} else { + lean_dec_ref(x_140); + x_152 = lean_box(0); +} +if (lean_is_scalar(x_152)) { + x_153 = lean_alloc_ctor(0, 5, 0); +} else { + x_153 = x_152; +} +lean_ctor_set(x_153, 0, x_148); +lean_ctor_set(x_153, 1, x_149); +lean_ctor_set(x_153, 2, x_119); +lean_ctor_set(x_153, 3, x_150); +lean_ctor_set(x_153, 4, x_151); +if (lean_is_scalar(x_147)) { + x_154 = lean_alloc_ctor(0, 6, 0); +} else { + x_154 = x_147; +} +lean_ctor_set(x_154, 0, x_142); +lean_ctor_set(x_154, 1, x_143); +lean_ctor_set(x_154, 2, x_153); +lean_ctor_set(x_154, 3, x_144); +lean_ctor_set(x_154, 4, x_145); +lean_ctor_set(x_154, 5, x_146); +if (lean_is_scalar(x_27)) { + x_155 = lean_alloc_ctor(0, 2, 0); +} else { + x_155 = x_27; +} +lean_ctor_set(x_155, 0, x_141); +lean_ctor_set(x_155, 1, x_154); +return x_155; +} +} +} +} +else +{ +lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; 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; lean_object* x_231; lean_object* x_232; lean_object* x_233; lean_object* x_234; +x_175 = lean_ctor_get(x_26, 2); +x_176 = lean_ctor_get(x_26, 0); +x_177 = lean_ctor_get(x_26, 1); +x_178 = lean_ctor_get(x_26, 3); +x_179 = lean_ctor_get(x_26, 4); +x_180 = lean_ctor_get(x_26, 5); +lean_inc(x_180); +lean_inc(x_179); +lean_inc(x_178); +lean_inc(x_175); +lean_inc(x_177); +lean_inc(x_176); +lean_dec(x_26); +x_181 = lean_ctor_get(x_175, 0); +lean_inc(x_181); +x_182 = lean_ctor_get(x_175, 1); +lean_inc(x_182); +x_183 = lean_ctor_get(x_175, 2); +lean_inc(x_183); +x_184 = lean_ctor_get(x_175, 3); +lean_inc(x_184); +x_185 = lean_ctor_get(x_175, 4); +lean_inc(x_185); +if (lean_is_exclusive(x_175)) { + lean_ctor_release(x_175, 0); + lean_ctor_release(x_175, 1); + lean_ctor_release(x_175, 2); + lean_ctor_release(x_175, 3); + lean_ctor_release(x_175, 4); + x_186 = x_175; +} else { + lean_dec_ref(x_175); + x_186 = lean_box(0); +} +x_222 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_186)) { x_223 = lean_alloc_ctor(0, 5, 0); } else { - x_223 = x_220; + x_223 = x_186; } -lean_ctor_set(x_223, 0, x_215); -lean_ctor_set(x_223, 1, x_216); +lean_ctor_set(x_223, 0, x_181); +lean_ctor_set(x_223, 1, x_182); lean_ctor_set(x_223, 2, x_222); -lean_ctor_set(x_223, 3, x_218); -lean_ctor_set(x_223, 4, x_219); -x_224 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_30__replaceIndFVarsWithConsts___spec__4(x_1, x_2, x_3, x_4, x_30, x_223, x_214); -if (lean_obj_tag(x_224) == 0) -{ -lean_object* x_225; lean_object* x_226; lean_object* x_227; -x_225 = lean_ctor_get(x_224, 0); +lean_ctor_set(x_223, 3, x_184); +lean_ctor_set(x_223, 4, x_185); +x_224 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_224, 0, x_176); +lean_ctor_set(x_224, 1, x_177); +lean_ctor_set(x_224, 2, x_223); +lean_ctor_set(x_224, 3, x_178); +lean_ctor_set(x_224, 4, x_179); +lean_ctor_set(x_224, 5, x_180); +x_225 = lean_ctor_get(x_6, 0); lean_inc(x_225); -x_226 = lean_ctor_get(x_224, 1); +x_226 = lean_ctor_get(x_6, 1); lean_inc(x_226); -lean_dec(x_224); -x_227 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_227, 0, x_225); -x_179 = x_227; -x_180 = x_226; -goto block_211; -} -else -{ -lean_object* x_228; lean_object* x_229; lean_object* x_230; -x_228 = lean_ctor_get(x_224, 0); +x_227 = lean_ctor_get(x_6, 2); +lean_inc(x_227); +x_228 = lean_ctor_get(x_6, 3); lean_inc(x_228); -x_229 = lean_ctor_get(x_224, 1); +x_229 = lean_ctor_get(x_6, 4); lean_inc(x_229); -lean_dec(x_224); -x_230 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_230, 0, x_228); -x_179 = x_230; -x_180 = x_229; -goto block_211; +if (lean_is_exclusive(x_6)) { + lean_ctor_release(x_6, 0); + lean_ctor_release(x_6, 1); + lean_ctor_release(x_6, 2); + lean_ctor_release(x_6, 3); + lean_ctor_release(x_6, 4); + x_230 = x_6; +} else { + lean_dec_ref(x_6); + x_230 = lean_box(0); } -block_211: +x_231 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_231, 0, x_28); +lean_ctor_set(x_231, 1, x_15); +x_232 = lean_array_push(x_227, x_231); +if (lean_is_scalar(x_230)) { + x_233 = lean_alloc_ctor(0, 5, 0); +} else { + x_233 = x_230; +} +lean_ctor_set(x_233, 0, x_225); +lean_ctor_set(x_233, 1, x_226); +lean_ctor_set(x_233, 2, x_232); +lean_ctor_set(x_233, 3, x_228); +lean_ctor_set(x_233, 4, x_229); +x_234 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_30__replaceIndFVarsWithConsts___spec__4(x_1, x_2, x_3, x_4, x_30, x_233, x_224); +if (lean_obj_tag(x_234) == 0) { -if (lean_obj_tag(x_179) == 0) -{ -lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; -x_181 = lean_ctor_get(x_180, 2); -lean_inc(x_181); -x_182 = lean_ctor_get(x_179, 0); -lean_inc(x_182); -lean_dec(x_179); -x_183 = lean_ctor_get(x_180, 0); -lean_inc(x_183); -x_184 = lean_ctor_get(x_180, 1); -lean_inc(x_184); -x_185 = lean_ctor_get(x_180, 3); -lean_inc(x_185); -x_186 = lean_ctor_get(x_180, 4); -lean_inc(x_186); -x_187 = lean_ctor_get(x_180, 5); -lean_inc(x_187); -if (lean_is_exclusive(x_180)) { - lean_ctor_release(x_180, 0); - lean_ctor_release(x_180, 1); - lean_ctor_release(x_180, 2); - lean_ctor_release(x_180, 3); - lean_ctor_release(x_180, 4); - lean_ctor_release(x_180, 5); - x_188 = x_180; -} else { - lean_dec_ref(x_180); - x_188 = lean_box(0); -} -x_189 = lean_ctor_get(x_181, 0); -lean_inc(x_189); -x_190 = lean_ctor_get(x_181, 1); -lean_inc(x_190); -x_191 = lean_ctor_get(x_181, 3); -lean_inc(x_191); -if (lean_is_exclusive(x_181)) { - lean_ctor_release(x_181, 0); - lean_ctor_release(x_181, 1); - lean_ctor_release(x_181, 2); - lean_ctor_release(x_181, 3); - x_192 = x_181; -} else { - lean_dec_ref(x_181); - x_192 = lean_box(0); -} -if (lean_is_scalar(x_192)) { - x_193 = lean_alloc_ctor(0, 4, 0); -} else { - x_193 = x_192; -} -lean_ctor_set(x_193, 0, x_189); -lean_ctor_set(x_193, 1, x_190); -lean_ctor_set(x_193, 2, x_176); -lean_ctor_set(x_193, 3, x_191); -if (lean_is_scalar(x_188)) { - x_194 = lean_alloc_ctor(0, 6, 0); -} else { - x_194 = x_188; -} -lean_ctor_set(x_194, 0, x_183); -lean_ctor_set(x_194, 1, x_184); -lean_ctor_set(x_194, 2, x_193); -lean_ctor_set(x_194, 3, x_185); -lean_ctor_set(x_194, 4, x_186); -lean_ctor_set(x_194, 5, x_187); -if (lean_is_scalar(x_27)) { - x_195 = lean_alloc_ctor(1, 2, 0); -} else { - x_195 = x_27; - lean_ctor_set_tag(x_195, 1); -} -lean_ctor_set(x_195, 0, x_182); -lean_ctor_set(x_195, 1, x_194); -return x_195; +lean_object* x_235; lean_object* x_236; lean_object* x_237; +x_235 = lean_ctor_get(x_234, 0); +lean_inc(x_235); +x_236 = lean_ctor_get(x_234, 1); +lean_inc(x_236); +lean_dec(x_234); +x_237 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_237, 0, x_235); +x_187 = x_237; +x_188 = x_236; +goto block_221; } else { -lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; -x_196 = lean_ctor_get(x_180, 2); -lean_inc(x_196); -x_197 = lean_ctor_get(x_179, 0); +lean_object* x_238; lean_object* x_239; lean_object* x_240; +x_238 = lean_ctor_get(x_234, 0); +lean_inc(x_238); +x_239 = lean_ctor_get(x_234, 1); +lean_inc(x_239); +lean_dec(x_234); +x_240 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_240, 0, x_238); +x_187 = x_240; +x_188 = x_239; +goto block_221; +} +block_221: +{ +if (lean_obj_tag(x_187) == 0) +{ +lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; +x_189 = lean_ctor_get(x_188, 2); +lean_inc(x_189); +x_190 = lean_ctor_get(x_187, 0); +lean_inc(x_190); +lean_dec(x_187); +x_191 = lean_ctor_get(x_188, 0); +lean_inc(x_191); +x_192 = lean_ctor_get(x_188, 1); +lean_inc(x_192); +x_193 = lean_ctor_get(x_188, 3); +lean_inc(x_193); +x_194 = lean_ctor_get(x_188, 4); +lean_inc(x_194); +x_195 = lean_ctor_get(x_188, 5); +lean_inc(x_195); +if (lean_is_exclusive(x_188)) { + lean_ctor_release(x_188, 0); + lean_ctor_release(x_188, 1); + lean_ctor_release(x_188, 2); + lean_ctor_release(x_188, 3); + lean_ctor_release(x_188, 4); + lean_ctor_release(x_188, 5); + x_196 = x_188; +} else { + lean_dec_ref(x_188); + x_196 = lean_box(0); +} +x_197 = lean_ctor_get(x_189, 0); lean_inc(x_197); -lean_dec(x_179); -x_198 = lean_ctor_get(x_180, 0); +x_198 = lean_ctor_get(x_189, 1); lean_inc(x_198); -x_199 = lean_ctor_get(x_180, 1); +x_199 = lean_ctor_get(x_189, 3); lean_inc(x_199); -x_200 = lean_ctor_get(x_180, 3); +x_200 = lean_ctor_get(x_189, 4); lean_inc(x_200); -x_201 = lean_ctor_get(x_180, 4); -lean_inc(x_201); -x_202 = lean_ctor_get(x_180, 5); -lean_inc(x_202); -if (lean_is_exclusive(x_180)) { - lean_ctor_release(x_180, 0); - lean_ctor_release(x_180, 1); - lean_ctor_release(x_180, 2); - lean_ctor_release(x_180, 3); - lean_ctor_release(x_180, 4); - lean_ctor_release(x_180, 5); - x_203 = x_180; +if (lean_is_exclusive(x_189)) { + lean_ctor_release(x_189, 0); + lean_ctor_release(x_189, 1); + lean_ctor_release(x_189, 2); + lean_ctor_release(x_189, 3); + lean_ctor_release(x_189, 4); + x_201 = x_189; } else { - lean_dec_ref(x_180); - x_203 = lean_box(0); + lean_dec_ref(x_189); + x_201 = lean_box(0); } -x_204 = lean_ctor_get(x_196, 0); -lean_inc(x_204); -x_205 = lean_ctor_get(x_196, 1); -lean_inc(x_205); -x_206 = lean_ctor_get(x_196, 3); -lean_inc(x_206); -if (lean_is_exclusive(x_196)) { - lean_ctor_release(x_196, 0); - lean_ctor_release(x_196, 1); - lean_ctor_release(x_196, 2); - lean_ctor_release(x_196, 3); - x_207 = x_196; +if (lean_is_scalar(x_201)) { + x_202 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_196); - x_207 = lean_box(0); + x_202 = x_201; } -if (lean_is_scalar(x_207)) { - x_208 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_202, 0, x_197); +lean_ctor_set(x_202, 1, x_198); +lean_ctor_set(x_202, 2, x_183); +lean_ctor_set(x_202, 3, x_199); +lean_ctor_set(x_202, 4, x_200); +if (lean_is_scalar(x_196)) { + x_203 = lean_alloc_ctor(0, 6, 0); } else { - x_208 = x_207; + x_203 = x_196; } -lean_ctor_set(x_208, 0, x_204); -lean_ctor_set(x_208, 1, x_205); -lean_ctor_set(x_208, 2, x_176); -lean_ctor_set(x_208, 3, x_206); -if (lean_is_scalar(x_203)) { - x_209 = lean_alloc_ctor(0, 6, 0); -} else { - x_209 = x_203; -} -lean_ctor_set(x_209, 0, x_198); -lean_ctor_set(x_209, 1, x_199); -lean_ctor_set(x_209, 2, x_208); -lean_ctor_set(x_209, 3, x_200); -lean_ctor_set(x_209, 4, x_201); -lean_ctor_set(x_209, 5, x_202); +lean_ctor_set(x_203, 0, x_191); +lean_ctor_set(x_203, 1, x_192); +lean_ctor_set(x_203, 2, x_202); +lean_ctor_set(x_203, 3, x_193); +lean_ctor_set(x_203, 4, x_194); +lean_ctor_set(x_203, 5, x_195); if (lean_is_scalar(x_27)) { - x_210 = lean_alloc_ctor(0, 2, 0); + x_204 = lean_alloc_ctor(1, 2, 0); } else { - x_210 = x_27; + x_204 = x_27; + lean_ctor_set_tag(x_204, 1); } -lean_ctor_set(x_210, 0, x_197); -lean_ctor_set(x_210, 1, x_209); -return x_210; +lean_ctor_set(x_204, 0, x_190); +lean_ctor_set(x_204, 1, x_203); +return x_204; +} +else +{ +lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; +x_205 = lean_ctor_get(x_188, 2); +lean_inc(x_205); +x_206 = lean_ctor_get(x_187, 0); +lean_inc(x_206); +lean_dec(x_187); +x_207 = lean_ctor_get(x_188, 0); +lean_inc(x_207); +x_208 = lean_ctor_get(x_188, 1); +lean_inc(x_208); +x_209 = lean_ctor_get(x_188, 3); +lean_inc(x_209); +x_210 = lean_ctor_get(x_188, 4); +lean_inc(x_210); +x_211 = lean_ctor_get(x_188, 5); +lean_inc(x_211); +if (lean_is_exclusive(x_188)) { + lean_ctor_release(x_188, 0); + lean_ctor_release(x_188, 1); + lean_ctor_release(x_188, 2); + lean_ctor_release(x_188, 3); + lean_ctor_release(x_188, 4); + lean_ctor_release(x_188, 5); + x_212 = x_188; +} else { + lean_dec_ref(x_188); + x_212 = lean_box(0); +} +x_213 = lean_ctor_get(x_205, 0); +lean_inc(x_213); +x_214 = lean_ctor_get(x_205, 1); +lean_inc(x_214); +x_215 = lean_ctor_get(x_205, 3); +lean_inc(x_215); +x_216 = lean_ctor_get(x_205, 4); +lean_inc(x_216); +if (lean_is_exclusive(x_205)) { + lean_ctor_release(x_205, 0); + lean_ctor_release(x_205, 1); + lean_ctor_release(x_205, 2); + lean_ctor_release(x_205, 3); + lean_ctor_release(x_205, 4); + x_217 = x_205; +} else { + lean_dec_ref(x_205); + x_217 = lean_box(0); +} +if (lean_is_scalar(x_217)) { + x_218 = lean_alloc_ctor(0, 5, 0); +} else { + x_218 = x_217; +} +lean_ctor_set(x_218, 0, x_213); +lean_ctor_set(x_218, 1, x_214); +lean_ctor_set(x_218, 2, x_183); +lean_ctor_set(x_218, 3, x_215); +lean_ctor_set(x_218, 4, x_216); +if (lean_is_scalar(x_212)) { + x_219 = lean_alloc_ctor(0, 6, 0); +} else { + x_219 = x_212; +} +lean_ctor_set(x_219, 0, x_207); +lean_ctor_set(x_219, 1, x_208); +lean_ctor_set(x_219, 2, x_218); +lean_ctor_set(x_219, 3, x_209); +lean_ctor_set(x_219, 4, x_210); +lean_ctor_set(x_219, 5, x_211); +if (lean_is_scalar(x_27)) { + x_220 = lean_alloc_ctor(0, 2, 0); +} else { + x_220 = x_27; +} +lean_ctor_set(x_220, 0, x_206); +lean_ctor_set(x_220, 1, x_219); +return x_220; } } } } default: { -lean_object* x_231; lean_object* x_232; -x_231 = lean_ctor_get(x_20, 1); -lean_inc(x_231); +lean_object* x_241; lean_object* x_242; +x_241 = lean_ctor_get(x_20, 1); +lean_inc(x_241); lean_dec(x_20); lean_inc(x_6); -x_232 = l_Lean_Meta_isClassExpensive___main(x_19, x_6, x_231); -if (lean_obj_tag(x_232) == 0) +x_242 = l_Lean_Meta_isClassExpensive___main(x_19, x_6, x_241); +if (lean_obj_tag(x_242) == 0) { -lean_object* x_233; -x_233 = lean_ctor_get(x_232, 0); -lean_inc(x_233); -if (lean_obj_tag(x_233) == 0) +lean_object* x_243; +x_243 = lean_ctor_get(x_242, 0); +lean_inc(x_243); +if (lean_obj_tag(x_243) == 0) { -lean_object* x_234; lean_object* x_235; lean_object* x_236; +lean_object* x_244; lean_object* x_245; lean_object* x_246; lean_dec(x_15); -x_234 = lean_ctor_get(x_232, 1); -lean_inc(x_234); -lean_dec(x_232); -x_235 = lean_unsigned_to_nat(1u); -x_236 = lean_nat_add(x_5, x_235); +x_244 = lean_ctor_get(x_242, 1); +lean_inc(x_244); +lean_dec(x_242); +x_245 = lean_unsigned_to_nat(1u); +x_246 = lean_nat_add(x_5, x_245); lean_dec(x_5); -x_5 = x_236; -x_7 = x_234; +x_5 = x_246; +x_7 = x_244; goto _start; } else { -lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; lean_object* x_242; uint8_t x_243; -x_238 = lean_ctor_get(x_232, 1); -lean_inc(x_238); -if (lean_is_exclusive(x_232)) { - lean_ctor_release(x_232, 0); - lean_ctor_release(x_232, 1); - x_239 = x_232; +lean_object* x_248; lean_object* x_249; lean_object* x_250; lean_object* x_251; lean_object* x_252; uint8_t x_253; +x_248 = lean_ctor_get(x_242, 1); +lean_inc(x_248); +if (lean_is_exclusive(x_242)) { + lean_ctor_release(x_242, 0); + lean_ctor_release(x_242, 1); + x_249 = x_242; } else { - lean_dec_ref(x_232); - x_239 = lean_box(0); + lean_dec_ref(x_242); + x_249 = lean_box(0); } -x_240 = lean_ctor_get(x_233, 0); -lean_inc(x_240); -lean_dec(x_233); -x_241 = lean_unsigned_to_nat(1u); -x_242 = lean_nat_add(x_5, x_241); -lean_dec(x_5); -x_243 = !lean_is_exclusive(x_238); -if (x_243 == 0) -{ -lean_object* x_244; uint8_t x_245; -x_244 = lean_ctor_get(x_238, 2); -x_245 = !lean_is_exclusive(x_244); -if (x_245 == 0) -{ -lean_object* x_246; lean_object* x_247; lean_object* x_248; lean_object* x_298; uint8_t x_299; -x_246 = lean_ctor_get(x_244, 2); -x_298 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_244, 2, x_298); -x_299 = !lean_is_exclusive(x_6); -if (x_299 == 0) -{ -lean_object* x_300; lean_object* x_301; lean_object* x_302; lean_object* x_303; -x_300 = lean_ctor_get(x_6, 2); -x_301 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_301, 0, x_240); -lean_ctor_set(x_301, 1, x_15); -x_302 = lean_array_push(x_300, x_301); -lean_ctor_set(x_6, 2, x_302); -x_303 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_30__replaceIndFVarsWithConsts___spec__4(x_1, x_2, x_3, x_4, x_242, x_6, x_238); -if (lean_obj_tag(x_303) == 0) -{ -lean_object* x_304; lean_object* x_305; lean_object* x_306; -x_304 = lean_ctor_get(x_303, 0); -lean_inc(x_304); -x_305 = lean_ctor_get(x_303, 1); -lean_inc(x_305); -lean_dec(x_303); -x_306 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_306, 0, x_304); -x_247 = x_306; -x_248 = x_305; -goto block_297; -} -else -{ -lean_object* x_307; lean_object* x_308; lean_object* x_309; -x_307 = lean_ctor_get(x_303, 0); -lean_inc(x_307); -x_308 = lean_ctor_get(x_303, 1); -lean_inc(x_308); -lean_dec(x_303); -x_309 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_309, 0, x_307); -x_247 = x_309; -x_248 = x_308; -goto block_297; -} -} -else -{ -lean_object* x_310; lean_object* x_311; lean_object* x_312; lean_object* x_313; lean_object* x_314; lean_object* x_315; lean_object* x_316; lean_object* x_317; lean_object* x_318; -x_310 = lean_ctor_get(x_6, 0); -x_311 = lean_ctor_get(x_6, 1); -x_312 = lean_ctor_get(x_6, 2); -x_313 = lean_ctor_get(x_6, 3); -x_314 = lean_ctor_get(x_6, 4); -lean_inc(x_314); -lean_inc(x_313); -lean_inc(x_312); -lean_inc(x_311); -lean_inc(x_310); -lean_dec(x_6); -x_315 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_315, 0, x_240); -lean_ctor_set(x_315, 1, x_15); -x_316 = lean_array_push(x_312, x_315); -x_317 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_317, 0, x_310); -lean_ctor_set(x_317, 1, x_311); -lean_ctor_set(x_317, 2, x_316); -lean_ctor_set(x_317, 3, x_313); -lean_ctor_set(x_317, 4, x_314); -x_318 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_30__replaceIndFVarsWithConsts___spec__4(x_1, x_2, x_3, x_4, x_242, x_317, x_238); -if (lean_obj_tag(x_318) == 0) -{ -lean_object* x_319; lean_object* x_320; lean_object* x_321; -x_319 = lean_ctor_get(x_318, 0); -lean_inc(x_319); -x_320 = lean_ctor_get(x_318, 1); -lean_inc(x_320); -lean_dec(x_318); -x_321 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_321, 0, x_319); -x_247 = x_321; -x_248 = x_320; -goto block_297; -} -else -{ -lean_object* x_322; lean_object* x_323; lean_object* x_324; -x_322 = lean_ctor_get(x_318, 0); -lean_inc(x_322); -x_323 = lean_ctor_get(x_318, 1); -lean_inc(x_323); -lean_dec(x_318); -x_324 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_324, 0, x_322); -x_247 = x_324; -x_248 = x_323; -goto block_297; -} -} -block_297: -{ -if (lean_obj_tag(x_247) == 0) -{ -lean_object* x_249; lean_object* x_250; uint8_t x_251; -x_249 = lean_ctor_get(x_248, 2); -lean_inc(x_249); -x_250 = lean_ctor_get(x_247, 0); +x_250 = lean_ctor_get(x_243, 0); lean_inc(x_250); -lean_dec(x_247); -x_251 = !lean_is_exclusive(x_248); -if (x_251 == 0) -{ -lean_object* x_252; uint8_t x_253; -x_252 = lean_ctor_get(x_248, 2); -lean_dec(x_252); -x_253 = !lean_is_exclusive(x_249); +lean_dec(x_243); +x_251 = lean_unsigned_to_nat(1u); +x_252 = lean_nat_add(x_5, x_251); +lean_dec(x_5); +x_253 = !lean_is_exclusive(x_248); if (x_253 == 0) { -lean_object* x_254; lean_object* x_255; -x_254 = lean_ctor_get(x_249, 2); -lean_dec(x_254); -lean_ctor_set(x_249, 2, x_246); -if (lean_is_scalar(x_239)) { - x_255 = lean_alloc_ctor(1, 2, 0); -} else { - x_255 = x_239; - lean_ctor_set_tag(x_255, 1); -} -lean_ctor_set(x_255, 0, x_250); -lean_ctor_set(x_255, 1, x_248); -return x_255; +lean_object* x_254; uint8_t x_255; +x_254 = lean_ctor_get(x_248, 2); +x_255 = !lean_is_exclusive(x_254); +if (x_255 == 0) +{ +lean_object* x_256; lean_object* x_257; lean_object* x_258; lean_object* x_312; uint8_t x_313; +x_256 = lean_ctor_get(x_254, 2); +x_312 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_254, 2, x_312); +x_313 = !lean_is_exclusive(x_6); +if (x_313 == 0) +{ +lean_object* x_314; lean_object* x_315; lean_object* x_316; lean_object* x_317; +x_314 = lean_ctor_get(x_6, 2); +x_315 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_315, 0, x_250); +lean_ctor_set(x_315, 1, x_15); +x_316 = lean_array_push(x_314, x_315); +lean_ctor_set(x_6, 2, x_316); +x_317 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_30__replaceIndFVarsWithConsts___spec__4(x_1, x_2, x_3, x_4, x_252, x_6, x_248); +if (lean_obj_tag(x_317) == 0) +{ +lean_object* x_318; lean_object* x_319; lean_object* x_320; +x_318 = lean_ctor_get(x_317, 0); +lean_inc(x_318); +x_319 = lean_ctor_get(x_317, 1); +lean_inc(x_319); +lean_dec(x_317); +x_320 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_320, 0, x_318); +x_257 = x_320; +x_258 = x_319; +goto block_311; } else { -lean_object* x_256; lean_object* x_257; lean_object* x_258; lean_object* x_259; lean_object* x_260; -x_256 = lean_ctor_get(x_249, 0); -x_257 = lean_ctor_get(x_249, 1); -x_258 = lean_ctor_get(x_249, 3); -lean_inc(x_258); -lean_inc(x_257); -lean_inc(x_256); -lean_dec(x_249); -x_259 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_259, 0, x_256); -lean_ctor_set(x_259, 1, x_257); -lean_ctor_set(x_259, 2, x_246); -lean_ctor_set(x_259, 3, x_258); -lean_ctor_set(x_248, 2, x_259); -if (lean_is_scalar(x_239)) { - x_260 = lean_alloc_ctor(1, 2, 0); -} else { - x_260 = x_239; - lean_ctor_set_tag(x_260, 1); -} -lean_ctor_set(x_260, 0, x_250); -lean_ctor_set(x_260, 1, x_248); -return x_260; +lean_object* x_321; lean_object* x_322; lean_object* x_323; +x_321 = lean_ctor_get(x_317, 0); +lean_inc(x_321); +x_322 = lean_ctor_get(x_317, 1); +lean_inc(x_322); +lean_dec(x_317); +x_323 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_323, 0, x_321); +x_257 = x_323; +x_258 = x_322; +goto block_311; } } else { -lean_object* x_261; lean_object* x_262; lean_object* x_263; lean_object* x_264; lean_object* x_265; lean_object* x_266; lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_object* x_270; lean_object* x_271; lean_object* x_272; -x_261 = lean_ctor_get(x_248, 0); -x_262 = lean_ctor_get(x_248, 1); -x_263 = lean_ctor_get(x_248, 3); -x_264 = lean_ctor_get(x_248, 4); -x_265 = lean_ctor_get(x_248, 5); -lean_inc(x_265); -lean_inc(x_264); -lean_inc(x_263); -lean_inc(x_262); -lean_inc(x_261); -lean_dec(x_248); -x_266 = lean_ctor_get(x_249, 0); -lean_inc(x_266); -x_267 = lean_ctor_get(x_249, 1); -lean_inc(x_267); -x_268 = lean_ctor_get(x_249, 3); +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; +x_324 = lean_ctor_get(x_6, 0); +x_325 = lean_ctor_get(x_6, 1); +x_326 = lean_ctor_get(x_6, 2); +x_327 = lean_ctor_get(x_6, 3); +x_328 = lean_ctor_get(x_6, 4); +lean_inc(x_328); +lean_inc(x_327); +lean_inc(x_326); +lean_inc(x_325); +lean_inc(x_324); +lean_dec(x_6); +x_329 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_329, 0, x_250); +lean_ctor_set(x_329, 1, x_15); +x_330 = lean_array_push(x_326, x_329); +x_331 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_331, 0, x_324); +lean_ctor_set(x_331, 1, x_325); +lean_ctor_set(x_331, 2, x_330); +lean_ctor_set(x_331, 3, x_327); +lean_ctor_set(x_331, 4, x_328); +x_332 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_30__replaceIndFVarsWithConsts___spec__4(x_1, x_2, x_3, x_4, x_252, x_331, x_248); +if (lean_obj_tag(x_332) == 0) +{ +lean_object* x_333; lean_object* x_334; lean_object* x_335; +x_333 = lean_ctor_get(x_332, 0); +lean_inc(x_333); +x_334 = lean_ctor_get(x_332, 1); +lean_inc(x_334); +lean_dec(x_332); +x_335 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_335, 0, x_333); +x_257 = x_335; +x_258 = x_334; +goto block_311; +} +else +{ +lean_object* x_336; lean_object* x_337; lean_object* x_338; +x_336 = lean_ctor_get(x_332, 0); +lean_inc(x_336); +x_337 = lean_ctor_get(x_332, 1); +lean_inc(x_337); +lean_dec(x_332); +x_338 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_338, 0, x_336); +x_257 = x_338; +x_258 = x_337; +goto block_311; +} +} +block_311: +{ +if (lean_obj_tag(x_257) == 0) +{ +lean_object* x_259; lean_object* x_260; uint8_t x_261; +x_259 = lean_ctor_get(x_258, 2); +lean_inc(x_259); +x_260 = lean_ctor_get(x_257, 0); +lean_inc(x_260); +lean_dec(x_257); +x_261 = !lean_is_exclusive(x_258); +if (x_261 == 0) +{ +lean_object* x_262; uint8_t x_263; +x_262 = lean_ctor_get(x_258, 2); +lean_dec(x_262); +x_263 = !lean_is_exclusive(x_259); +if (x_263 == 0) +{ +lean_object* x_264; lean_object* x_265; +x_264 = lean_ctor_get(x_259, 2); +lean_dec(x_264); +lean_ctor_set(x_259, 2, x_256); +if (lean_is_scalar(x_249)) { + x_265 = lean_alloc_ctor(1, 2, 0); +} else { + x_265 = x_249; + lean_ctor_set_tag(x_265, 1); +} +lean_ctor_set(x_265, 0, x_260); +lean_ctor_set(x_265, 1, x_258); +return x_265; +} +else +{ +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_266 = lean_ctor_get(x_259, 0); +x_267 = lean_ctor_get(x_259, 1); +x_268 = lean_ctor_get(x_259, 3); +x_269 = lean_ctor_get(x_259, 4); +lean_inc(x_269); lean_inc(x_268); -if (lean_is_exclusive(x_249)) { - lean_ctor_release(x_249, 0); - lean_ctor_release(x_249, 1); - lean_ctor_release(x_249, 2); - lean_ctor_release(x_249, 3); - x_269 = x_249; -} else { - lean_dec_ref(x_249); - x_269 = lean_box(0); -} -if (lean_is_scalar(x_269)) { - x_270 = lean_alloc_ctor(0, 4, 0); -} else { - x_270 = x_269; -} +lean_inc(x_267); +lean_inc(x_266); +lean_dec(x_259); +x_270 = lean_alloc_ctor(0, 5, 0); lean_ctor_set(x_270, 0, x_266); lean_ctor_set(x_270, 1, x_267); -lean_ctor_set(x_270, 2, x_246); +lean_ctor_set(x_270, 2, x_256); lean_ctor_set(x_270, 3, x_268); -x_271 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_271, 0, x_261); -lean_ctor_set(x_271, 1, x_262); -lean_ctor_set(x_271, 2, x_270); -lean_ctor_set(x_271, 3, x_263); -lean_ctor_set(x_271, 4, x_264); -lean_ctor_set(x_271, 5, x_265); -if (lean_is_scalar(x_239)) { - x_272 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_270, 4, x_269); +lean_ctor_set(x_258, 2, x_270); +if (lean_is_scalar(x_249)) { + x_271 = lean_alloc_ctor(1, 2, 0); } else { - x_272 = x_239; - lean_ctor_set_tag(x_272, 1); + x_271 = x_249; + lean_ctor_set_tag(x_271, 1); } -lean_ctor_set(x_272, 0, x_250); -lean_ctor_set(x_272, 1, x_271); -return x_272; +lean_ctor_set(x_271, 0, x_260); +lean_ctor_set(x_271, 1, x_258); +return x_271; } } else { -lean_object* x_273; lean_object* x_274; uint8_t x_275; -x_273 = lean_ctor_get(x_248, 2); -lean_inc(x_273); -x_274 = lean_ctor_get(x_247, 0); +lean_object* x_272; lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_object* x_276; lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; lean_object* x_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; +x_272 = lean_ctor_get(x_258, 0); +x_273 = lean_ctor_get(x_258, 1); +x_274 = lean_ctor_get(x_258, 3); +x_275 = lean_ctor_get(x_258, 4); +x_276 = lean_ctor_get(x_258, 5); +lean_inc(x_276); +lean_inc(x_275); lean_inc(x_274); -lean_dec(x_247); -x_275 = !lean_is_exclusive(x_248); -if (x_275 == 0) -{ -lean_object* x_276; uint8_t x_277; -x_276 = lean_ctor_get(x_248, 2); -lean_dec(x_276); -x_277 = !lean_is_exclusive(x_273); -if (x_277 == 0) -{ -lean_object* x_278; lean_object* x_279; -x_278 = lean_ctor_get(x_273, 2); -lean_dec(x_278); -lean_ctor_set(x_273, 2, x_246); -if (lean_is_scalar(x_239)) { - x_279 = lean_alloc_ctor(0, 2, 0); -} else { - x_279 = x_239; -} -lean_ctor_set(x_279, 0, x_274); -lean_ctor_set(x_279, 1, x_248); -return x_279; -} -else -{ -lean_object* x_280; lean_object* x_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; -x_280 = lean_ctor_get(x_273, 0); -x_281 = lean_ctor_get(x_273, 1); -x_282 = lean_ctor_get(x_273, 3); -lean_inc(x_282); -lean_inc(x_281); +lean_inc(x_273); +lean_inc(x_272); +lean_dec(x_258); +x_277 = lean_ctor_get(x_259, 0); +lean_inc(x_277); +x_278 = lean_ctor_get(x_259, 1); +lean_inc(x_278); +x_279 = lean_ctor_get(x_259, 3); +lean_inc(x_279); +x_280 = lean_ctor_get(x_259, 4); lean_inc(x_280); -lean_dec(x_273); -x_283 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_283, 0, x_280); -lean_ctor_set(x_283, 1, x_281); -lean_ctor_set(x_283, 2, x_246); -lean_ctor_set(x_283, 3, x_282); -lean_ctor_set(x_248, 2, x_283); -if (lean_is_scalar(x_239)) { - x_284 = lean_alloc_ctor(0, 2, 0); +if (lean_is_exclusive(x_259)) { + lean_ctor_release(x_259, 0); + lean_ctor_release(x_259, 1); + lean_ctor_release(x_259, 2); + lean_ctor_release(x_259, 3); + lean_ctor_release(x_259, 4); + x_281 = x_259; } else { - x_284 = x_239; + lean_dec_ref(x_259); + x_281 = lean_box(0); } -lean_ctor_set(x_284, 0, x_274); -lean_ctor_set(x_284, 1, x_248); +if (lean_is_scalar(x_281)) { + x_282 = lean_alloc_ctor(0, 5, 0); +} else { + x_282 = x_281; +} +lean_ctor_set(x_282, 0, x_277); +lean_ctor_set(x_282, 1, x_278); +lean_ctor_set(x_282, 2, x_256); +lean_ctor_set(x_282, 3, x_279); +lean_ctor_set(x_282, 4, x_280); +x_283 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_283, 0, x_272); +lean_ctor_set(x_283, 1, x_273); +lean_ctor_set(x_283, 2, x_282); +lean_ctor_set(x_283, 3, x_274); +lean_ctor_set(x_283, 4, x_275); +lean_ctor_set(x_283, 5, x_276); +if (lean_is_scalar(x_249)) { + x_284 = lean_alloc_ctor(1, 2, 0); +} else { + x_284 = x_249; + lean_ctor_set_tag(x_284, 1); +} +lean_ctor_set(x_284, 0, x_260); +lean_ctor_set(x_284, 1, x_283); return x_284; } } else { -lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; lean_object* x_289; lean_object* x_290; lean_object* x_291; lean_object* x_292; lean_object* x_293; lean_object* x_294; lean_object* x_295; lean_object* x_296; -x_285 = lean_ctor_get(x_248, 0); -x_286 = lean_ctor_get(x_248, 1); -x_287 = lean_ctor_get(x_248, 3); -x_288 = lean_ctor_get(x_248, 4); -x_289 = lean_ctor_get(x_248, 5); -lean_inc(x_289); -lean_inc(x_288); -lean_inc(x_287); -lean_inc(x_286); +lean_object* x_285; lean_object* x_286; uint8_t x_287; +x_285 = lean_ctor_get(x_258, 2); lean_inc(x_285); -lean_dec(x_248); -x_290 = lean_ctor_get(x_273, 0); -lean_inc(x_290); -x_291 = lean_ctor_get(x_273, 1); -lean_inc(x_291); -x_292 = lean_ctor_get(x_273, 3); +x_286 = lean_ctor_get(x_257, 0); +lean_inc(x_286); +lean_dec(x_257); +x_287 = !lean_is_exclusive(x_258); +if (x_287 == 0) +{ +lean_object* x_288; uint8_t x_289; +x_288 = lean_ctor_get(x_258, 2); +lean_dec(x_288); +x_289 = !lean_is_exclusive(x_285); +if (x_289 == 0) +{ +lean_object* x_290; lean_object* x_291; +x_290 = lean_ctor_get(x_285, 2); +lean_dec(x_290); +lean_ctor_set(x_285, 2, x_256); +if (lean_is_scalar(x_249)) { + x_291 = lean_alloc_ctor(0, 2, 0); +} else { + x_291 = x_249; +} +lean_ctor_set(x_291, 0, x_286); +lean_ctor_set(x_291, 1, x_258); +return x_291; +} +else +{ +lean_object* x_292; lean_object* x_293; lean_object* x_294; lean_object* x_295; lean_object* x_296; lean_object* x_297; +x_292 = lean_ctor_get(x_285, 0); +x_293 = lean_ctor_get(x_285, 1); +x_294 = lean_ctor_get(x_285, 3); +x_295 = lean_ctor_get(x_285, 4); +lean_inc(x_295); +lean_inc(x_294); +lean_inc(x_293); lean_inc(x_292); -if (lean_is_exclusive(x_273)) { - lean_ctor_release(x_273, 0); - lean_ctor_release(x_273, 1); - lean_ctor_release(x_273, 2); - lean_ctor_release(x_273, 3); - x_293 = x_273; +lean_dec(x_285); +x_296 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_296, 0, x_292); +lean_ctor_set(x_296, 1, x_293); +lean_ctor_set(x_296, 2, x_256); +lean_ctor_set(x_296, 3, x_294); +lean_ctor_set(x_296, 4, x_295); +lean_ctor_set(x_258, 2, x_296); +if (lean_is_scalar(x_249)) { + x_297 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_273); - x_293 = lean_box(0); + x_297 = x_249; } -if (lean_is_scalar(x_293)) { - x_294 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_297, 0, x_286); +lean_ctor_set(x_297, 1, x_258); +return x_297; +} +} +else +{ +lean_object* x_298; lean_object* x_299; lean_object* x_300; lean_object* x_301; lean_object* x_302; lean_object* x_303; lean_object* x_304; lean_object* x_305; lean_object* x_306; lean_object* x_307; lean_object* x_308; lean_object* x_309; lean_object* x_310; +x_298 = lean_ctor_get(x_258, 0); +x_299 = lean_ctor_get(x_258, 1); +x_300 = lean_ctor_get(x_258, 3); +x_301 = lean_ctor_get(x_258, 4); +x_302 = lean_ctor_get(x_258, 5); +lean_inc(x_302); +lean_inc(x_301); +lean_inc(x_300); +lean_inc(x_299); +lean_inc(x_298); +lean_dec(x_258); +x_303 = lean_ctor_get(x_285, 0); +lean_inc(x_303); +x_304 = lean_ctor_get(x_285, 1); +lean_inc(x_304); +x_305 = lean_ctor_get(x_285, 3); +lean_inc(x_305); +x_306 = lean_ctor_get(x_285, 4); +lean_inc(x_306); +if (lean_is_exclusive(x_285)) { + lean_ctor_release(x_285, 0); + lean_ctor_release(x_285, 1); + lean_ctor_release(x_285, 2); + lean_ctor_release(x_285, 3); + lean_ctor_release(x_285, 4); + x_307 = x_285; } else { - x_294 = x_293; + lean_dec_ref(x_285); + x_307 = lean_box(0); } -lean_ctor_set(x_294, 0, x_290); -lean_ctor_set(x_294, 1, x_291); -lean_ctor_set(x_294, 2, x_246); -lean_ctor_set(x_294, 3, x_292); -x_295 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_295, 0, x_285); -lean_ctor_set(x_295, 1, x_286); -lean_ctor_set(x_295, 2, x_294); -lean_ctor_set(x_295, 3, x_287); -lean_ctor_set(x_295, 4, x_288); -lean_ctor_set(x_295, 5, x_289); -if (lean_is_scalar(x_239)) { - x_296 = lean_alloc_ctor(0, 2, 0); +if (lean_is_scalar(x_307)) { + x_308 = lean_alloc_ctor(0, 5, 0); } else { - x_296 = x_239; + x_308 = x_307; } -lean_ctor_set(x_296, 0, x_274); -lean_ctor_set(x_296, 1, x_295); -return x_296; +lean_ctor_set(x_308, 0, x_303); +lean_ctor_set(x_308, 1, x_304); +lean_ctor_set(x_308, 2, x_256); +lean_ctor_set(x_308, 3, x_305); +lean_ctor_set(x_308, 4, x_306); +x_309 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_309, 0, x_298); +lean_ctor_set(x_309, 1, x_299); +lean_ctor_set(x_309, 2, x_308); +lean_ctor_set(x_309, 3, x_300); +lean_ctor_set(x_309, 4, x_301); +lean_ctor_set(x_309, 5, x_302); +if (lean_is_scalar(x_249)) { + x_310 = lean_alloc_ctor(0, 2, 0); +} else { + x_310 = x_249; +} +lean_ctor_set(x_310, 0, x_286); +lean_ctor_set(x_310, 1, x_309); +return x_310; } } } } else { -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_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_325 = lean_ctor_get(x_244, 0); -x_326 = lean_ctor_get(x_244, 1); -x_327 = lean_ctor_get(x_244, 2); -x_328 = lean_ctor_get(x_244, 3); -lean_inc(x_328); -lean_inc(x_327); -lean_inc(x_326); -lean_inc(x_325); -lean_dec(x_244); -x_362 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_363 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_363, 0, x_325); -lean_ctor_set(x_363, 1, x_326); -lean_ctor_set(x_363, 2, x_362); -lean_ctor_set(x_363, 3, x_328); -lean_ctor_set(x_238, 2, x_363); -x_364 = lean_ctor_get(x_6, 0); -lean_inc(x_364); -x_365 = lean_ctor_get(x_6, 1); -lean_inc(x_365); -x_366 = lean_ctor_get(x_6, 2); -lean_inc(x_366); -x_367 = lean_ctor_get(x_6, 3); -lean_inc(x_367); -x_368 = lean_ctor_get(x_6, 4); -lean_inc(x_368); +lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; lean_object* x_345; 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_339 = lean_ctor_get(x_254, 0); +x_340 = lean_ctor_get(x_254, 1); +x_341 = lean_ctor_get(x_254, 2); +x_342 = lean_ctor_get(x_254, 3); +x_343 = lean_ctor_get(x_254, 4); +lean_inc(x_343); +lean_inc(x_342); +lean_inc(x_341); +lean_inc(x_340); +lean_inc(x_339); +lean_dec(x_254); +x_379 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_380 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_380, 0, x_339); +lean_ctor_set(x_380, 1, x_340); +lean_ctor_set(x_380, 2, x_379); +lean_ctor_set(x_380, 3, x_342); +lean_ctor_set(x_380, 4, x_343); +lean_ctor_set(x_248, 2, x_380); +x_381 = lean_ctor_get(x_6, 0); +lean_inc(x_381); +x_382 = lean_ctor_get(x_6, 1); +lean_inc(x_382); +x_383 = lean_ctor_get(x_6, 2); +lean_inc(x_383); +x_384 = lean_ctor_get(x_6, 3); +lean_inc(x_384); +x_385 = lean_ctor_get(x_6, 4); +lean_inc(x_385); if (lean_is_exclusive(x_6)) { lean_ctor_release(x_6, 0); lean_ctor_release(x_6, 1); lean_ctor_release(x_6, 2); lean_ctor_release(x_6, 3); lean_ctor_release(x_6, 4); - x_369 = x_6; + x_386 = x_6; } else { lean_dec_ref(x_6); - x_369 = lean_box(0); + x_386 = lean_box(0); } -x_370 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_370, 0, x_240); -lean_ctor_set(x_370, 1, x_15); -x_371 = lean_array_push(x_366, x_370); -if (lean_is_scalar(x_369)) { - x_372 = lean_alloc_ctor(0, 5, 0); +x_387 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_387, 0, x_250); +lean_ctor_set(x_387, 1, x_15); +x_388 = lean_array_push(x_383, x_387); +if (lean_is_scalar(x_386)) { + x_389 = lean_alloc_ctor(0, 5, 0); } else { - x_372 = x_369; + x_389 = x_386; } -lean_ctor_set(x_372, 0, x_364); -lean_ctor_set(x_372, 1, x_365); -lean_ctor_set(x_372, 2, x_371); -lean_ctor_set(x_372, 3, x_367); -lean_ctor_set(x_372, 4, x_368); -x_373 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_30__replaceIndFVarsWithConsts___spec__4(x_1, x_2, x_3, x_4, x_242, x_372, x_238); -if (lean_obj_tag(x_373) == 0) +lean_ctor_set(x_389, 0, x_381); +lean_ctor_set(x_389, 1, x_382); +lean_ctor_set(x_389, 2, x_388); +lean_ctor_set(x_389, 3, x_384); +lean_ctor_set(x_389, 4, x_385); +x_390 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_30__replaceIndFVarsWithConsts___spec__4(x_1, x_2, x_3, x_4, x_252, x_389, x_248); +if (lean_obj_tag(x_390) == 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); -x_376 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_376, 0, x_374); -x_329 = x_376; -x_330 = x_375; -goto block_361; +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); +x_393 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_393, 0, x_391); +x_344 = x_393; +x_345 = x_392; +goto block_378; } else { -lean_object* x_377; lean_object* x_378; lean_object* x_379; -x_377 = lean_ctor_get(x_373, 0); -lean_inc(x_377); -x_378 = lean_ctor_get(x_373, 1); -lean_inc(x_378); -lean_dec(x_373); -x_379 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_379, 0, x_377); -x_329 = x_379; -x_330 = x_378; -goto block_361; +lean_object* x_394; lean_object* x_395; lean_object* x_396; +x_394 = lean_ctor_get(x_390, 0); +lean_inc(x_394); +x_395 = lean_ctor_get(x_390, 1); +lean_inc(x_395); +lean_dec(x_390); +x_396 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_396, 0, x_394); +x_344 = x_396; +x_345 = x_395; +goto block_378; } -block_361: +block_378: { -if (lean_obj_tag(x_329) == 0) +if (lean_obj_tag(x_344) == 0) { -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; lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; lean_object* x_345; -x_331 = lean_ctor_get(x_330, 2); -lean_inc(x_331); -x_332 = lean_ctor_get(x_329, 0); -lean_inc(x_332); -lean_dec(x_329); -x_333 = lean_ctor_get(x_330, 0); -lean_inc(x_333); -x_334 = lean_ctor_get(x_330, 1); -lean_inc(x_334); -x_335 = lean_ctor_get(x_330, 3); -lean_inc(x_335); -x_336 = lean_ctor_get(x_330, 4); -lean_inc(x_336); -x_337 = lean_ctor_get(x_330, 5); -lean_inc(x_337); -if (lean_is_exclusive(x_330)) { - lean_ctor_release(x_330, 0); - lean_ctor_release(x_330, 1); - lean_ctor_release(x_330, 2); - lean_ctor_release(x_330, 3); - lean_ctor_release(x_330, 4); - lean_ctor_release(x_330, 5); - x_338 = x_330; -} else { - lean_dec_ref(x_330); - x_338 = lean_box(0); -} -x_339 = lean_ctor_get(x_331, 0); -lean_inc(x_339); -x_340 = lean_ctor_get(x_331, 1); -lean_inc(x_340); -x_341 = lean_ctor_get(x_331, 3); -lean_inc(x_341); -if (lean_is_exclusive(x_331)) { - lean_ctor_release(x_331, 0); - lean_ctor_release(x_331, 1); - lean_ctor_release(x_331, 2); - lean_ctor_release(x_331, 3); - x_342 = x_331; -} else { - lean_dec_ref(x_331); - x_342 = lean_box(0); -} -if (lean_is_scalar(x_342)) { - x_343 = lean_alloc_ctor(0, 4, 0); -} else { - x_343 = x_342; -} -lean_ctor_set(x_343, 0, x_339); -lean_ctor_set(x_343, 1, x_340); -lean_ctor_set(x_343, 2, x_327); -lean_ctor_set(x_343, 3, x_341); -if (lean_is_scalar(x_338)) { - x_344 = lean_alloc_ctor(0, 6, 0); -} else { - x_344 = x_338; -} -lean_ctor_set(x_344, 0, x_333); -lean_ctor_set(x_344, 1, x_334); -lean_ctor_set(x_344, 2, x_343); -lean_ctor_set(x_344, 3, x_335); -lean_ctor_set(x_344, 4, x_336); -lean_ctor_set(x_344, 5, x_337); -if (lean_is_scalar(x_239)) { - x_345 = lean_alloc_ctor(1, 2, 0); -} else { - x_345 = x_239; - lean_ctor_set_tag(x_345, 1); -} -lean_ctor_set(x_345, 0, x_332); -lean_ctor_set(x_345, 1, x_344); -return x_345; -} -else -{ -lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; lean_object* x_350; lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; lean_object* x_358; lean_object* x_359; lean_object* x_360; -x_346 = lean_ctor_get(x_330, 2); +lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; lean_object* x_350; lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; lean_object* x_358; lean_object* x_359; lean_object* x_360; lean_object* x_361; +x_346 = lean_ctor_get(x_345, 2); lean_inc(x_346); -x_347 = lean_ctor_get(x_329, 0); +x_347 = lean_ctor_get(x_344, 0); lean_inc(x_347); -lean_dec(x_329); -x_348 = lean_ctor_get(x_330, 0); +lean_dec(x_344); +x_348 = lean_ctor_get(x_345, 0); lean_inc(x_348); -x_349 = lean_ctor_get(x_330, 1); +x_349 = lean_ctor_get(x_345, 1); lean_inc(x_349); -x_350 = lean_ctor_get(x_330, 3); +x_350 = lean_ctor_get(x_345, 3); lean_inc(x_350); -x_351 = lean_ctor_get(x_330, 4); +x_351 = lean_ctor_get(x_345, 4); lean_inc(x_351); -x_352 = lean_ctor_get(x_330, 5); +x_352 = lean_ctor_get(x_345, 5); lean_inc(x_352); -if (lean_is_exclusive(x_330)) { - lean_ctor_release(x_330, 0); - lean_ctor_release(x_330, 1); - lean_ctor_release(x_330, 2); - lean_ctor_release(x_330, 3); - lean_ctor_release(x_330, 4); - lean_ctor_release(x_330, 5); - x_353 = x_330; +if (lean_is_exclusive(x_345)) { + lean_ctor_release(x_345, 0); + lean_ctor_release(x_345, 1); + lean_ctor_release(x_345, 2); + lean_ctor_release(x_345, 3); + lean_ctor_release(x_345, 4); + lean_ctor_release(x_345, 5); + x_353 = x_345; } else { - lean_dec_ref(x_330); + lean_dec_ref(x_345); x_353 = lean_box(0); } x_354 = lean_ctor_get(x_346, 0); @@ -11936,315 +11914,411 @@ x_355 = lean_ctor_get(x_346, 1); lean_inc(x_355); x_356 = lean_ctor_get(x_346, 3); lean_inc(x_356); +x_357 = lean_ctor_get(x_346, 4); +lean_inc(x_357); if (lean_is_exclusive(x_346)) { lean_ctor_release(x_346, 0); lean_ctor_release(x_346, 1); lean_ctor_release(x_346, 2); lean_ctor_release(x_346, 3); - x_357 = x_346; + lean_ctor_release(x_346, 4); + x_358 = x_346; } else { lean_dec_ref(x_346); - x_357 = lean_box(0); + x_358 = lean_box(0); } -if (lean_is_scalar(x_357)) { - x_358 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_358)) { + x_359 = lean_alloc_ctor(0, 5, 0); } else { - x_358 = x_357; + x_359 = x_358; } -lean_ctor_set(x_358, 0, x_354); -lean_ctor_set(x_358, 1, x_355); -lean_ctor_set(x_358, 2, x_327); -lean_ctor_set(x_358, 3, x_356); +lean_ctor_set(x_359, 0, x_354); +lean_ctor_set(x_359, 1, x_355); +lean_ctor_set(x_359, 2, x_341); +lean_ctor_set(x_359, 3, x_356); +lean_ctor_set(x_359, 4, x_357); if (lean_is_scalar(x_353)) { - x_359 = lean_alloc_ctor(0, 6, 0); + x_360 = lean_alloc_ctor(0, 6, 0); } else { - x_359 = x_353; + x_360 = x_353; } -lean_ctor_set(x_359, 0, x_348); -lean_ctor_set(x_359, 1, x_349); -lean_ctor_set(x_359, 2, x_358); -lean_ctor_set(x_359, 3, x_350); -lean_ctor_set(x_359, 4, x_351); -lean_ctor_set(x_359, 5, x_352); -if (lean_is_scalar(x_239)) { - x_360 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_360, 0, x_348); +lean_ctor_set(x_360, 1, x_349); +lean_ctor_set(x_360, 2, x_359); +lean_ctor_set(x_360, 3, x_350); +lean_ctor_set(x_360, 4, x_351); +lean_ctor_set(x_360, 5, x_352); +if (lean_is_scalar(x_249)) { + x_361 = lean_alloc_ctor(1, 2, 0); } else { - x_360 = x_239; + x_361 = x_249; + lean_ctor_set_tag(x_361, 1); } -lean_ctor_set(x_360, 0, x_347); -lean_ctor_set(x_360, 1, x_359); -return x_360; +lean_ctor_set(x_361, 0, x_347); +lean_ctor_set(x_361, 1, x_360); +return x_361; +} +else +{ +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; lean_object* x_374; lean_object* x_375; lean_object* x_376; lean_object* x_377; +x_362 = lean_ctor_get(x_345, 2); +lean_inc(x_362); +x_363 = lean_ctor_get(x_344, 0); +lean_inc(x_363); +lean_dec(x_344); +x_364 = lean_ctor_get(x_345, 0); +lean_inc(x_364); +x_365 = lean_ctor_get(x_345, 1); +lean_inc(x_365); +x_366 = lean_ctor_get(x_345, 3); +lean_inc(x_366); +x_367 = lean_ctor_get(x_345, 4); +lean_inc(x_367); +x_368 = lean_ctor_get(x_345, 5); +lean_inc(x_368); +if (lean_is_exclusive(x_345)) { + lean_ctor_release(x_345, 0); + lean_ctor_release(x_345, 1); + lean_ctor_release(x_345, 2); + lean_ctor_release(x_345, 3); + lean_ctor_release(x_345, 4); + lean_ctor_release(x_345, 5); + x_369 = x_345; +} else { + lean_dec_ref(x_345); + x_369 = lean_box(0); +} +x_370 = lean_ctor_get(x_362, 0); +lean_inc(x_370); +x_371 = lean_ctor_get(x_362, 1); +lean_inc(x_371); +x_372 = lean_ctor_get(x_362, 3); +lean_inc(x_372); +x_373 = lean_ctor_get(x_362, 4); +lean_inc(x_373); +if (lean_is_exclusive(x_362)) { + lean_ctor_release(x_362, 0); + lean_ctor_release(x_362, 1); + lean_ctor_release(x_362, 2); + lean_ctor_release(x_362, 3); + lean_ctor_release(x_362, 4); + x_374 = x_362; +} else { + lean_dec_ref(x_362); + x_374 = lean_box(0); +} +if (lean_is_scalar(x_374)) { + x_375 = lean_alloc_ctor(0, 5, 0); +} else { + x_375 = x_374; +} +lean_ctor_set(x_375, 0, x_370); +lean_ctor_set(x_375, 1, x_371); +lean_ctor_set(x_375, 2, x_341); +lean_ctor_set(x_375, 3, x_372); +lean_ctor_set(x_375, 4, x_373); +if (lean_is_scalar(x_369)) { + x_376 = lean_alloc_ctor(0, 6, 0); +} else { + x_376 = x_369; +} +lean_ctor_set(x_376, 0, x_364); +lean_ctor_set(x_376, 1, x_365); +lean_ctor_set(x_376, 2, x_375); +lean_ctor_set(x_376, 3, x_366); +lean_ctor_set(x_376, 4, x_367); +lean_ctor_set(x_376, 5, x_368); +if (lean_is_scalar(x_249)) { + x_377 = lean_alloc_ctor(0, 2, 0); +} else { + x_377 = x_249; +} +lean_ctor_set(x_377, 0, x_363); +lean_ctor_set(x_377, 1, x_376); +return x_377; } } } } else { -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; lean_object* x_391; lean_object* x_392; lean_object* x_424; lean_object* x_425; lean_object* x_426; lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; lean_object* x_432; lean_object* x_433; lean_object* x_434; lean_object* x_435; lean_object* x_436; -x_380 = lean_ctor_get(x_238, 2); -x_381 = lean_ctor_get(x_238, 0); -x_382 = lean_ctor_get(x_238, 1); -x_383 = lean_ctor_get(x_238, 3); -x_384 = lean_ctor_get(x_238, 4); -x_385 = lean_ctor_get(x_238, 5); -lean_inc(x_385); -lean_inc(x_384); -lean_inc(x_383); -lean_inc(x_380); -lean_inc(x_382); -lean_inc(x_381); -lean_dec(x_238); -x_386 = lean_ctor_get(x_380, 0); -lean_inc(x_386); -x_387 = lean_ctor_get(x_380, 1); -lean_inc(x_387); -x_388 = lean_ctor_get(x_380, 2); -lean_inc(x_388); -x_389 = lean_ctor_get(x_380, 3); -lean_inc(x_389); -if (lean_is_exclusive(x_380)) { - lean_ctor_release(x_380, 0); - lean_ctor_release(x_380, 1); - lean_ctor_release(x_380, 2); - lean_ctor_release(x_380, 3); - x_390 = x_380; +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; lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_444; lean_object* x_445; lean_object* x_446; lean_object* x_447; lean_object* x_448; lean_object* x_449; lean_object* x_450; lean_object* x_451; lean_object* x_452; lean_object* x_453; lean_object* x_454; lean_object* x_455; lean_object* x_456; +x_397 = lean_ctor_get(x_248, 2); +x_398 = lean_ctor_get(x_248, 0); +x_399 = lean_ctor_get(x_248, 1); +x_400 = lean_ctor_get(x_248, 3); +x_401 = lean_ctor_get(x_248, 4); +x_402 = lean_ctor_get(x_248, 5); +lean_inc(x_402); +lean_inc(x_401); +lean_inc(x_400); +lean_inc(x_397); +lean_inc(x_399); +lean_inc(x_398); +lean_dec(x_248); +x_403 = lean_ctor_get(x_397, 0); +lean_inc(x_403); +x_404 = lean_ctor_get(x_397, 1); +lean_inc(x_404); +x_405 = lean_ctor_get(x_397, 2); +lean_inc(x_405); +x_406 = lean_ctor_get(x_397, 3); +lean_inc(x_406); +x_407 = lean_ctor_get(x_397, 4); +lean_inc(x_407); +if (lean_is_exclusive(x_397)) { + lean_ctor_release(x_397, 0); + lean_ctor_release(x_397, 1); + lean_ctor_release(x_397, 2); + lean_ctor_release(x_397, 3); + lean_ctor_release(x_397, 4); + x_408 = x_397; } else { - lean_dec_ref(x_380); - x_390 = lean_box(0); + lean_dec_ref(x_397); + x_408 = lean_box(0); } -x_424 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_390)) { - x_425 = lean_alloc_ctor(0, 4, 0); +x_444 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_408)) { + x_445 = lean_alloc_ctor(0, 5, 0); } else { - x_425 = x_390; + x_445 = x_408; } -lean_ctor_set(x_425, 0, x_386); -lean_ctor_set(x_425, 1, x_387); -lean_ctor_set(x_425, 2, x_424); -lean_ctor_set(x_425, 3, x_389); -x_426 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_426, 0, x_381); -lean_ctor_set(x_426, 1, x_382); -lean_ctor_set(x_426, 2, x_425); -lean_ctor_set(x_426, 3, x_383); -lean_ctor_set(x_426, 4, x_384); -lean_ctor_set(x_426, 5, x_385); -x_427 = lean_ctor_get(x_6, 0); -lean_inc(x_427); -x_428 = lean_ctor_get(x_6, 1); -lean_inc(x_428); -x_429 = lean_ctor_get(x_6, 2); -lean_inc(x_429); -x_430 = lean_ctor_get(x_6, 3); -lean_inc(x_430); -x_431 = lean_ctor_get(x_6, 4); -lean_inc(x_431); +lean_ctor_set(x_445, 0, x_403); +lean_ctor_set(x_445, 1, x_404); +lean_ctor_set(x_445, 2, x_444); +lean_ctor_set(x_445, 3, x_406); +lean_ctor_set(x_445, 4, x_407); +x_446 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_446, 0, x_398); +lean_ctor_set(x_446, 1, x_399); +lean_ctor_set(x_446, 2, x_445); +lean_ctor_set(x_446, 3, x_400); +lean_ctor_set(x_446, 4, x_401); +lean_ctor_set(x_446, 5, x_402); +x_447 = lean_ctor_get(x_6, 0); +lean_inc(x_447); +x_448 = lean_ctor_get(x_6, 1); +lean_inc(x_448); +x_449 = lean_ctor_get(x_6, 2); +lean_inc(x_449); +x_450 = lean_ctor_get(x_6, 3); +lean_inc(x_450); +x_451 = lean_ctor_get(x_6, 4); +lean_inc(x_451); if (lean_is_exclusive(x_6)) { lean_ctor_release(x_6, 0); lean_ctor_release(x_6, 1); lean_ctor_release(x_6, 2); lean_ctor_release(x_6, 3); lean_ctor_release(x_6, 4); - x_432 = x_6; + x_452 = x_6; } else { lean_dec_ref(x_6); - x_432 = lean_box(0); + x_452 = lean_box(0); } -x_433 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_433, 0, x_240); -lean_ctor_set(x_433, 1, x_15); -x_434 = lean_array_push(x_429, x_433); -if (lean_is_scalar(x_432)) { - x_435 = lean_alloc_ctor(0, 5, 0); +x_453 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_453, 0, x_250); +lean_ctor_set(x_453, 1, x_15); +x_454 = lean_array_push(x_449, x_453); +if (lean_is_scalar(x_452)) { + x_455 = lean_alloc_ctor(0, 5, 0); } else { - x_435 = x_432; + x_455 = x_452; } -lean_ctor_set(x_435, 0, x_427); -lean_ctor_set(x_435, 1, x_428); -lean_ctor_set(x_435, 2, x_434); -lean_ctor_set(x_435, 3, x_430); -lean_ctor_set(x_435, 4, x_431); -x_436 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_30__replaceIndFVarsWithConsts___spec__4(x_1, x_2, x_3, x_4, x_242, x_435, x_426); -if (lean_obj_tag(x_436) == 0) +lean_ctor_set(x_455, 0, x_447); +lean_ctor_set(x_455, 1, x_448); +lean_ctor_set(x_455, 2, x_454); +lean_ctor_set(x_455, 3, x_450); +lean_ctor_set(x_455, 4, x_451); +x_456 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_30__replaceIndFVarsWithConsts___spec__4(x_1, x_2, x_3, x_4, x_252, x_455, x_446); +if (lean_obj_tag(x_456) == 0) { -lean_object* x_437; lean_object* x_438; lean_object* x_439; -x_437 = lean_ctor_get(x_436, 0); -lean_inc(x_437); -x_438 = lean_ctor_get(x_436, 1); -lean_inc(x_438); -lean_dec(x_436); -x_439 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_439, 0, x_437); -x_391 = x_439; -x_392 = x_438; -goto block_423; +lean_object* x_457; lean_object* x_458; lean_object* x_459; +x_457 = lean_ctor_get(x_456, 0); +lean_inc(x_457); +x_458 = lean_ctor_get(x_456, 1); +lean_inc(x_458); +lean_dec(x_456); +x_459 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_459, 0, x_457); +x_409 = x_459; +x_410 = x_458; +goto block_443; } else { -lean_object* x_440; lean_object* x_441; lean_object* x_442; -x_440 = lean_ctor_get(x_436, 0); -lean_inc(x_440); -x_441 = lean_ctor_get(x_436, 1); -lean_inc(x_441); -lean_dec(x_436); -x_442 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_442, 0, x_440); -x_391 = x_442; -x_392 = x_441; -goto block_423; +lean_object* x_460; lean_object* x_461; lean_object* x_462; +x_460 = lean_ctor_get(x_456, 0); +lean_inc(x_460); +x_461 = lean_ctor_get(x_456, 1); +lean_inc(x_461); +lean_dec(x_456); +x_462 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_462, 0, x_460); +x_409 = x_462; +x_410 = x_461; +goto block_443; } -block_423: +block_443: { -if (lean_obj_tag(x_391) == 0) +if (lean_obj_tag(x_409) == 0) { -lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; lean_object* x_400; lean_object* x_401; lean_object* x_402; lean_object* x_403; lean_object* x_404; lean_object* x_405; lean_object* x_406; lean_object* x_407; -x_393 = lean_ctor_get(x_392, 2); -lean_inc(x_393); -x_394 = lean_ctor_get(x_391, 0); -lean_inc(x_394); -lean_dec(x_391); -x_395 = lean_ctor_get(x_392, 0); -lean_inc(x_395); -x_396 = lean_ctor_get(x_392, 1); -lean_inc(x_396); -x_397 = lean_ctor_get(x_392, 3); -lean_inc(x_397); -x_398 = lean_ctor_get(x_392, 4); -lean_inc(x_398); -x_399 = lean_ctor_get(x_392, 5); -lean_inc(x_399); -if (lean_is_exclusive(x_392)) { - lean_ctor_release(x_392, 0); - lean_ctor_release(x_392, 1); - lean_ctor_release(x_392, 2); - lean_ctor_release(x_392, 3); - lean_ctor_release(x_392, 4); - lean_ctor_release(x_392, 5); - x_400 = x_392; -} else { - lean_dec_ref(x_392); - x_400 = lean_box(0); -} -x_401 = lean_ctor_get(x_393, 0); -lean_inc(x_401); -x_402 = lean_ctor_get(x_393, 1); -lean_inc(x_402); -x_403 = lean_ctor_get(x_393, 3); -lean_inc(x_403); -if (lean_is_exclusive(x_393)) { - lean_ctor_release(x_393, 0); - lean_ctor_release(x_393, 1); - lean_ctor_release(x_393, 2); - lean_ctor_release(x_393, 3); - x_404 = x_393; -} else { - lean_dec_ref(x_393); - x_404 = lean_box(0); -} -if (lean_is_scalar(x_404)) { - x_405 = lean_alloc_ctor(0, 4, 0); -} else { - x_405 = x_404; -} -lean_ctor_set(x_405, 0, x_401); -lean_ctor_set(x_405, 1, x_402); -lean_ctor_set(x_405, 2, x_388); -lean_ctor_set(x_405, 3, x_403); -if (lean_is_scalar(x_400)) { - x_406 = lean_alloc_ctor(0, 6, 0); -} else { - x_406 = x_400; -} -lean_ctor_set(x_406, 0, x_395); -lean_ctor_set(x_406, 1, x_396); -lean_ctor_set(x_406, 2, x_405); -lean_ctor_set(x_406, 3, x_397); -lean_ctor_set(x_406, 4, x_398); -lean_ctor_set(x_406, 5, x_399); -if (lean_is_scalar(x_239)) { - x_407 = lean_alloc_ctor(1, 2, 0); -} else { - x_407 = x_239; - lean_ctor_set_tag(x_407, 1); -} -lean_ctor_set(x_407, 0, x_394); -lean_ctor_set(x_407, 1, x_406); -return x_407; -} -else -{ -lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_object* x_412; lean_object* x_413; lean_object* x_414; lean_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; -x_408 = lean_ctor_get(x_392, 2); -lean_inc(x_408); -x_409 = lean_ctor_get(x_391, 0); -lean_inc(x_409); -lean_dec(x_391); -x_410 = lean_ctor_get(x_392, 0); -lean_inc(x_410); -x_411 = lean_ctor_get(x_392, 1); +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; lean_object* x_426; +x_411 = lean_ctor_get(x_410, 2); lean_inc(x_411); -x_412 = lean_ctor_get(x_392, 3); +x_412 = lean_ctor_get(x_409, 0); lean_inc(x_412); -x_413 = lean_ctor_get(x_392, 4); +lean_dec(x_409); +x_413 = lean_ctor_get(x_410, 0); lean_inc(x_413); -x_414 = lean_ctor_get(x_392, 5); +x_414 = lean_ctor_get(x_410, 1); lean_inc(x_414); -if (lean_is_exclusive(x_392)) { - lean_ctor_release(x_392, 0); - lean_ctor_release(x_392, 1); - lean_ctor_release(x_392, 2); - lean_ctor_release(x_392, 3); - lean_ctor_release(x_392, 4); - lean_ctor_release(x_392, 5); - x_415 = x_392; -} else { - lean_dec_ref(x_392); - x_415 = lean_box(0); -} -x_416 = lean_ctor_get(x_408, 0); +x_415 = lean_ctor_get(x_410, 3); +lean_inc(x_415); +x_416 = lean_ctor_get(x_410, 4); lean_inc(x_416); -x_417 = lean_ctor_get(x_408, 1); +x_417 = lean_ctor_get(x_410, 5); lean_inc(x_417); -x_418 = lean_ctor_get(x_408, 3); -lean_inc(x_418); -if (lean_is_exclusive(x_408)) { - lean_ctor_release(x_408, 0); - lean_ctor_release(x_408, 1); - lean_ctor_release(x_408, 2); - lean_ctor_release(x_408, 3); - x_419 = x_408; +if (lean_is_exclusive(x_410)) { + lean_ctor_release(x_410, 0); + lean_ctor_release(x_410, 1); + lean_ctor_release(x_410, 2); + lean_ctor_release(x_410, 3); + lean_ctor_release(x_410, 4); + lean_ctor_release(x_410, 5); + x_418 = x_410; } else { - lean_dec_ref(x_408); - x_419 = lean_box(0); + lean_dec_ref(x_410); + x_418 = lean_box(0); } -if (lean_is_scalar(x_419)) { - x_420 = lean_alloc_ctor(0, 4, 0); +x_419 = lean_ctor_get(x_411, 0); +lean_inc(x_419); +x_420 = lean_ctor_get(x_411, 1); +lean_inc(x_420); +x_421 = lean_ctor_get(x_411, 3); +lean_inc(x_421); +x_422 = lean_ctor_get(x_411, 4); +lean_inc(x_422); +if (lean_is_exclusive(x_411)) { + lean_ctor_release(x_411, 0); + lean_ctor_release(x_411, 1); + lean_ctor_release(x_411, 2); + lean_ctor_release(x_411, 3); + lean_ctor_release(x_411, 4); + x_423 = x_411; } else { - x_420 = x_419; + lean_dec_ref(x_411); + x_423 = lean_box(0); } -lean_ctor_set(x_420, 0, x_416); -lean_ctor_set(x_420, 1, x_417); -lean_ctor_set(x_420, 2, x_388); -lean_ctor_set(x_420, 3, x_418); -if (lean_is_scalar(x_415)) { - x_421 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_423)) { + x_424 = lean_alloc_ctor(0, 5, 0); } else { - x_421 = x_415; + x_424 = x_423; } -lean_ctor_set(x_421, 0, x_410); -lean_ctor_set(x_421, 1, x_411); -lean_ctor_set(x_421, 2, x_420); -lean_ctor_set(x_421, 3, x_412); -lean_ctor_set(x_421, 4, x_413); -lean_ctor_set(x_421, 5, x_414); -if (lean_is_scalar(x_239)) { - x_422 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_424, 0, x_419); +lean_ctor_set(x_424, 1, x_420); +lean_ctor_set(x_424, 2, x_405); +lean_ctor_set(x_424, 3, x_421); +lean_ctor_set(x_424, 4, x_422); +if (lean_is_scalar(x_418)) { + x_425 = lean_alloc_ctor(0, 6, 0); } else { - x_422 = x_239; + x_425 = x_418; } -lean_ctor_set(x_422, 0, x_409); -lean_ctor_set(x_422, 1, x_421); -return x_422; +lean_ctor_set(x_425, 0, x_413); +lean_ctor_set(x_425, 1, x_414); +lean_ctor_set(x_425, 2, x_424); +lean_ctor_set(x_425, 3, x_415); +lean_ctor_set(x_425, 4, x_416); +lean_ctor_set(x_425, 5, x_417); +if (lean_is_scalar(x_249)) { + x_426 = lean_alloc_ctor(1, 2, 0); +} else { + x_426 = x_249; + lean_ctor_set_tag(x_426, 1); +} +lean_ctor_set(x_426, 0, x_412); +lean_ctor_set(x_426, 1, x_425); +return x_426; +} +else +{ +lean_object* x_427; 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; +x_427 = lean_ctor_get(x_410, 2); +lean_inc(x_427); +x_428 = lean_ctor_get(x_409, 0); +lean_inc(x_428); +lean_dec(x_409); +x_429 = lean_ctor_get(x_410, 0); +lean_inc(x_429); +x_430 = lean_ctor_get(x_410, 1); +lean_inc(x_430); +x_431 = lean_ctor_get(x_410, 3); +lean_inc(x_431); +x_432 = lean_ctor_get(x_410, 4); +lean_inc(x_432); +x_433 = lean_ctor_get(x_410, 5); +lean_inc(x_433); +if (lean_is_exclusive(x_410)) { + lean_ctor_release(x_410, 0); + lean_ctor_release(x_410, 1); + lean_ctor_release(x_410, 2); + lean_ctor_release(x_410, 3); + lean_ctor_release(x_410, 4); + lean_ctor_release(x_410, 5); + x_434 = x_410; +} else { + lean_dec_ref(x_410); + x_434 = lean_box(0); +} +x_435 = lean_ctor_get(x_427, 0); +lean_inc(x_435); +x_436 = lean_ctor_get(x_427, 1); +lean_inc(x_436); +x_437 = lean_ctor_get(x_427, 3); +lean_inc(x_437); +x_438 = lean_ctor_get(x_427, 4); +lean_inc(x_438); +if (lean_is_exclusive(x_427)) { + lean_ctor_release(x_427, 0); + lean_ctor_release(x_427, 1); + lean_ctor_release(x_427, 2); + lean_ctor_release(x_427, 3); + lean_ctor_release(x_427, 4); + x_439 = x_427; +} else { + lean_dec_ref(x_427); + x_439 = lean_box(0); +} +if (lean_is_scalar(x_439)) { + x_440 = lean_alloc_ctor(0, 5, 0); +} else { + x_440 = x_439; +} +lean_ctor_set(x_440, 0, x_435); +lean_ctor_set(x_440, 1, x_436); +lean_ctor_set(x_440, 2, x_405); +lean_ctor_set(x_440, 3, x_437); +lean_ctor_set(x_440, 4, x_438); +if (lean_is_scalar(x_434)) { + x_441 = lean_alloc_ctor(0, 6, 0); +} else { + x_441 = x_434; +} +lean_ctor_set(x_441, 0, x_429); +lean_ctor_set(x_441, 1, x_430); +lean_ctor_set(x_441, 2, x_440); +lean_ctor_set(x_441, 3, x_431); +lean_ctor_set(x_441, 4, x_432); +lean_ctor_set(x_441, 5, x_433); +if (lean_is_scalar(x_249)) { + x_442 = lean_alloc_ctor(0, 2, 0); +} else { + x_442 = x_249; +} +lean_ctor_set(x_442, 0, x_428); +lean_ctor_set(x_442, 1, x_441); +return x_442; } } } @@ -12252,29 +12326,29 @@ return x_422; } else { -uint8_t x_443; +uint8_t x_463; lean_dec(x_15); lean_dec(x_6); lean_dec(x_5); lean_dec(x_3); lean_dec(x_2); -x_443 = !lean_is_exclusive(x_232); -if (x_443 == 0) +x_463 = !lean_is_exclusive(x_242); +if (x_463 == 0) { -return x_232; +return x_242; } else { -lean_object* x_444; lean_object* x_445; lean_object* x_446; -x_444 = lean_ctor_get(x_232, 0); -x_445 = lean_ctor_get(x_232, 1); -lean_inc(x_445); -lean_inc(x_444); -lean_dec(x_232); -x_446 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_446, 0, x_444); -lean_ctor_set(x_446, 1, x_445); -return x_446; +lean_object* x_464; lean_object* x_465; lean_object* x_466; +x_464 = lean_ctor_get(x_242, 0); +x_465 = lean_ctor_get(x_242, 1); +lean_inc(x_465); +lean_inc(x_464); +lean_dec(x_242); +x_466 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_466, 0, x_464); +lean_ctor_set(x_466, 1, x_465); +return x_466; } } } @@ -12282,58 +12356,58 @@ return x_446; } else { -uint8_t x_447; +uint8_t x_467; lean_dec(x_19); lean_dec(x_15); lean_dec(x_6); lean_dec(x_5); lean_dec(x_3); lean_dec(x_2); -x_447 = !lean_is_exclusive(x_20); -if (x_447 == 0) +x_467 = !lean_is_exclusive(x_20); +if (x_467 == 0) { return x_20; } else { -lean_object* x_448; lean_object* x_449; lean_object* x_450; -x_448 = lean_ctor_get(x_20, 0); -x_449 = lean_ctor_get(x_20, 1); -lean_inc(x_449); -lean_inc(x_448); +lean_object* x_468; lean_object* x_469; lean_object* x_470; +x_468 = lean_ctor_get(x_20, 0); +x_469 = lean_ctor_get(x_20, 1); +lean_inc(x_469); +lean_inc(x_468); lean_dec(x_20); -x_450 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_450, 0, x_448); -lean_ctor_set(x_450, 1, x_449); -return x_450; +x_470 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_470, 0, x_468); +lean_ctor_set(x_470, 1, x_469); +return x_470; } } } else { -uint8_t x_451; +uint8_t x_471; lean_dec(x_15); lean_dec(x_6); lean_dec(x_5); lean_dec(x_3); lean_dec(x_2); -x_451 = !lean_is_exclusive(x_16); -if (x_451 == 0) +x_471 = !lean_is_exclusive(x_16); +if (x_471 == 0) { return x_16; } else { -lean_object* x_452; lean_object* x_453; lean_object* x_454; -x_452 = lean_ctor_get(x_16, 0); -x_453 = lean_ctor_get(x_16, 1); -lean_inc(x_453); -lean_inc(x_452); +lean_object* x_472; lean_object* x_473; lean_object* x_474; +x_472 = lean_ctor_get(x_16, 0); +x_473 = lean_ctor_get(x_16, 1); +lean_inc(x_473); +lean_inc(x_472); lean_dec(x_16); -x_454 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_454, 0, x_452); -lean_ctor_set(x_454, 1, x_453); -return x_454; +x_474 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_474, 0, x_472); +lean_ctor_set(x_474, 1, x_473); +return x_474; } } } @@ -12478,105 +12552,105 @@ x_37 = lean_ctor_get(x_31, 2); x_38 = !lean_is_exclusive(x_37); if (x_38 == 0) { -lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_91; uint8_t x_92; +lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_95; uint8_t x_96; x_39 = lean_ctor_get(x_37, 2); -x_91 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_37, 2, x_91); -x_92 = !lean_is_exclusive(x_12); -if (x_92 == 0) +x_95 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_37, 2, x_95); +x_96 = !lean_is_exclusive(x_12); +if (x_96 == 0) { -lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; -x_93 = lean_ctor_get(x_12, 2); -x_94 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_94, 0, x_33); -lean_ctor_set(x_94, 1, x_20); -x_95 = lean_array_push(x_93, x_94); -lean_ctor_set(x_12, 2, x_95); -x_96 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_30__replaceIndFVarsWithConsts___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_35, x_12, x_31); -if (lean_obj_tag(x_96) == 0) +lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; +x_97 = lean_ctor_get(x_12, 2); +x_98 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_98, 0, x_33); +lean_ctor_set(x_98, 1, x_20); +x_99 = lean_array_push(x_97, x_98); +lean_ctor_set(x_12, 2, x_99); +x_100 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_30__replaceIndFVarsWithConsts___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_35, x_12, x_31); +if (lean_obj_tag(x_100) == 0) { -lean_object* x_97; lean_object* x_98; lean_object* x_99; -x_97 = lean_ctor_get(x_96, 0); -lean_inc(x_97); -x_98 = lean_ctor_get(x_96, 1); -lean_inc(x_98); -lean_dec(x_96); -x_99 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_99, 0, x_97); -x_40 = x_99; -x_41 = x_98; -goto block_90; -} -else -{ -lean_object* x_100; lean_object* x_101; lean_object* x_102; -x_100 = lean_ctor_get(x_96, 0); -lean_inc(x_100); -x_101 = lean_ctor_get(x_96, 1); +lean_object* x_101; lean_object* x_102; lean_object* x_103; +x_101 = lean_ctor_get(x_100, 0); lean_inc(x_101); -lean_dec(x_96); -x_102 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_102, 0, x_100); -x_40 = x_102; -x_41 = x_101; -goto block_90; -} +x_102 = lean_ctor_get(x_100, 1); +lean_inc(x_102); +lean_dec(x_100); +x_103 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_103, 0, x_101); +x_40 = x_103; +x_41 = x_102; +goto block_94; } else { -lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; -x_103 = lean_ctor_get(x_12, 0); -x_104 = lean_ctor_get(x_12, 1); -x_105 = lean_ctor_get(x_12, 2); -x_106 = lean_ctor_get(x_12, 3); -x_107 = lean_ctor_get(x_12, 4); -lean_inc(x_107); -lean_inc(x_106); -lean_inc(x_105); +lean_object* x_104; lean_object* x_105; lean_object* x_106; +x_104 = lean_ctor_get(x_100, 0); lean_inc(x_104); -lean_inc(x_103); -lean_dec(x_12); -x_108 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_108, 0, x_33); -lean_ctor_set(x_108, 1, x_20); -x_109 = lean_array_push(x_105, x_108); -x_110 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_110, 0, x_103); -lean_ctor_set(x_110, 1, x_104); -lean_ctor_set(x_110, 2, x_109); -lean_ctor_set(x_110, 3, x_106); -lean_ctor_set(x_110, 4, x_107); -x_111 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_30__replaceIndFVarsWithConsts___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_35, x_110, x_31); -if (lean_obj_tag(x_111) == 0) -{ -lean_object* x_112; lean_object* x_113; lean_object* x_114; -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_alloc_ctor(1, 1, 0); -lean_ctor_set(x_114, 0, x_112); -x_40 = x_114; -x_41 = x_113; -goto block_90; +x_105 = lean_ctor_get(x_100, 1); +lean_inc(x_105); +lean_dec(x_100); +x_106 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_106, 0, x_104); +x_40 = x_106; +x_41 = x_105; +goto block_94; +} } else { -lean_object* x_115; lean_object* x_116; lean_object* x_117; -x_115 = lean_ctor_get(x_111, 0); -lean_inc(x_115); -x_116 = lean_ctor_get(x_111, 1); +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; +x_107 = lean_ctor_get(x_12, 0); +x_108 = lean_ctor_get(x_12, 1); +x_109 = lean_ctor_get(x_12, 2); +x_110 = lean_ctor_get(x_12, 3); +x_111 = lean_ctor_get(x_12, 4); +lean_inc(x_111); +lean_inc(x_110); +lean_inc(x_109); +lean_inc(x_108); +lean_inc(x_107); +lean_dec(x_12); +x_112 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_112, 0, x_33); +lean_ctor_set(x_112, 1, x_20); +x_113 = lean_array_push(x_109, x_112); +x_114 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_114, 0, x_107); +lean_ctor_set(x_114, 1, x_108); +lean_ctor_set(x_114, 2, x_113); +lean_ctor_set(x_114, 3, x_110); +lean_ctor_set(x_114, 4, x_111); +x_115 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_30__replaceIndFVarsWithConsts___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_35, x_114, x_31); +if (lean_obj_tag(x_115) == 0) +{ +lean_object* x_116; lean_object* x_117; lean_object* x_118; +x_116 = lean_ctor_get(x_115, 0); lean_inc(x_116); -lean_dec(x_111); -x_117 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_117, 0, x_115); -x_40 = x_117; -x_41 = x_116; -goto block_90; +x_117 = lean_ctor_get(x_115, 1); +lean_inc(x_117); +lean_dec(x_115); +x_118 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_118, 0, x_116); +x_40 = x_118; +x_41 = x_117; +goto block_94; +} +else +{ +lean_object* x_119; lean_object* x_120; lean_object* x_121; +x_119 = lean_ctor_get(x_115, 0); +lean_inc(x_119); +x_120 = lean_ctor_get(x_115, 1); +lean_inc(x_120); +lean_dec(x_115); +x_121 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_121, 0, x_119); +x_40 = x_121; +x_41 = x_120; +goto block_94; } } -block_90: +block_94: { if (lean_obj_tag(x_40) == 0) { @@ -12611,1284 +12685,1262 @@ return x_48; } else { -lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; +lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; x_49 = lean_ctor_get(x_42, 0); x_50 = lean_ctor_get(x_42, 1); x_51 = lean_ctor_get(x_42, 3); +x_52 = lean_ctor_get(x_42, 4); +lean_inc(x_52); lean_inc(x_51); lean_inc(x_50); lean_inc(x_49); lean_dec(x_42); -x_52 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_52, 0, x_49); -lean_ctor_set(x_52, 1, x_50); -lean_ctor_set(x_52, 2, x_39); -lean_ctor_set(x_52, 3, x_51); -lean_ctor_set(x_41, 2, x_52); +x_53 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_53, 0, x_49); +lean_ctor_set(x_53, 1, x_50); +lean_ctor_set(x_53, 2, x_39); +lean_ctor_set(x_53, 3, x_51); +lean_ctor_set(x_53, 4, x_52); +lean_ctor_set(x_41, 2, x_53); if (lean_is_scalar(x_32)) { - x_53 = lean_alloc_ctor(1, 2, 0); + x_54 = lean_alloc_ctor(1, 2, 0); } else { - x_53 = x_32; - lean_ctor_set_tag(x_53, 1); + x_54 = x_32; + lean_ctor_set_tag(x_54, 1); } -lean_ctor_set(x_53, 0, x_43); -lean_ctor_set(x_53, 1, x_41); -return x_53; +lean_ctor_set(x_54, 0, x_43); +lean_ctor_set(x_54, 1, x_41); +return x_54; } } else { -lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; -x_54 = lean_ctor_get(x_41, 0); -x_55 = lean_ctor_get(x_41, 1); -x_56 = lean_ctor_get(x_41, 3); -x_57 = lean_ctor_get(x_41, 4); -x_58 = lean_ctor_get(x_41, 5); +lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; +x_55 = lean_ctor_get(x_41, 0); +x_56 = lean_ctor_get(x_41, 1); +x_57 = lean_ctor_get(x_41, 3); +x_58 = lean_ctor_get(x_41, 4); +x_59 = lean_ctor_get(x_41, 5); +lean_inc(x_59); lean_inc(x_58); lean_inc(x_57); lean_inc(x_56); lean_inc(x_55); -lean_inc(x_54); lean_dec(x_41); -x_59 = lean_ctor_get(x_42, 0); -lean_inc(x_59); -x_60 = lean_ctor_get(x_42, 1); +x_60 = lean_ctor_get(x_42, 0); lean_inc(x_60); -x_61 = lean_ctor_get(x_42, 3); +x_61 = lean_ctor_get(x_42, 1); lean_inc(x_61); +x_62 = lean_ctor_get(x_42, 3); +lean_inc(x_62); +x_63 = lean_ctor_get(x_42, 4); +lean_inc(x_63); if (lean_is_exclusive(x_42)) { lean_ctor_release(x_42, 0); lean_ctor_release(x_42, 1); lean_ctor_release(x_42, 2); lean_ctor_release(x_42, 3); - x_62 = x_42; + lean_ctor_release(x_42, 4); + x_64 = x_42; } else { lean_dec_ref(x_42); - x_62 = lean_box(0); + x_64 = lean_box(0); } -if (lean_is_scalar(x_62)) { - x_63 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_64)) { + x_65 = lean_alloc_ctor(0, 5, 0); } else { - x_63 = x_62; + x_65 = x_64; } -lean_ctor_set(x_63, 0, x_59); -lean_ctor_set(x_63, 1, x_60); -lean_ctor_set(x_63, 2, x_39); -lean_ctor_set(x_63, 3, x_61); -x_64 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_64, 0, x_54); -lean_ctor_set(x_64, 1, x_55); -lean_ctor_set(x_64, 2, x_63); -lean_ctor_set(x_64, 3, x_56); -lean_ctor_set(x_64, 4, x_57); -lean_ctor_set(x_64, 5, x_58); +lean_ctor_set(x_65, 0, x_60); +lean_ctor_set(x_65, 1, x_61); +lean_ctor_set(x_65, 2, x_39); +lean_ctor_set(x_65, 3, x_62); +lean_ctor_set(x_65, 4, x_63); +x_66 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_66, 0, x_55); +lean_ctor_set(x_66, 1, x_56); +lean_ctor_set(x_66, 2, x_65); +lean_ctor_set(x_66, 3, x_57); +lean_ctor_set(x_66, 4, x_58); +lean_ctor_set(x_66, 5, x_59); if (lean_is_scalar(x_32)) { - x_65 = lean_alloc_ctor(1, 2, 0); + x_67 = lean_alloc_ctor(1, 2, 0); } else { - x_65 = x_32; - lean_ctor_set_tag(x_65, 1); + x_67 = x_32; + lean_ctor_set_tag(x_67, 1); } -lean_ctor_set(x_65, 0, x_43); -lean_ctor_set(x_65, 1, x_64); -return x_65; +lean_ctor_set(x_67, 0, x_43); +lean_ctor_set(x_67, 1, x_66); +return x_67; } } else { -lean_object* x_66; lean_object* x_67; uint8_t x_68; -x_66 = lean_ctor_get(x_41, 2); -lean_inc(x_66); -x_67 = lean_ctor_get(x_40, 0); -lean_inc(x_67); +lean_object* x_68; lean_object* x_69; uint8_t x_70; +x_68 = lean_ctor_get(x_41, 2); +lean_inc(x_68); +x_69 = lean_ctor_get(x_40, 0); +lean_inc(x_69); lean_dec(x_40); -x_68 = !lean_is_exclusive(x_41); -if (x_68 == 0) -{ -lean_object* x_69; uint8_t x_70; -x_69 = lean_ctor_get(x_41, 2); -lean_dec(x_69); -x_70 = !lean_is_exclusive(x_66); +x_70 = !lean_is_exclusive(x_41); if (x_70 == 0) { -lean_object* x_71; lean_object* x_72; -x_71 = lean_ctor_get(x_66, 2); +lean_object* x_71; uint8_t x_72; +x_71 = lean_ctor_get(x_41, 2); lean_dec(x_71); -lean_ctor_set(x_66, 2, x_39); +x_72 = !lean_is_exclusive(x_68); +if (x_72 == 0) +{ +lean_object* x_73; lean_object* x_74; +x_73 = lean_ctor_get(x_68, 2); +lean_dec(x_73); +lean_ctor_set(x_68, 2, x_39); if (lean_is_scalar(x_32)) { - x_72 = lean_alloc_ctor(0, 2, 0); + x_74 = lean_alloc_ctor(0, 2, 0); } else { - x_72 = x_32; + x_74 = x_32; } -lean_ctor_set(x_72, 0, x_67); -lean_ctor_set(x_72, 1, x_41); -return x_72; +lean_ctor_set(x_74, 0, x_69); +lean_ctor_set(x_74, 1, x_41); +return x_74; } else { -lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; -x_73 = lean_ctor_get(x_66, 0); -x_74 = lean_ctor_get(x_66, 1); -x_75 = lean_ctor_get(x_66, 3); +lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; +x_75 = lean_ctor_get(x_68, 0); +x_76 = lean_ctor_get(x_68, 1); +x_77 = lean_ctor_get(x_68, 3); +x_78 = lean_ctor_get(x_68, 4); +lean_inc(x_78); +lean_inc(x_77); +lean_inc(x_76); lean_inc(x_75); -lean_inc(x_74); -lean_inc(x_73); -lean_dec(x_66); -x_76 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_76, 0, x_73); -lean_ctor_set(x_76, 1, x_74); -lean_ctor_set(x_76, 2, x_39); -lean_ctor_set(x_76, 3, x_75); -lean_ctor_set(x_41, 2, x_76); +lean_dec(x_68); +x_79 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_79, 0, x_75); +lean_ctor_set(x_79, 1, x_76); +lean_ctor_set(x_79, 2, x_39); +lean_ctor_set(x_79, 3, x_77); +lean_ctor_set(x_79, 4, x_78); +lean_ctor_set(x_41, 2, x_79); if (lean_is_scalar(x_32)) { - x_77 = lean_alloc_ctor(0, 2, 0); + x_80 = lean_alloc_ctor(0, 2, 0); } else { - x_77 = x_32; + x_80 = x_32; } -lean_ctor_set(x_77, 0, x_67); -lean_ctor_set(x_77, 1, x_41); -return x_77; +lean_ctor_set(x_80, 0, x_69); +lean_ctor_set(x_80, 1, x_41); +return x_80; } } else { -lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; -x_78 = lean_ctor_get(x_41, 0); -x_79 = lean_ctor_get(x_41, 1); -x_80 = lean_ctor_get(x_41, 3); -x_81 = lean_ctor_get(x_41, 4); -x_82 = lean_ctor_get(x_41, 5); +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; +x_81 = lean_ctor_get(x_41, 0); +x_82 = lean_ctor_get(x_41, 1); +x_83 = lean_ctor_get(x_41, 3); +x_84 = lean_ctor_get(x_41, 4); +x_85 = lean_ctor_get(x_41, 5); +lean_inc(x_85); +lean_inc(x_84); +lean_inc(x_83); lean_inc(x_82); lean_inc(x_81); -lean_inc(x_80); -lean_inc(x_79); -lean_inc(x_78); lean_dec(x_41); -x_83 = lean_ctor_get(x_66, 0); -lean_inc(x_83); -x_84 = lean_ctor_get(x_66, 1); -lean_inc(x_84); -x_85 = lean_ctor_get(x_66, 3); -lean_inc(x_85); -if (lean_is_exclusive(x_66)) { - lean_ctor_release(x_66, 0); - lean_ctor_release(x_66, 1); - lean_ctor_release(x_66, 2); - lean_ctor_release(x_66, 3); - x_86 = x_66; +x_86 = lean_ctor_get(x_68, 0); +lean_inc(x_86); +x_87 = lean_ctor_get(x_68, 1); +lean_inc(x_87); +x_88 = lean_ctor_get(x_68, 3); +lean_inc(x_88); +x_89 = lean_ctor_get(x_68, 4); +lean_inc(x_89); +if (lean_is_exclusive(x_68)) { + lean_ctor_release(x_68, 0); + lean_ctor_release(x_68, 1); + lean_ctor_release(x_68, 2); + lean_ctor_release(x_68, 3); + lean_ctor_release(x_68, 4); + x_90 = x_68; } else { - lean_dec_ref(x_66); - x_86 = lean_box(0); + lean_dec_ref(x_68); + x_90 = lean_box(0); } -if (lean_is_scalar(x_86)) { - x_87 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_90)) { + x_91 = lean_alloc_ctor(0, 5, 0); } else { - x_87 = x_86; + x_91 = x_90; } -lean_ctor_set(x_87, 0, x_83); -lean_ctor_set(x_87, 1, x_84); -lean_ctor_set(x_87, 2, x_39); -lean_ctor_set(x_87, 3, x_85); -x_88 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_88, 0, x_78); -lean_ctor_set(x_88, 1, x_79); -lean_ctor_set(x_88, 2, x_87); -lean_ctor_set(x_88, 3, x_80); -lean_ctor_set(x_88, 4, x_81); -lean_ctor_set(x_88, 5, x_82); +lean_ctor_set(x_91, 0, x_86); +lean_ctor_set(x_91, 1, x_87); +lean_ctor_set(x_91, 2, x_39); +lean_ctor_set(x_91, 3, x_88); +lean_ctor_set(x_91, 4, x_89); +x_92 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_92, 0, x_81); +lean_ctor_set(x_92, 1, x_82); +lean_ctor_set(x_92, 2, x_91); +lean_ctor_set(x_92, 3, x_83); +lean_ctor_set(x_92, 4, x_84); +lean_ctor_set(x_92, 5, x_85); if (lean_is_scalar(x_32)) { - x_89 = lean_alloc_ctor(0, 2, 0); + x_93 = lean_alloc_ctor(0, 2, 0); } else { - x_89 = x_32; + x_93 = x_32; } -lean_ctor_set(x_89, 0, x_67); -lean_ctor_set(x_89, 1, x_88); -return x_89; +lean_ctor_set(x_93, 0, x_69); +lean_ctor_set(x_93, 1, x_92); +return x_93; } } } } else { -lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_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; -x_118 = lean_ctor_get(x_37, 0); -x_119 = lean_ctor_get(x_37, 1); -x_120 = lean_ctor_get(x_37, 2); -x_121 = lean_ctor_get(x_37, 3); -lean_inc(x_121); -lean_inc(x_120); -lean_inc(x_119); -lean_inc(x_118); -lean_dec(x_37); -x_155 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_156 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_156, 0, x_118); -lean_ctor_set(x_156, 1, x_119); -lean_ctor_set(x_156, 2, x_155); -lean_ctor_set(x_156, 3, x_121); -lean_ctor_set(x_31, 2, x_156); -x_157 = lean_ctor_get(x_12, 0); -lean_inc(x_157); -x_158 = lean_ctor_get(x_12, 1); -lean_inc(x_158); -x_159 = lean_ctor_get(x_12, 2); -lean_inc(x_159); -x_160 = lean_ctor_get(x_12, 3); -lean_inc(x_160); -x_161 = lean_ctor_get(x_12, 4); -lean_inc(x_161); -if (lean_is_exclusive(x_12)) { - lean_ctor_release(x_12, 0); - lean_ctor_release(x_12, 1); - lean_ctor_release(x_12, 2); - lean_ctor_release(x_12, 3); - lean_ctor_release(x_12, 4); - x_162 = x_12; -} else { - lean_dec_ref(x_12); - x_162 = lean_box(0); -} -x_163 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_163, 0, x_33); -lean_ctor_set(x_163, 1, x_20); -x_164 = lean_array_push(x_159, x_163); -if (lean_is_scalar(x_162)) { - x_165 = lean_alloc_ctor(0, 5, 0); -} else { - x_165 = x_162; -} -lean_ctor_set(x_165, 0, x_157); -lean_ctor_set(x_165, 1, x_158); -lean_ctor_set(x_165, 2, x_164); -lean_ctor_set(x_165, 3, x_160); -lean_ctor_set(x_165, 4, x_161); -x_166 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_30__replaceIndFVarsWithConsts___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_35, x_165, x_31); -if (lean_obj_tag(x_166) == 0) -{ -lean_object* x_167; lean_object* x_168; lean_object* x_169; -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, 1, 0); -lean_ctor_set(x_169, 0, x_167); -x_122 = x_169; -x_123 = x_168; -goto block_154; -} -else -{ -lean_object* x_170; lean_object* x_171; lean_object* x_172; -x_170 = lean_ctor_get(x_166, 0); -lean_inc(x_170); -x_171 = lean_ctor_get(x_166, 1); -lean_inc(x_171); -lean_dec(x_166); -x_172 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_172, 0, x_170); -x_122 = x_172; -x_123 = x_171; -goto block_154; -} -block_154: -{ -if (lean_obj_tag(x_122) == 0) -{ -lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; -x_124 = lean_ctor_get(x_123, 2); -lean_inc(x_124); -x_125 = lean_ctor_get(x_122, 0); -lean_inc(x_125); -lean_dec(x_122); -x_126 = lean_ctor_get(x_123, 0); +lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; lean_object* x_173; +x_122 = lean_ctor_get(x_37, 0); +x_123 = lean_ctor_get(x_37, 1); +x_124 = lean_ctor_get(x_37, 2); +x_125 = lean_ctor_get(x_37, 3); +x_126 = lean_ctor_get(x_37, 4); lean_inc(x_126); -x_127 = lean_ctor_get(x_123, 1); -lean_inc(x_127); -x_128 = lean_ctor_get(x_123, 3); -lean_inc(x_128); -x_129 = lean_ctor_get(x_123, 4); -lean_inc(x_129); -x_130 = lean_ctor_get(x_123, 5); -lean_inc(x_130); -if (lean_is_exclusive(x_123)) { - lean_ctor_release(x_123, 0); - lean_ctor_release(x_123, 1); - lean_ctor_release(x_123, 2); - lean_ctor_release(x_123, 3); - lean_ctor_release(x_123, 4); - lean_ctor_release(x_123, 5); - x_131 = x_123; -} else { - lean_dec_ref(x_123); - x_131 = lean_box(0); -} -x_132 = lean_ctor_get(x_124, 0); -lean_inc(x_132); -x_133 = lean_ctor_get(x_124, 1); -lean_inc(x_133); -x_134 = lean_ctor_get(x_124, 3); -lean_inc(x_134); -if (lean_is_exclusive(x_124)) { - lean_ctor_release(x_124, 0); - lean_ctor_release(x_124, 1); - lean_ctor_release(x_124, 2); - lean_ctor_release(x_124, 3); - x_135 = x_124; -} else { - lean_dec_ref(x_124); - x_135 = lean_box(0); -} -if (lean_is_scalar(x_135)) { - x_136 = lean_alloc_ctor(0, 4, 0); -} else { - x_136 = x_135; -} -lean_ctor_set(x_136, 0, x_132); -lean_ctor_set(x_136, 1, x_133); -lean_ctor_set(x_136, 2, x_120); -lean_ctor_set(x_136, 3, x_134); -if (lean_is_scalar(x_131)) { - x_137 = lean_alloc_ctor(0, 6, 0); -} else { - x_137 = x_131; -} -lean_ctor_set(x_137, 0, x_126); -lean_ctor_set(x_137, 1, x_127); -lean_ctor_set(x_137, 2, x_136); -lean_ctor_set(x_137, 3, x_128); -lean_ctor_set(x_137, 4, x_129); -lean_ctor_set(x_137, 5, x_130); -if (lean_is_scalar(x_32)) { - x_138 = lean_alloc_ctor(1, 2, 0); -} else { - x_138 = x_32; - lean_ctor_set_tag(x_138, 1); -} -lean_ctor_set(x_138, 0, x_125); -lean_ctor_set(x_138, 1, x_137); -return x_138; -} -else -{ -lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_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; -x_139 = lean_ctor_get(x_123, 2); -lean_inc(x_139); -x_140 = lean_ctor_get(x_122, 0); -lean_inc(x_140); -lean_dec(x_122); -x_141 = lean_ctor_get(x_123, 0); -lean_inc(x_141); -x_142 = lean_ctor_get(x_123, 1); -lean_inc(x_142); -x_143 = lean_ctor_get(x_123, 3); -lean_inc(x_143); -x_144 = lean_ctor_get(x_123, 4); -lean_inc(x_144); -x_145 = lean_ctor_get(x_123, 5); -lean_inc(x_145); -if (lean_is_exclusive(x_123)) { - lean_ctor_release(x_123, 0); - lean_ctor_release(x_123, 1); - lean_ctor_release(x_123, 2); - lean_ctor_release(x_123, 3); - lean_ctor_release(x_123, 4); - lean_ctor_release(x_123, 5); - x_146 = x_123; -} else { - lean_dec_ref(x_123); - x_146 = lean_box(0); -} -x_147 = lean_ctor_get(x_139, 0); -lean_inc(x_147); -x_148 = lean_ctor_get(x_139, 1); -lean_inc(x_148); -x_149 = lean_ctor_get(x_139, 3); -lean_inc(x_149); -if (lean_is_exclusive(x_139)) { - lean_ctor_release(x_139, 0); - lean_ctor_release(x_139, 1); - lean_ctor_release(x_139, 2); - lean_ctor_release(x_139, 3); - x_150 = x_139; -} else { - lean_dec_ref(x_139); - x_150 = lean_box(0); -} -if (lean_is_scalar(x_150)) { - x_151 = lean_alloc_ctor(0, 4, 0); -} else { - x_151 = x_150; -} -lean_ctor_set(x_151, 0, x_147); -lean_ctor_set(x_151, 1, x_148); -lean_ctor_set(x_151, 2, x_120); -lean_ctor_set(x_151, 3, x_149); -if (lean_is_scalar(x_146)) { - x_152 = lean_alloc_ctor(0, 6, 0); -} else { - x_152 = x_146; -} -lean_ctor_set(x_152, 0, x_141); -lean_ctor_set(x_152, 1, x_142); -lean_ctor_set(x_152, 2, x_151); -lean_ctor_set(x_152, 3, x_143); -lean_ctor_set(x_152, 4, x_144); -lean_ctor_set(x_152, 5, x_145); -if (lean_is_scalar(x_32)) { - x_153 = lean_alloc_ctor(0, 2, 0); -} else { - x_153 = x_32; -} -lean_ctor_set(x_153, 0, x_140); -lean_ctor_set(x_153, 1, x_152); -return x_153; -} -} -} -} -else -{ -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; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; lean_object* x_224; lean_object* x_225; lean_object* x_226; lean_object* x_227; lean_object* x_228; lean_object* x_229; -x_173 = lean_ctor_get(x_31, 2); -x_174 = lean_ctor_get(x_31, 0); -x_175 = lean_ctor_get(x_31, 1); -x_176 = lean_ctor_get(x_31, 3); -x_177 = lean_ctor_get(x_31, 4); -x_178 = lean_ctor_get(x_31, 5); -lean_inc(x_178); -lean_inc(x_177); -lean_inc(x_176); -lean_inc(x_173); -lean_inc(x_175); -lean_inc(x_174); -lean_dec(x_31); -x_179 = lean_ctor_get(x_173, 0); -lean_inc(x_179); -x_180 = lean_ctor_get(x_173, 1); -lean_inc(x_180); -x_181 = lean_ctor_get(x_173, 2); -lean_inc(x_181); -x_182 = lean_ctor_get(x_173, 3); -lean_inc(x_182); -if (lean_is_exclusive(x_173)) { - lean_ctor_release(x_173, 0); - lean_ctor_release(x_173, 1); - lean_ctor_release(x_173, 2); - lean_ctor_release(x_173, 3); - x_183 = x_173; -} else { - lean_dec_ref(x_173); - x_183 = lean_box(0); -} -x_217 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_183)) { - x_218 = lean_alloc_ctor(0, 4, 0); -} else { - x_218 = x_183; -} -lean_ctor_set(x_218, 0, x_179); -lean_ctor_set(x_218, 1, x_180); -lean_ctor_set(x_218, 2, x_217); -lean_ctor_set(x_218, 3, x_182); -x_219 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_219, 0, x_174); -lean_ctor_set(x_219, 1, x_175); -lean_ctor_set(x_219, 2, x_218); -lean_ctor_set(x_219, 3, x_176); -lean_ctor_set(x_219, 4, x_177); -lean_ctor_set(x_219, 5, x_178); -x_220 = lean_ctor_get(x_12, 0); -lean_inc(x_220); -x_221 = lean_ctor_get(x_12, 1); -lean_inc(x_221); -x_222 = lean_ctor_get(x_12, 2); -lean_inc(x_222); -x_223 = lean_ctor_get(x_12, 3); -lean_inc(x_223); -x_224 = lean_ctor_get(x_12, 4); -lean_inc(x_224); +lean_inc(x_125); +lean_inc(x_124); +lean_inc(x_123); +lean_inc(x_122); +lean_dec(x_37); +x_162 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_163 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_163, 0, x_122); +lean_ctor_set(x_163, 1, x_123); +lean_ctor_set(x_163, 2, x_162); +lean_ctor_set(x_163, 3, x_125); +lean_ctor_set(x_163, 4, x_126); +lean_ctor_set(x_31, 2, x_163); +x_164 = lean_ctor_get(x_12, 0); +lean_inc(x_164); +x_165 = lean_ctor_get(x_12, 1); +lean_inc(x_165); +x_166 = lean_ctor_get(x_12, 2); +lean_inc(x_166); +x_167 = lean_ctor_get(x_12, 3); +lean_inc(x_167); +x_168 = lean_ctor_get(x_12, 4); +lean_inc(x_168); if (lean_is_exclusive(x_12)) { lean_ctor_release(x_12, 0); lean_ctor_release(x_12, 1); lean_ctor_release(x_12, 2); lean_ctor_release(x_12, 3); lean_ctor_release(x_12, 4); - x_225 = x_12; + x_169 = x_12; } else { lean_dec_ref(x_12); - x_225 = lean_box(0); + x_169 = lean_box(0); } -x_226 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_226, 0, x_33); -lean_ctor_set(x_226, 1, x_20); -x_227 = lean_array_push(x_222, x_226); -if (lean_is_scalar(x_225)) { +x_170 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_170, 0, x_33); +lean_ctor_set(x_170, 1, x_20); +x_171 = lean_array_push(x_166, x_170); +if (lean_is_scalar(x_169)) { + x_172 = lean_alloc_ctor(0, 5, 0); +} else { + x_172 = x_169; +} +lean_ctor_set(x_172, 0, x_164); +lean_ctor_set(x_172, 1, x_165); +lean_ctor_set(x_172, 2, x_171); +lean_ctor_set(x_172, 3, x_167); +lean_ctor_set(x_172, 4, x_168); +x_173 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_30__replaceIndFVarsWithConsts___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_35, x_172, x_31); +if (lean_obj_tag(x_173) == 0) +{ +lean_object* x_174; lean_object* x_175; lean_object* x_176; +x_174 = lean_ctor_get(x_173, 0); +lean_inc(x_174); +x_175 = lean_ctor_get(x_173, 1); +lean_inc(x_175); +lean_dec(x_173); +x_176 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_176, 0, x_174); +x_127 = x_176; +x_128 = x_175; +goto block_161; +} +else +{ +lean_object* x_177; lean_object* x_178; lean_object* x_179; +x_177 = lean_ctor_get(x_173, 0); +lean_inc(x_177); +x_178 = lean_ctor_get(x_173, 1); +lean_inc(x_178); +lean_dec(x_173); +x_179 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_179, 0, x_177); +x_127 = x_179; +x_128 = x_178; +goto block_161; +} +block_161: +{ +if (lean_obj_tag(x_127) == 0) +{ +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; +x_129 = lean_ctor_get(x_128, 2); +lean_inc(x_129); +x_130 = lean_ctor_get(x_127, 0); +lean_inc(x_130); +lean_dec(x_127); +x_131 = lean_ctor_get(x_128, 0); +lean_inc(x_131); +x_132 = lean_ctor_get(x_128, 1); +lean_inc(x_132); +x_133 = lean_ctor_get(x_128, 3); +lean_inc(x_133); +x_134 = lean_ctor_get(x_128, 4); +lean_inc(x_134); +x_135 = lean_ctor_get(x_128, 5); +lean_inc(x_135); +if (lean_is_exclusive(x_128)) { + lean_ctor_release(x_128, 0); + lean_ctor_release(x_128, 1); + lean_ctor_release(x_128, 2); + lean_ctor_release(x_128, 3); + lean_ctor_release(x_128, 4); + lean_ctor_release(x_128, 5); + x_136 = x_128; +} else { + lean_dec_ref(x_128); + x_136 = lean_box(0); +} +x_137 = lean_ctor_get(x_129, 0); +lean_inc(x_137); +x_138 = lean_ctor_get(x_129, 1); +lean_inc(x_138); +x_139 = lean_ctor_get(x_129, 3); +lean_inc(x_139); +x_140 = lean_ctor_get(x_129, 4); +lean_inc(x_140); +if (lean_is_exclusive(x_129)) { + lean_ctor_release(x_129, 0); + lean_ctor_release(x_129, 1); + lean_ctor_release(x_129, 2); + lean_ctor_release(x_129, 3); + lean_ctor_release(x_129, 4); + x_141 = x_129; +} else { + lean_dec_ref(x_129); + x_141 = lean_box(0); +} +if (lean_is_scalar(x_141)) { + x_142 = lean_alloc_ctor(0, 5, 0); +} else { + x_142 = x_141; +} +lean_ctor_set(x_142, 0, x_137); +lean_ctor_set(x_142, 1, x_138); +lean_ctor_set(x_142, 2, x_124); +lean_ctor_set(x_142, 3, x_139); +lean_ctor_set(x_142, 4, x_140); +if (lean_is_scalar(x_136)) { + x_143 = lean_alloc_ctor(0, 6, 0); +} else { + x_143 = x_136; +} +lean_ctor_set(x_143, 0, x_131); +lean_ctor_set(x_143, 1, x_132); +lean_ctor_set(x_143, 2, x_142); +lean_ctor_set(x_143, 3, x_133); +lean_ctor_set(x_143, 4, x_134); +lean_ctor_set(x_143, 5, x_135); +if (lean_is_scalar(x_32)) { + x_144 = lean_alloc_ctor(1, 2, 0); +} else { + x_144 = x_32; + lean_ctor_set_tag(x_144, 1); +} +lean_ctor_set(x_144, 0, x_130); +lean_ctor_set(x_144, 1, x_143); +return x_144; +} +else +{ +lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_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; +x_145 = lean_ctor_get(x_128, 2); +lean_inc(x_145); +x_146 = lean_ctor_get(x_127, 0); +lean_inc(x_146); +lean_dec(x_127); +x_147 = lean_ctor_get(x_128, 0); +lean_inc(x_147); +x_148 = lean_ctor_get(x_128, 1); +lean_inc(x_148); +x_149 = lean_ctor_get(x_128, 3); +lean_inc(x_149); +x_150 = lean_ctor_get(x_128, 4); +lean_inc(x_150); +x_151 = lean_ctor_get(x_128, 5); +lean_inc(x_151); +if (lean_is_exclusive(x_128)) { + lean_ctor_release(x_128, 0); + lean_ctor_release(x_128, 1); + lean_ctor_release(x_128, 2); + lean_ctor_release(x_128, 3); + lean_ctor_release(x_128, 4); + lean_ctor_release(x_128, 5); + x_152 = x_128; +} else { + lean_dec_ref(x_128); + x_152 = lean_box(0); +} +x_153 = lean_ctor_get(x_145, 0); +lean_inc(x_153); +x_154 = lean_ctor_get(x_145, 1); +lean_inc(x_154); +x_155 = lean_ctor_get(x_145, 3); +lean_inc(x_155); +x_156 = lean_ctor_get(x_145, 4); +lean_inc(x_156); +if (lean_is_exclusive(x_145)) { + lean_ctor_release(x_145, 0); + lean_ctor_release(x_145, 1); + lean_ctor_release(x_145, 2); + lean_ctor_release(x_145, 3); + lean_ctor_release(x_145, 4); + x_157 = x_145; +} else { + lean_dec_ref(x_145); + x_157 = lean_box(0); +} +if (lean_is_scalar(x_157)) { + x_158 = lean_alloc_ctor(0, 5, 0); +} else { + x_158 = x_157; +} +lean_ctor_set(x_158, 0, x_153); +lean_ctor_set(x_158, 1, x_154); +lean_ctor_set(x_158, 2, x_124); +lean_ctor_set(x_158, 3, x_155); +lean_ctor_set(x_158, 4, x_156); +if (lean_is_scalar(x_152)) { + x_159 = lean_alloc_ctor(0, 6, 0); +} else { + x_159 = x_152; +} +lean_ctor_set(x_159, 0, x_147); +lean_ctor_set(x_159, 1, x_148); +lean_ctor_set(x_159, 2, x_158); +lean_ctor_set(x_159, 3, x_149); +lean_ctor_set(x_159, 4, x_150); +lean_ctor_set(x_159, 5, x_151); +if (lean_is_scalar(x_32)) { + x_160 = lean_alloc_ctor(0, 2, 0); +} else { + x_160 = x_32; +} +lean_ctor_set(x_160, 0, x_146); +lean_ctor_set(x_160, 1, x_159); +return x_160; +} +} +} +} +else +{ +lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; 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_227; lean_object* x_228; lean_object* x_229; lean_object* x_230; lean_object* x_231; lean_object* x_232; lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_object* x_236; lean_object* x_237; lean_object* x_238; lean_object* x_239; +x_180 = lean_ctor_get(x_31, 2); +x_181 = lean_ctor_get(x_31, 0); +x_182 = lean_ctor_get(x_31, 1); +x_183 = lean_ctor_get(x_31, 3); +x_184 = lean_ctor_get(x_31, 4); +x_185 = lean_ctor_get(x_31, 5); +lean_inc(x_185); +lean_inc(x_184); +lean_inc(x_183); +lean_inc(x_180); +lean_inc(x_182); +lean_inc(x_181); +lean_dec(x_31); +x_186 = lean_ctor_get(x_180, 0); +lean_inc(x_186); +x_187 = lean_ctor_get(x_180, 1); +lean_inc(x_187); +x_188 = lean_ctor_get(x_180, 2); +lean_inc(x_188); +x_189 = lean_ctor_get(x_180, 3); +lean_inc(x_189); +x_190 = lean_ctor_get(x_180, 4); +lean_inc(x_190); +if (lean_is_exclusive(x_180)) { + lean_ctor_release(x_180, 0); + lean_ctor_release(x_180, 1); + lean_ctor_release(x_180, 2); + lean_ctor_release(x_180, 3); + lean_ctor_release(x_180, 4); + x_191 = x_180; +} else { + lean_dec_ref(x_180); + x_191 = lean_box(0); +} +x_227 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_191)) { x_228 = lean_alloc_ctor(0, 5, 0); } else { - x_228 = x_225; + x_228 = x_191; } -lean_ctor_set(x_228, 0, x_220); -lean_ctor_set(x_228, 1, x_221); +lean_ctor_set(x_228, 0, x_186); +lean_ctor_set(x_228, 1, x_187); lean_ctor_set(x_228, 2, x_227); -lean_ctor_set(x_228, 3, x_223); -lean_ctor_set(x_228, 4, x_224); -x_229 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_30__replaceIndFVarsWithConsts___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_35, x_228, x_219); -if (lean_obj_tag(x_229) == 0) -{ -lean_object* x_230; lean_object* x_231; lean_object* x_232; -x_230 = lean_ctor_get(x_229, 0); +lean_ctor_set(x_228, 3, x_189); +lean_ctor_set(x_228, 4, x_190); +x_229 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_229, 0, x_181); +lean_ctor_set(x_229, 1, x_182); +lean_ctor_set(x_229, 2, x_228); +lean_ctor_set(x_229, 3, x_183); +lean_ctor_set(x_229, 4, x_184); +lean_ctor_set(x_229, 5, x_185); +x_230 = lean_ctor_get(x_12, 0); lean_inc(x_230); -x_231 = lean_ctor_get(x_229, 1); +x_231 = lean_ctor_get(x_12, 1); lean_inc(x_231); -lean_dec(x_229); -x_232 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_232, 0, x_230); -x_184 = x_232; -x_185 = x_231; -goto block_216; -} -else -{ -lean_object* x_233; lean_object* x_234; lean_object* x_235; -x_233 = lean_ctor_get(x_229, 0); +x_232 = lean_ctor_get(x_12, 2); +lean_inc(x_232); +x_233 = lean_ctor_get(x_12, 3); lean_inc(x_233); -x_234 = lean_ctor_get(x_229, 1); +x_234 = lean_ctor_get(x_12, 4); lean_inc(x_234); -lean_dec(x_229); -x_235 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_235, 0, x_233); -x_184 = x_235; -x_185 = x_234; -goto block_216; +if (lean_is_exclusive(x_12)) { + lean_ctor_release(x_12, 0); + lean_ctor_release(x_12, 1); + lean_ctor_release(x_12, 2); + lean_ctor_release(x_12, 3); + lean_ctor_release(x_12, 4); + x_235 = x_12; +} else { + lean_dec_ref(x_12); + x_235 = lean_box(0); } -block_216: +x_236 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_236, 0, x_33); +lean_ctor_set(x_236, 1, x_20); +x_237 = lean_array_push(x_232, x_236); +if (lean_is_scalar(x_235)) { + x_238 = lean_alloc_ctor(0, 5, 0); +} else { + x_238 = x_235; +} +lean_ctor_set(x_238, 0, x_230); +lean_ctor_set(x_238, 1, x_231); +lean_ctor_set(x_238, 2, x_237); +lean_ctor_set(x_238, 3, x_233); +lean_ctor_set(x_238, 4, x_234); +x_239 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_30__replaceIndFVarsWithConsts___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_35, x_238, x_229); +if (lean_obj_tag(x_239) == 0) { -if (lean_obj_tag(x_184) == 0) -{ -lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; -x_186 = lean_ctor_get(x_185, 2); -lean_inc(x_186); -x_187 = lean_ctor_get(x_184, 0); -lean_inc(x_187); -lean_dec(x_184); -x_188 = lean_ctor_get(x_185, 0); -lean_inc(x_188); -x_189 = lean_ctor_get(x_185, 1); -lean_inc(x_189); -x_190 = lean_ctor_get(x_185, 3); -lean_inc(x_190); -x_191 = lean_ctor_get(x_185, 4); -lean_inc(x_191); -x_192 = lean_ctor_get(x_185, 5); -lean_inc(x_192); -if (lean_is_exclusive(x_185)) { - lean_ctor_release(x_185, 0); - lean_ctor_release(x_185, 1); - lean_ctor_release(x_185, 2); - lean_ctor_release(x_185, 3); - lean_ctor_release(x_185, 4); - lean_ctor_release(x_185, 5); - x_193 = x_185; -} else { - lean_dec_ref(x_185); - x_193 = lean_box(0); -} -x_194 = lean_ctor_get(x_186, 0); -lean_inc(x_194); -x_195 = lean_ctor_get(x_186, 1); -lean_inc(x_195); -x_196 = lean_ctor_get(x_186, 3); -lean_inc(x_196); -if (lean_is_exclusive(x_186)) { - lean_ctor_release(x_186, 0); - lean_ctor_release(x_186, 1); - lean_ctor_release(x_186, 2); - lean_ctor_release(x_186, 3); - x_197 = x_186; -} else { - lean_dec_ref(x_186); - x_197 = lean_box(0); -} -if (lean_is_scalar(x_197)) { - x_198 = lean_alloc_ctor(0, 4, 0); -} else { - x_198 = x_197; -} -lean_ctor_set(x_198, 0, x_194); -lean_ctor_set(x_198, 1, x_195); -lean_ctor_set(x_198, 2, x_181); -lean_ctor_set(x_198, 3, x_196); -if (lean_is_scalar(x_193)) { - x_199 = lean_alloc_ctor(0, 6, 0); -} else { - x_199 = x_193; -} -lean_ctor_set(x_199, 0, x_188); -lean_ctor_set(x_199, 1, x_189); -lean_ctor_set(x_199, 2, x_198); -lean_ctor_set(x_199, 3, x_190); -lean_ctor_set(x_199, 4, x_191); -lean_ctor_set(x_199, 5, x_192); -if (lean_is_scalar(x_32)) { - x_200 = lean_alloc_ctor(1, 2, 0); -} else { - x_200 = x_32; - lean_ctor_set_tag(x_200, 1); -} -lean_ctor_set(x_200, 0, x_187); -lean_ctor_set(x_200, 1, x_199); -return x_200; +lean_object* x_240; lean_object* x_241; lean_object* x_242; +x_240 = lean_ctor_get(x_239, 0); +lean_inc(x_240); +x_241 = lean_ctor_get(x_239, 1); +lean_inc(x_241); +lean_dec(x_239); +x_242 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_242, 0, x_240); +x_192 = x_242; +x_193 = x_241; +goto block_226; } else { -lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; -x_201 = lean_ctor_get(x_185, 2); -lean_inc(x_201); -x_202 = lean_ctor_get(x_184, 0); +lean_object* x_243; lean_object* x_244; lean_object* x_245; +x_243 = lean_ctor_get(x_239, 0); +lean_inc(x_243); +x_244 = lean_ctor_get(x_239, 1); +lean_inc(x_244); +lean_dec(x_239); +x_245 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_245, 0, x_243); +x_192 = x_245; +x_193 = x_244; +goto block_226; +} +block_226: +{ +if (lean_obj_tag(x_192) == 0) +{ +lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; +x_194 = lean_ctor_get(x_193, 2); +lean_inc(x_194); +x_195 = lean_ctor_get(x_192, 0); +lean_inc(x_195); +lean_dec(x_192); +x_196 = lean_ctor_get(x_193, 0); +lean_inc(x_196); +x_197 = lean_ctor_get(x_193, 1); +lean_inc(x_197); +x_198 = lean_ctor_get(x_193, 3); +lean_inc(x_198); +x_199 = lean_ctor_get(x_193, 4); +lean_inc(x_199); +x_200 = lean_ctor_get(x_193, 5); +lean_inc(x_200); +if (lean_is_exclusive(x_193)) { + lean_ctor_release(x_193, 0); + lean_ctor_release(x_193, 1); + lean_ctor_release(x_193, 2); + lean_ctor_release(x_193, 3); + lean_ctor_release(x_193, 4); + lean_ctor_release(x_193, 5); + x_201 = x_193; +} else { + lean_dec_ref(x_193); + x_201 = lean_box(0); +} +x_202 = lean_ctor_get(x_194, 0); lean_inc(x_202); -lean_dec(x_184); -x_203 = lean_ctor_get(x_185, 0); +x_203 = lean_ctor_get(x_194, 1); lean_inc(x_203); -x_204 = lean_ctor_get(x_185, 1); +x_204 = lean_ctor_get(x_194, 3); lean_inc(x_204); -x_205 = lean_ctor_get(x_185, 3); +x_205 = lean_ctor_get(x_194, 4); lean_inc(x_205); -x_206 = lean_ctor_get(x_185, 4); -lean_inc(x_206); -x_207 = lean_ctor_get(x_185, 5); -lean_inc(x_207); -if (lean_is_exclusive(x_185)) { - lean_ctor_release(x_185, 0); - lean_ctor_release(x_185, 1); - lean_ctor_release(x_185, 2); - lean_ctor_release(x_185, 3); - lean_ctor_release(x_185, 4); - lean_ctor_release(x_185, 5); - x_208 = x_185; +if (lean_is_exclusive(x_194)) { + lean_ctor_release(x_194, 0); + lean_ctor_release(x_194, 1); + lean_ctor_release(x_194, 2); + lean_ctor_release(x_194, 3); + lean_ctor_release(x_194, 4); + x_206 = x_194; } else { - lean_dec_ref(x_185); - x_208 = lean_box(0); + lean_dec_ref(x_194); + x_206 = lean_box(0); } -x_209 = lean_ctor_get(x_201, 0); -lean_inc(x_209); -x_210 = lean_ctor_get(x_201, 1); -lean_inc(x_210); -x_211 = lean_ctor_get(x_201, 3); -lean_inc(x_211); -if (lean_is_exclusive(x_201)) { - lean_ctor_release(x_201, 0); - lean_ctor_release(x_201, 1); - lean_ctor_release(x_201, 2); - lean_ctor_release(x_201, 3); - x_212 = x_201; +if (lean_is_scalar(x_206)) { + x_207 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_201); - x_212 = lean_box(0); + x_207 = x_206; } -if (lean_is_scalar(x_212)) { - x_213 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_207, 0, x_202); +lean_ctor_set(x_207, 1, x_203); +lean_ctor_set(x_207, 2, x_188); +lean_ctor_set(x_207, 3, x_204); +lean_ctor_set(x_207, 4, x_205); +if (lean_is_scalar(x_201)) { + x_208 = lean_alloc_ctor(0, 6, 0); } else { - x_213 = x_212; + x_208 = x_201; } -lean_ctor_set(x_213, 0, x_209); -lean_ctor_set(x_213, 1, x_210); -lean_ctor_set(x_213, 2, x_181); -lean_ctor_set(x_213, 3, x_211); -if (lean_is_scalar(x_208)) { - x_214 = lean_alloc_ctor(0, 6, 0); -} else { - x_214 = x_208; -} -lean_ctor_set(x_214, 0, x_203); -lean_ctor_set(x_214, 1, x_204); -lean_ctor_set(x_214, 2, x_213); -lean_ctor_set(x_214, 3, x_205); -lean_ctor_set(x_214, 4, x_206); -lean_ctor_set(x_214, 5, x_207); +lean_ctor_set(x_208, 0, x_196); +lean_ctor_set(x_208, 1, x_197); +lean_ctor_set(x_208, 2, x_207); +lean_ctor_set(x_208, 3, x_198); +lean_ctor_set(x_208, 4, x_199); +lean_ctor_set(x_208, 5, x_200); if (lean_is_scalar(x_32)) { - x_215 = lean_alloc_ctor(0, 2, 0); + x_209 = lean_alloc_ctor(1, 2, 0); } else { - x_215 = x_32; + x_209 = x_32; + lean_ctor_set_tag(x_209, 1); } -lean_ctor_set(x_215, 0, x_202); -lean_ctor_set(x_215, 1, x_214); -return x_215; +lean_ctor_set(x_209, 0, x_195); +lean_ctor_set(x_209, 1, x_208); +return x_209; +} +else +{ +lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; lean_object* x_224; lean_object* x_225; +x_210 = lean_ctor_get(x_193, 2); +lean_inc(x_210); +x_211 = lean_ctor_get(x_192, 0); +lean_inc(x_211); +lean_dec(x_192); +x_212 = lean_ctor_get(x_193, 0); +lean_inc(x_212); +x_213 = lean_ctor_get(x_193, 1); +lean_inc(x_213); +x_214 = lean_ctor_get(x_193, 3); +lean_inc(x_214); +x_215 = lean_ctor_get(x_193, 4); +lean_inc(x_215); +x_216 = lean_ctor_get(x_193, 5); +lean_inc(x_216); +if (lean_is_exclusive(x_193)) { + lean_ctor_release(x_193, 0); + lean_ctor_release(x_193, 1); + lean_ctor_release(x_193, 2); + lean_ctor_release(x_193, 3); + lean_ctor_release(x_193, 4); + lean_ctor_release(x_193, 5); + x_217 = x_193; +} else { + lean_dec_ref(x_193); + x_217 = lean_box(0); +} +x_218 = lean_ctor_get(x_210, 0); +lean_inc(x_218); +x_219 = lean_ctor_get(x_210, 1); +lean_inc(x_219); +x_220 = lean_ctor_get(x_210, 3); +lean_inc(x_220); +x_221 = lean_ctor_get(x_210, 4); +lean_inc(x_221); +if (lean_is_exclusive(x_210)) { + lean_ctor_release(x_210, 0); + lean_ctor_release(x_210, 1); + lean_ctor_release(x_210, 2); + lean_ctor_release(x_210, 3); + lean_ctor_release(x_210, 4); + x_222 = x_210; +} else { + lean_dec_ref(x_210); + x_222 = lean_box(0); +} +if (lean_is_scalar(x_222)) { + x_223 = lean_alloc_ctor(0, 5, 0); +} else { + x_223 = x_222; +} +lean_ctor_set(x_223, 0, x_218); +lean_ctor_set(x_223, 1, x_219); +lean_ctor_set(x_223, 2, x_188); +lean_ctor_set(x_223, 3, x_220); +lean_ctor_set(x_223, 4, x_221); +if (lean_is_scalar(x_217)) { + x_224 = lean_alloc_ctor(0, 6, 0); +} else { + x_224 = x_217; +} +lean_ctor_set(x_224, 0, x_212); +lean_ctor_set(x_224, 1, x_213); +lean_ctor_set(x_224, 2, x_223); +lean_ctor_set(x_224, 3, x_214); +lean_ctor_set(x_224, 4, x_215); +lean_ctor_set(x_224, 5, x_216); +if (lean_is_scalar(x_32)) { + x_225 = lean_alloc_ctor(0, 2, 0); +} else { + x_225 = x_32; +} +lean_ctor_set(x_225, 0, x_211); +lean_ctor_set(x_225, 1, x_224); +return x_225; } } } } default: { -lean_object* x_236; lean_object* x_237; -x_236 = lean_ctor_get(x_25, 1); -lean_inc(x_236); +lean_object* x_246; lean_object* x_247; +x_246 = lean_ctor_get(x_25, 1); +lean_inc(x_246); lean_dec(x_25); lean_inc(x_12); -x_237 = l_Lean_Meta_isClassExpensive___main(x_24, x_12, x_236); -if (lean_obj_tag(x_237) == 0) +x_247 = l_Lean_Meta_isClassExpensive___main(x_24, x_12, x_246); +if (lean_obj_tag(x_247) == 0) { -lean_object* x_238; -x_238 = lean_ctor_get(x_237, 0); -lean_inc(x_238); -if (lean_obj_tag(x_238) == 0) +lean_object* x_248; +x_248 = lean_ctor_get(x_247, 0); +lean_inc(x_248); +if (lean_obj_tag(x_248) == 0) { -lean_object* x_239; lean_object* x_240; lean_object* x_241; +lean_object* x_249; lean_object* x_250; lean_object* x_251; lean_dec(x_20); -x_239 = lean_ctor_get(x_237, 1); -lean_inc(x_239); -lean_dec(x_237); -x_240 = lean_unsigned_to_nat(1u); -x_241 = lean_nat_add(x_11, x_240); +x_249 = lean_ctor_get(x_247, 1); +lean_inc(x_249); +lean_dec(x_247); +x_250 = lean_unsigned_to_nat(1u); +x_251 = lean_nat_add(x_11, x_250); lean_dec(x_11); -x_11 = x_241; -x_13 = x_239; +x_11 = x_251; +x_13 = x_249; goto _start; } else { -lean_object* x_243; lean_object* x_244; lean_object* x_245; lean_object* x_246; lean_object* x_247; uint8_t x_248; -x_243 = lean_ctor_get(x_237, 1); -lean_inc(x_243); -if (lean_is_exclusive(x_237)) { - lean_ctor_release(x_237, 0); - lean_ctor_release(x_237, 1); - x_244 = x_237; +lean_object* x_253; lean_object* x_254; lean_object* x_255; lean_object* x_256; lean_object* x_257; uint8_t x_258; +x_253 = lean_ctor_get(x_247, 1); +lean_inc(x_253); +if (lean_is_exclusive(x_247)) { + lean_ctor_release(x_247, 0); + lean_ctor_release(x_247, 1); + x_254 = x_247; } else { - lean_dec_ref(x_237); - x_244 = lean_box(0); + lean_dec_ref(x_247); + x_254 = lean_box(0); } -x_245 = lean_ctor_get(x_238, 0); -lean_inc(x_245); -lean_dec(x_238); -x_246 = lean_unsigned_to_nat(1u); -x_247 = lean_nat_add(x_11, x_246); -lean_dec(x_11); -x_248 = !lean_is_exclusive(x_243); -if (x_248 == 0) -{ -lean_object* x_249; uint8_t x_250; -x_249 = lean_ctor_get(x_243, 2); -x_250 = !lean_is_exclusive(x_249); -if (x_250 == 0) -{ -lean_object* x_251; lean_object* x_252; lean_object* x_253; lean_object* x_303; uint8_t x_304; -x_251 = lean_ctor_get(x_249, 2); -x_303 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_249, 2, x_303); -x_304 = !lean_is_exclusive(x_12); -if (x_304 == 0) -{ -lean_object* x_305; lean_object* x_306; lean_object* x_307; lean_object* x_308; -x_305 = lean_ctor_get(x_12, 2); -x_306 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_306, 0, x_245); -lean_ctor_set(x_306, 1, x_20); -x_307 = lean_array_push(x_305, x_306); -lean_ctor_set(x_12, 2, x_307); -x_308 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_30__replaceIndFVarsWithConsts___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_247, x_12, x_243); -if (lean_obj_tag(x_308) == 0) -{ -lean_object* x_309; lean_object* x_310; lean_object* x_311; -x_309 = lean_ctor_get(x_308, 0); -lean_inc(x_309); -x_310 = lean_ctor_get(x_308, 1); -lean_inc(x_310); -lean_dec(x_308); -x_311 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_311, 0, x_309); -x_252 = x_311; -x_253 = x_310; -goto block_302; -} -else -{ -lean_object* x_312; lean_object* x_313; lean_object* x_314; -x_312 = lean_ctor_get(x_308, 0); -lean_inc(x_312); -x_313 = lean_ctor_get(x_308, 1); -lean_inc(x_313); -lean_dec(x_308); -x_314 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_314, 0, x_312); -x_252 = x_314; -x_253 = x_313; -goto block_302; -} -} -else -{ -lean_object* x_315; lean_object* x_316; lean_object* x_317; lean_object* x_318; lean_object* x_319; lean_object* x_320; lean_object* x_321; lean_object* x_322; lean_object* x_323; -x_315 = lean_ctor_get(x_12, 0); -x_316 = lean_ctor_get(x_12, 1); -x_317 = lean_ctor_get(x_12, 2); -x_318 = lean_ctor_get(x_12, 3); -x_319 = lean_ctor_get(x_12, 4); -lean_inc(x_319); -lean_inc(x_318); -lean_inc(x_317); -lean_inc(x_316); -lean_inc(x_315); -lean_dec(x_12); -x_320 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_320, 0, x_245); -lean_ctor_set(x_320, 1, x_20); -x_321 = lean_array_push(x_317, x_320); -x_322 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_322, 0, x_315); -lean_ctor_set(x_322, 1, x_316); -lean_ctor_set(x_322, 2, x_321); -lean_ctor_set(x_322, 3, x_318); -lean_ctor_set(x_322, 4, x_319); -x_323 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_30__replaceIndFVarsWithConsts___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_247, x_322, x_243); -if (lean_obj_tag(x_323) == 0) -{ -lean_object* x_324; lean_object* x_325; lean_object* x_326; -x_324 = lean_ctor_get(x_323, 0); -lean_inc(x_324); -x_325 = lean_ctor_get(x_323, 1); -lean_inc(x_325); -lean_dec(x_323); -x_326 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_326, 0, x_324); -x_252 = x_326; -x_253 = x_325; -goto block_302; -} -else -{ -lean_object* x_327; lean_object* x_328; lean_object* x_329; -x_327 = lean_ctor_get(x_323, 0); -lean_inc(x_327); -x_328 = lean_ctor_get(x_323, 1); -lean_inc(x_328); -lean_dec(x_323); -x_329 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_329, 0, x_327); -x_252 = x_329; -x_253 = x_328; -goto block_302; -} -} -block_302: -{ -if (lean_obj_tag(x_252) == 0) -{ -lean_object* x_254; lean_object* x_255; uint8_t x_256; -x_254 = lean_ctor_get(x_253, 2); -lean_inc(x_254); -x_255 = lean_ctor_get(x_252, 0); +x_255 = lean_ctor_get(x_248, 0); lean_inc(x_255); -lean_dec(x_252); -x_256 = !lean_is_exclusive(x_253); -if (x_256 == 0) -{ -lean_object* x_257; uint8_t x_258; -x_257 = lean_ctor_get(x_253, 2); -lean_dec(x_257); -x_258 = !lean_is_exclusive(x_254); +lean_dec(x_248); +x_256 = lean_unsigned_to_nat(1u); +x_257 = lean_nat_add(x_11, x_256); +lean_dec(x_11); +x_258 = !lean_is_exclusive(x_253); if (x_258 == 0) { -lean_object* x_259; lean_object* x_260; -x_259 = lean_ctor_get(x_254, 2); -lean_dec(x_259); -lean_ctor_set(x_254, 2, x_251); -if (lean_is_scalar(x_244)) { - x_260 = lean_alloc_ctor(1, 2, 0); -} else { - x_260 = x_244; - lean_ctor_set_tag(x_260, 1); -} -lean_ctor_set(x_260, 0, x_255); -lean_ctor_set(x_260, 1, x_253); -return x_260; +lean_object* x_259; uint8_t x_260; +x_259 = lean_ctor_get(x_253, 2); +x_260 = !lean_is_exclusive(x_259); +if (x_260 == 0) +{ +lean_object* x_261; lean_object* x_262; lean_object* x_263; lean_object* x_317; uint8_t x_318; +x_261 = lean_ctor_get(x_259, 2); +x_317 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_259, 2, x_317); +x_318 = !lean_is_exclusive(x_12); +if (x_318 == 0) +{ +lean_object* x_319; lean_object* x_320; lean_object* x_321; lean_object* x_322; +x_319 = lean_ctor_get(x_12, 2); +x_320 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_320, 0, x_255); +lean_ctor_set(x_320, 1, x_20); +x_321 = lean_array_push(x_319, x_320); +lean_ctor_set(x_12, 2, x_321); +x_322 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_30__replaceIndFVarsWithConsts___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_257, x_12, x_253); +if (lean_obj_tag(x_322) == 0) +{ +lean_object* x_323; lean_object* x_324; lean_object* x_325; +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_alloc_ctor(1, 1, 0); +lean_ctor_set(x_325, 0, x_323); +x_262 = x_325; +x_263 = x_324; +goto block_316; } else { -lean_object* x_261; lean_object* x_262; lean_object* x_263; lean_object* x_264; lean_object* x_265; -x_261 = lean_ctor_get(x_254, 0); -x_262 = lean_ctor_get(x_254, 1); -x_263 = lean_ctor_get(x_254, 3); -lean_inc(x_263); -lean_inc(x_262); -lean_inc(x_261); -lean_dec(x_254); -x_264 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_264, 0, x_261); -lean_ctor_set(x_264, 1, x_262); -lean_ctor_set(x_264, 2, x_251); -lean_ctor_set(x_264, 3, x_263); -lean_ctor_set(x_253, 2, x_264); -if (lean_is_scalar(x_244)) { - x_265 = lean_alloc_ctor(1, 2, 0); -} else { - x_265 = x_244; - lean_ctor_set_tag(x_265, 1); -} -lean_ctor_set(x_265, 0, x_255); -lean_ctor_set(x_265, 1, x_253); -return x_265; +lean_object* x_326; lean_object* x_327; lean_object* x_328; +x_326 = lean_ctor_get(x_322, 0); +lean_inc(x_326); +x_327 = lean_ctor_get(x_322, 1); +lean_inc(x_327); +lean_dec(x_322); +x_328 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_328, 0, x_326); +x_262 = x_328; +x_263 = x_327; +goto block_316; } } else { -lean_object* x_266; lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_object* x_270; lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_object* x_276; lean_object* x_277; -x_266 = lean_ctor_get(x_253, 0); -x_267 = lean_ctor_get(x_253, 1); -x_268 = lean_ctor_get(x_253, 3); -x_269 = lean_ctor_get(x_253, 4); -x_270 = lean_ctor_get(x_253, 5); -lean_inc(x_270); -lean_inc(x_269); -lean_inc(x_268); -lean_inc(x_267); -lean_inc(x_266); -lean_dec(x_253); -x_271 = lean_ctor_get(x_254, 0); -lean_inc(x_271); -x_272 = lean_ctor_get(x_254, 1); -lean_inc(x_272); -x_273 = lean_ctor_get(x_254, 3); +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; +x_329 = lean_ctor_get(x_12, 0); +x_330 = lean_ctor_get(x_12, 1); +x_331 = lean_ctor_get(x_12, 2); +x_332 = lean_ctor_get(x_12, 3); +x_333 = lean_ctor_get(x_12, 4); +lean_inc(x_333); +lean_inc(x_332); +lean_inc(x_331); +lean_inc(x_330); +lean_inc(x_329); +lean_dec(x_12); +x_334 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_334, 0, x_255); +lean_ctor_set(x_334, 1, x_20); +x_335 = lean_array_push(x_331, x_334); +x_336 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_336, 0, x_329); +lean_ctor_set(x_336, 1, x_330); +lean_ctor_set(x_336, 2, x_335); +lean_ctor_set(x_336, 3, x_332); +lean_ctor_set(x_336, 4, x_333); +x_337 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_30__replaceIndFVarsWithConsts___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_257, x_336, x_253); +if (lean_obj_tag(x_337) == 0) +{ +lean_object* x_338; lean_object* x_339; lean_object* x_340; +x_338 = lean_ctor_get(x_337, 0); +lean_inc(x_338); +x_339 = lean_ctor_get(x_337, 1); +lean_inc(x_339); +lean_dec(x_337); +x_340 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_340, 0, x_338); +x_262 = x_340; +x_263 = x_339; +goto block_316; +} +else +{ +lean_object* x_341; lean_object* x_342; lean_object* x_343; +x_341 = lean_ctor_get(x_337, 0); +lean_inc(x_341); +x_342 = lean_ctor_get(x_337, 1); +lean_inc(x_342); +lean_dec(x_337); +x_343 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_343, 0, x_341); +x_262 = x_343; +x_263 = x_342; +goto block_316; +} +} +block_316: +{ +if (lean_obj_tag(x_262) == 0) +{ +lean_object* x_264; lean_object* x_265; uint8_t x_266; +x_264 = lean_ctor_get(x_263, 2); +lean_inc(x_264); +x_265 = lean_ctor_get(x_262, 0); +lean_inc(x_265); +lean_dec(x_262); +x_266 = !lean_is_exclusive(x_263); +if (x_266 == 0) +{ +lean_object* x_267; uint8_t x_268; +x_267 = lean_ctor_get(x_263, 2); +lean_dec(x_267); +x_268 = !lean_is_exclusive(x_264); +if (x_268 == 0) +{ +lean_object* x_269; lean_object* x_270; +x_269 = lean_ctor_get(x_264, 2); +lean_dec(x_269); +lean_ctor_set(x_264, 2, x_261); +if (lean_is_scalar(x_254)) { + x_270 = lean_alloc_ctor(1, 2, 0); +} else { + x_270 = x_254; + lean_ctor_set_tag(x_270, 1); +} +lean_ctor_set(x_270, 0, x_265); +lean_ctor_set(x_270, 1, x_263); +return x_270; +} +else +{ +lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_object* x_276; +x_271 = lean_ctor_get(x_264, 0); +x_272 = lean_ctor_get(x_264, 1); +x_273 = lean_ctor_get(x_264, 3); +x_274 = lean_ctor_get(x_264, 4); +lean_inc(x_274); lean_inc(x_273); -if (lean_is_exclusive(x_254)) { - lean_ctor_release(x_254, 0); - lean_ctor_release(x_254, 1); - lean_ctor_release(x_254, 2); - lean_ctor_release(x_254, 3); - x_274 = x_254; -} else { - lean_dec_ref(x_254); - x_274 = lean_box(0); -} -if (lean_is_scalar(x_274)) { - x_275 = lean_alloc_ctor(0, 4, 0); -} else { - x_275 = x_274; -} +lean_inc(x_272); +lean_inc(x_271); +lean_dec(x_264); +x_275 = lean_alloc_ctor(0, 5, 0); lean_ctor_set(x_275, 0, x_271); lean_ctor_set(x_275, 1, x_272); -lean_ctor_set(x_275, 2, x_251); +lean_ctor_set(x_275, 2, x_261); lean_ctor_set(x_275, 3, x_273); -x_276 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_276, 0, x_266); -lean_ctor_set(x_276, 1, x_267); -lean_ctor_set(x_276, 2, x_275); -lean_ctor_set(x_276, 3, x_268); -lean_ctor_set(x_276, 4, x_269); -lean_ctor_set(x_276, 5, x_270); -if (lean_is_scalar(x_244)) { - x_277 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_275, 4, x_274); +lean_ctor_set(x_263, 2, x_275); +if (lean_is_scalar(x_254)) { + x_276 = lean_alloc_ctor(1, 2, 0); } else { - x_277 = x_244; - lean_ctor_set_tag(x_277, 1); + x_276 = x_254; + lean_ctor_set_tag(x_276, 1); } -lean_ctor_set(x_277, 0, x_255); -lean_ctor_set(x_277, 1, x_276); -return x_277; +lean_ctor_set(x_276, 0, x_265); +lean_ctor_set(x_276, 1, x_263); +return x_276; } } else { -lean_object* x_278; lean_object* x_279; uint8_t x_280; -x_278 = lean_ctor_get(x_253, 2); -lean_inc(x_278); -x_279 = lean_ctor_get(x_252, 0); +lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; lean_object* x_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; lean_object* x_289; +x_277 = lean_ctor_get(x_263, 0); +x_278 = lean_ctor_get(x_263, 1); +x_279 = lean_ctor_get(x_263, 3); +x_280 = lean_ctor_get(x_263, 4); +x_281 = lean_ctor_get(x_263, 5); +lean_inc(x_281); +lean_inc(x_280); lean_inc(x_279); -lean_dec(x_252); -x_280 = !lean_is_exclusive(x_253); -if (x_280 == 0) -{ -lean_object* x_281; uint8_t x_282; -x_281 = lean_ctor_get(x_253, 2); -lean_dec(x_281); -x_282 = !lean_is_exclusive(x_278); -if (x_282 == 0) -{ -lean_object* x_283; lean_object* x_284; -x_283 = lean_ctor_get(x_278, 2); -lean_dec(x_283); -lean_ctor_set(x_278, 2, x_251); -if (lean_is_scalar(x_244)) { - x_284 = lean_alloc_ctor(0, 2, 0); -} else { - x_284 = x_244; -} -lean_ctor_set(x_284, 0, x_279); -lean_ctor_set(x_284, 1, x_253); -return x_284; -} -else -{ -lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; lean_object* x_289; -x_285 = lean_ctor_get(x_278, 0); -x_286 = lean_ctor_get(x_278, 1); -x_287 = lean_ctor_get(x_278, 3); -lean_inc(x_287); -lean_inc(x_286); +lean_inc(x_278); +lean_inc(x_277); +lean_dec(x_263); +x_282 = lean_ctor_get(x_264, 0); +lean_inc(x_282); +x_283 = lean_ctor_get(x_264, 1); +lean_inc(x_283); +x_284 = lean_ctor_get(x_264, 3); +lean_inc(x_284); +x_285 = lean_ctor_get(x_264, 4); lean_inc(x_285); -lean_dec(x_278); -x_288 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_288, 0, x_285); -lean_ctor_set(x_288, 1, x_286); -lean_ctor_set(x_288, 2, x_251); -lean_ctor_set(x_288, 3, x_287); -lean_ctor_set(x_253, 2, x_288); -if (lean_is_scalar(x_244)) { - x_289 = lean_alloc_ctor(0, 2, 0); +if (lean_is_exclusive(x_264)) { + lean_ctor_release(x_264, 0); + lean_ctor_release(x_264, 1); + lean_ctor_release(x_264, 2); + lean_ctor_release(x_264, 3); + lean_ctor_release(x_264, 4); + x_286 = x_264; } else { - x_289 = x_244; + lean_dec_ref(x_264); + x_286 = lean_box(0); } -lean_ctor_set(x_289, 0, x_279); -lean_ctor_set(x_289, 1, x_253); +if (lean_is_scalar(x_286)) { + x_287 = lean_alloc_ctor(0, 5, 0); +} else { + x_287 = x_286; +} +lean_ctor_set(x_287, 0, x_282); +lean_ctor_set(x_287, 1, x_283); +lean_ctor_set(x_287, 2, x_261); +lean_ctor_set(x_287, 3, x_284); +lean_ctor_set(x_287, 4, x_285); +x_288 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_288, 0, x_277); +lean_ctor_set(x_288, 1, x_278); +lean_ctor_set(x_288, 2, x_287); +lean_ctor_set(x_288, 3, x_279); +lean_ctor_set(x_288, 4, x_280); +lean_ctor_set(x_288, 5, x_281); +if (lean_is_scalar(x_254)) { + x_289 = lean_alloc_ctor(1, 2, 0); +} else { + x_289 = x_254; + lean_ctor_set_tag(x_289, 1); +} +lean_ctor_set(x_289, 0, x_265); +lean_ctor_set(x_289, 1, x_288); return x_289; } } else { -lean_object* x_290; lean_object* x_291; lean_object* x_292; lean_object* x_293; lean_object* x_294; lean_object* x_295; lean_object* x_296; lean_object* x_297; lean_object* x_298; lean_object* x_299; lean_object* x_300; lean_object* x_301; -x_290 = lean_ctor_get(x_253, 0); -x_291 = lean_ctor_get(x_253, 1); -x_292 = lean_ctor_get(x_253, 3); -x_293 = lean_ctor_get(x_253, 4); -x_294 = lean_ctor_get(x_253, 5); -lean_inc(x_294); -lean_inc(x_293); -lean_inc(x_292); -lean_inc(x_291); +lean_object* x_290; lean_object* x_291; uint8_t x_292; +x_290 = lean_ctor_get(x_263, 2); lean_inc(x_290); -lean_dec(x_253); -x_295 = lean_ctor_get(x_278, 0); -lean_inc(x_295); -x_296 = lean_ctor_get(x_278, 1); -lean_inc(x_296); -x_297 = lean_ctor_get(x_278, 3); +x_291 = lean_ctor_get(x_262, 0); +lean_inc(x_291); +lean_dec(x_262); +x_292 = !lean_is_exclusive(x_263); +if (x_292 == 0) +{ +lean_object* x_293; uint8_t x_294; +x_293 = lean_ctor_get(x_263, 2); +lean_dec(x_293); +x_294 = !lean_is_exclusive(x_290); +if (x_294 == 0) +{ +lean_object* x_295; lean_object* x_296; +x_295 = lean_ctor_get(x_290, 2); +lean_dec(x_295); +lean_ctor_set(x_290, 2, x_261); +if (lean_is_scalar(x_254)) { + x_296 = lean_alloc_ctor(0, 2, 0); +} else { + x_296 = x_254; +} +lean_ctor_set(x_296, 0, x_291); +lean_ctor_set(x_296, 1, x_263); +return x_296; +} +else +{ +lean_object* x_297; lean_object* x_298; lean_object* x_299; lean_object* x_300; lean_object* x_301; lean_object* x_302; +x_297 = lean_ctor_get(x_290, 0); +x_298 = lean_ctor_get(x_290, 1); +x_299 = lean_ctor_get(x_290, 3); +x_300 = lean_ctor_get(x_290, 4); +lean_inc(x_300); +lean_inc(x_299); +lean_inc(x_298); lean_inc(x_297); -if (lean_is_exclusive(x_278)) { - lean_ctor_release(x_278, 0); - lean_ctor_release(x_278, 1); - lean_ctor_release(x_278, 2); - lean_ctor_release(x_278, 3); - x_298 = x_278; +lean_dec(x_290); +x_301 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_301, 0, x_297); +lean_ctor_set(x_301, 1, x_298); +lean_ctor_set(x_301, 2, x_261); +lean_ctor_set(x_301, 3, x_299); +lean_ctor_set(x_301, 4, x_300); +lean_ctor_set(x_263, 2, x_301); +if (lean_is_scalar(x_254)) { + x_302 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_278); - x_298 = lean_box(0); + x_302 = x_254; } -if (lean_is_scalar(x_298)) { - x_299 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_302, 0, x_291); +lean_ctor_set(x_302, 1, x_263); +return x_302; +} +} +else +{ +lean_object* x_303; lean_object* x_304; lean_object* x_305; lean_object* x_306; lean_object* x_307; lean_object* x_308; lean_object* x_309; lean_object* x_310; lean_object* x_311; lean_object* x_312; lean_object* x_313; lean_object* x_314; lean_object* x_315; +x_303 = lean_ctor_get(x_263, 0); +x_304 = lean_ctor_get(x_263, 1); +x_305 = lean_ctor_get(x_263, 3); +x_306 = lean_ctor_get(x_263, 4); +x_307 = lean_ctor_get(x_263, 5); +lean_inc(x_307); +lean_inc(x_306); +lean_inc(x_305); +lean_inc(x_304); +lean_inc(x_303); +lean_dec(x_263); +x_308 = lean_ctor_get(x_290, 0); +lean_inc(x_308); +x_309 = lean_ctor_get(x_290, 1); +lean_inc(x_309); +x_310 = lean_ctor_get(x_290, 3); +lean_inc(x_310); +x_311 = lean_ctor_get(x_290, 4); +lean_inc(x_311); +if (lean_is_exclusive(x_290)) { + lean_ctor_release(x_290, 0); + lean_ctor_release(x_290, 1); + lean_ctor_release(x_290, 2); + lean_ctor_release(x_290, 3); + lean_ctor_release(x_290, 4); + x_312 = x_290; } else { - x_299 = x_298; + lean_dec_ref(x_290); + x_312 = lean_box(0); } -lean_ctor_set(x_299, 0, x_295); -lean_ctor_set(x_299, 1, x_296); -lean_ctor_set(x_299, 2, x_251); -lean_ctor_set(x_299, 3, x_297); -x_300 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_300, 0, x_290); -lean_ctor_set(x_300, 1, x_291); -lean_ctor_set(x_300, 2, x_299); -lean_ctor_set(x_300, 3, x_292); -lean_ctor_set(x_300, 4, x_293); -lean_ctor_set(x_300, 5, x_294); -if (lean_is_scalar(x_244)) { - x_301 = lean_alloc_ctor(0, 2, 0); +if (lean_is_scalar(x_312)) { + x_313 = lean_alloc_ctor(0, 5, 0); } else { - x_301 = x_244; + x_313 = x_312; } -lean_ctor_set(x_301, 0, x_279); -lean_ctor_set(x_301, 1, x_300); -return x_301; +lean_ctor_set(x_313, 0, x_308); +lean_ctor_set(x_313, 1, x_309); +lean_ctor_set(x_313, 2, x_261); +lean_ctor_set(x_313, 3, x_310); +lean_ctor_set(x_313, 4, x_311); +x_314 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_314, 0, x_303); +lean_ctor_set(x_314, 1, x_304); +lean_ctor_set(x_314, 2, x_313); +lean_ctor_set(x_314, 3, x_305); +lean_ctor_set(x_314, 4, x_306); +lean_ctor_set(x_314, 5, x_307); +if (lean_is_scalar(x_254)) { + x_315 = lean_alloc_ctor(0, 2, 0); +} else { + x_315 = x_254; +} +lean_ctor_set(x_315, 0, x_291); +lean_ctor_set(x_315, 1, x_314); +return x_315; } } } } else { -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_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; lean_object* x_374; lean_object* x_375; lean_object* x_376; lean_object* x_377; lean_object* x_378; -x_330 = lean_ctor_get(x_249, 0); -x_331 = lean_ctor_get(x_249, 1); -x_332 = lean_ctor_get(x_249, 2); -x_333 = lean_ctor_get(x_249, 3); -lean_inc(x_333); -lean_inc(x_332); -lean_inc(x_331); -lean_inc(x_330); -lean_dec(x_249); -x_367 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_368 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_368, 0, x_330); -lean_ctor_set(x_368, 1, x_331); -lean_ctor_set(x_368, 2, x_367); -lean_ctor_set(x_368, 3, x_333); -lean_ctor_set(x_243, 2, x_368); -x_369 = lean_ctor_get(x_12, 0); -lean_inc(x_369); -x_370 = lean_ctor_get(x_12, 1); -lean_inc(x_370); -x_371 = lean_ctor_get(x_12, 2); -lean_inc(x_371); -x_372 = lean_ctor_get(x_12, 3); -lean_inc(x_372); -x_373 = lean_ctor_get(x_12, 4); -lean_inc(x_373); +lean_object* x_344; lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; lean_object* x_350; 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; lean_object* x_391; lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; +x_344 = lean_ctor_get(x_259, 0); +x_345 = lean_ctor_get(x_259, 1); +x_346 = lean_ctor_get(x_259, 2); +x_347 = lean_ctor_get(x_259, 3); +x_348 = lean_ctor_get(x_259, 4); +lean_inc(x_348); +lean_inc(x_347); +lean_inc(x_346); +lean_inc(x_345); +lean_inc(x_344); +lean_dec(x_259); +x_384 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_385 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_385, 0, x_344); +lean_ctor_set(x_385, 1, x_345); +lean_ctor_set(x_385, 2, x_384); +lean_ctor_set(x_385, 3, x_347); +lean_ctor_set(x_385, 4, x_348); +lean_ctor_set(x_253, 2, x_385); +x_386 = lean_ctor_get(x_12, 0); +lean_inc(x_386); +x_387 = lean_ctor_get(x_12, 1); +lean_inc(x_387); +x_388 = lean_ctor_get(x_12, 2); +lean_inc(x_388); +x_389 = lean_ctor_get(x_12, 3); +lean_inc(x_389); +x_390 = lean_ctor_get(x_12, 4); +lean_inc(x_390); if (lean_is_exclusive(x_12)) { lean_ctor_release(x_12, 0); lean_ctor_release(x_12, 1); lean_ctor_release(x_12, 2); lean_ctor_release(x_12, 3); lean_ctor_release(x_12, 4); - x_374 = x_12; + x_391 = x_12; } else { lean_dec_ref(x_12); - x_374 = lean_box(0); + x_391 = lean_box(0); } -x_375 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_375, 0, x_245); -lean_ctor_set(x_375, 1, x_20); -x_376 = lean_array_push(x_371, x_375); -if (lean_is_scalar(x_374)) { - x_377 = lean_alloc_ctor(0, 5, 0); +x_392 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_392, 0, x_255); +lean_ctor_set(x_392, 1, x_20); +x_393 = lean_array_push(x_388, x_392); +if (lean_is_scalar(x_391)) { + x_394 = lean_alloc_ctor(0, 5, 0); } else { - x_377 = x_374; + x_394 = x_391; } -lean_ctor_set(x_377, 0, x_369); -lean_ctor_set(x_377, 1, x_370); -lean_ctor_set(x_377, 2, x_376); -lean_ctor_set(x_377, 3, x_372); -lean_ctor_set(x_377, 4, x_373); -x_378 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_30__replaceIndFVarsWithConsts___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_247, x_377, x_243); -if (lean_obj_tag(x_378) == 0) +lean_ctor_set(x_394, 0, x_386); +lean_ctor_set(x_394, 1, x_387); +lean_ctor_set(x_394, 2, x_393); +lean_ctor_set(x_394, 3, x_389); +lean_ctor_set(x_394, 4, x_390); +x_395 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_30__replaceIndFVarsWithConsts___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_257, x_394, x_253); +if (lean_obj_tag(x_395) == 0) { -lean_object* x_379; lean_object* x_380; lean_object* x_381; -x_379 = lean_ctor_get(x_378, 0); -lean_inc(x_379); -x_380 = lean_ctor_get(x_378, 1); -lean_inc(x_380); -lean_dec(x_378); -x_381 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_381, 0, x_379); -x_334 = x_381; -x_335 = x_380; -goto block_366; +lean_object* x_396; lean_object* x_397; lean_object* x_398; +x_396 = lean_ctor_get(x_395, 0); +lean_inc(x_396); +x_397 = lean_ctor_get(x_395, 1); +lean_inc(x_397); +lean_dec(x_395); +x_398 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_398, 0, x_396); +x_349 = x_398; +x_350 = x_397; +goto block_383; } else { -lean_object* x_382; lean_object* x_383; lean_object* x_384; -x_382 = lean_ctor_get(x_378, 0); -lean_inc(x_382); -x_383 = lean_ctor_get(x_378, 1); -lean_inc(x_383); -lean_dec(x_378); -x_384 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_384, 0, x_382); -x_334 = x_384; -x_335 = x_383; -goto block_366; +lean_object* x_399; lean_object* x_400; lean_object* x_401; +x_399 = lean_ctor_get(x_395, 0); +lean_inc(x_399); +x_400 = lean_ctor_get(x_395, 1); +lean_inc(x_400); +lean_dec(x_395); +x_401 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_401, 0, x_399); +x_349 = x_401; +x_350 = x_400; +goto block_383; } -block_366: +block_383: { -if (lean_obj_tag(x_334) == 0) +if (lean_obj_tag(x_349) == 0) { -lean_object* x_336; lean_object* x_337; lean_object* x_338; lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; lean_object* x_350; -x_336 = lean_ctor_get(x_335, 2); -lean_inc(x_336); -x_337 = lean_ctor_get(x_334, 0); -lean_inc(x_337); -lean_dec(x_334); -x_338 = lean_ctor_get(x_335, 0); -lean_inc(x_338); -x_339 = lean_ctor_get(x_335, 1); -lean_inc(x_339); -x_340 = lean_ctor_get(x_335, 3); -lean_inc(x_340); -x_341 = lean_ctor_get(x_335, 4); -lean_inc(x_341); -x_342 = lean_ctor_get(x_335, 5); -lean_inc(x_342); -if (lean_is_exclusive(x_335)) { - lean_ctor_release(x_335, 0); - lean_ctor_release(x_335, 1); - lean_ctor_release(x_335, 2); - lean_ctor_release(x_335, 3); - lean_ctor_release(x_335, 4); - lean_ctor_release(x_335, 5); - x_343 = x_335; -} else { - lean_dec_ref(x_335); - x_343 = lean_box(0); -} -x_344 = lean_ctor_get(x_336, 0); -lean_inc(x_344); -x_345 = lean_ctor_get(x_336, 1); -lean_inc(x_345); -x_346 = lean_ctor_get(x_336, 3); -lean_inc(x_346); -if (lean_is_exclusive(x_336)) { - lean_ctor_release(x_336, 0); - lean_ctor_release(x_336, 1); - lean_ctor_release(x_336, 2); - lean_ctor_release(x_336, 3); - x_347 = x_336; -} else { - lean_dec_ref(x_336); - x_347 = lean_box(0); -} -if (lean_is_scalar(x_347)) { - x_348 = lean_alloc_ctor(0, 4, 0); -} else { - x_348 = x_347; -} -lean_ctor_set(x_348, 0, x_344); -lean_ctor_set(x_348, 1, x_345); -lean_ctor_set(x_348, 2, x_332); -lean_ctor_set(x_348, 3, x_346); -if (lean_is_scalar(x_343)) { - x_349 = lean_alloc_ctor(0, 6, 0); -} else { - x_349 = x_343; -} -lean_ctor_set(x_349, 0, x_338); -lean_ctor_set(x_349, 1, x_339); -lean_ctor_set(x_349, 2, x_348); -lean_ctor_set(x_349, 3, x_340); -lean_ctor_set(x_349, 4, x_341); -lean_ctor_set(x_349, 5, x_342); -if (lean_is_scalar(x_244)) { - x_350 = lean_alloc_ctor(1, 2, 0); -} else { - x_350 = x_244; - lean_ctor_set_tag(x_350, 1); -} -lean_ctor_set(x_350, 0, x_337); -lean_ctor_set(x_350, 1, x_349); -return x_350; -} -else -{ -lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; 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; -x_351 = lean_ctor_get(x_335, 2); +lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; 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; +x_351 = lean_ctor_get(x_350, 2); lean_inc(x_351); -x_352 = lean_ctor_get(x_334, 0); +x_352 = lean_ctor_get(x_349, 0); lean_inc(x_352); -lean_dec(x_334); -x_353 = lean_ctor_get(x_335, 0); +lean_dec(x_349); +x_353 = lean_ctor_get(x_350, 0); lean_inc(x_353); -x_354 = lean_ctor_get(x_335, 1); +x_354 = lean_ctor_get(x_350, 1); lean_inc(x_354); -x_355 = lean_ctor_get(x_335, 3); +x_355 = lean_ctor_get(x_350, 3); lean_inc(x_355); -x_356 = lean_ctor_get(x_335, 4); +x_356 = lean_ctor_get(x_350, 4); lean_inc(x_356); -x_357 = lean_ctor_get(x_335, 5); +x_357 = lean_ctor_get(x_350, 5); lean_inc(x_357); -if (lean_is_exclusive(x_335)) { - lean_ctor_release(x_335, 0); - lean_ctor_release(x_335, 1); - lean_ctor_release(x_335, 2); - lean_ctor_release(x_335, 3); - lean_ctor_release(x_335, 4); - lean_ctor_release(x_335, 5); - x_358 = x_335; +if (lean_is_exclusive(x_350)) { + lean_ctor_release(x_350, 0); + lean_ctor_release(x_350, 1); + lean_ctor_release(x_350, 2); + lean_ctor_release(x_350, 3); + lean_ctor_release(x_350, 4); + lean_ctor_release(x_350, 5); + x_358 = x_350; } else { - lean_dec_ref(x_335); + lean_dec_ref(x_350); x_358 = lean_box(0); } x_359 = lean_ctor_get(x_351, 0); @@ -13897,315 +13949,411 @@ x_360 = lean_ctor_get(x_351, 1); lean_inc(x_360); x_361 = lean_ctor_get(x_351, 3); lean_inc(x_361); +x_362 = lean_ctor_get(x_351, 4); +lean_inc(x_362); if (lean_is_exclusive(x_351)) { lean_ctor_release(x_351, 0); lean_ctor_release(x_351, 1); lean_ctor_release(x_351, 2); lean_ctor_release(x_351, 3); - x_362 = x_351; + lean_ctor_release(x_351, 4); + x_363 = x_351; } else { lean_dec_ref(x_351); - x_362 = lean_box(0); + x_363 = lean_box(0); } -if (lean_is_scalar(x_362)) { - x_363 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_363)) { + x_364 = lean_alloc_ctor(0, 5, 0); } else { - x_363 = x_362; + x_364 = x_363; } -lean_ctor_set(x_363, 0, x_359); -lean_ctor_set(x_363, 1, x_360); -lean_ctor_set(x_363, 2, x_332); -lean_ctor_set(x_363, 3, x_361); +lean_ctor_set(x_364, 0, x_359); +lean_ctor_set(x_364, 1, x_360); +lean_ctor_set(x_364, 2, x_346); +lean_ctor_set(x_364, 3, x_361); +lean_ctor_set(x_364, 4, x_362); if (lean_is_scalar(x_358)) { - x_364 = lean_alloc_ctor(0, 6, 0); + x_365 = lean_alloc_ctor(0, 6, 0); } else { - x_364 = x_358; + x_365 = x_358; } -lean_ctor_set(x_364, 0, x_353); -lean_ctor_set(x_364, 1, x_354); -lean_ctor_set(x_364, 2, x_363); -lean_ctor_set(x_364, 3, x_355); -lean_ctor_set(x_364, 4, x_356); -lean_ctor_set(x_364, 5, x_357); -if (lean_is_scalar(x_244)) { - x_365 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_365, 0, x_353); +lean_ctor_set(x_365, 1, x_354); +lean_ctor_set(x_365, 2, x_364); +lean_ctor_set(x_365, 3, x_355); +lean_ctor_set(x_365, 4, x_356); +lean_ctor_set(x_365, 5, x_357); +if (lean_is_scalar(x_254)) { + x_366 = lean_alloc_ctor(1, 2, 0); } else { - x_365 = x_244; + x_366 = x_254; + lean_ctor_set_tag(x_366, 1); } -lean_ctor_set(x_365, 0, x_352); -lean_ctor_set(x_365, 1, x_364); -return x_365; +lean_ctor_set(x_366, 0, x_352); +lean_ctor_set(x_366, 1, x_365); +return x_366; +} +else +{ +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; lean_object* x_374; lean_object* x_375; 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; +x_367 = lean_ctor_get(x_350, 2); +lean_inc(x_367); +x_368 = lean_ctor_get(x_349, 0); +lean_inc(x_368); +lean_dec(x_349); +x_369 = lean_ctor_get(x_350, 0); +lean_inc(x_369); +x_370 = lean_ctor_get(x_350, 1); +lean_inc(x_370); +x_371 = lean_ctor_get(x_350, 3); +lean_inc(x_371); +x_372 = lean_ctor_get(x_350, 4); +lean_inc(x_372); +x_373 = lean_ctor_get(x_350, 5); +lean_inc(x_373); +if (lean_is_exclusive(x_350)) { + lean_ctor_release(x_350, 0); + lean_ctor_release(x_350, 1); + lean_ctor_release(x_350, 2); + lean_ctor_release(x_350, 3); + lean_ctor_release(x_350, 4); + lean_ctor_release(x_350, 5); + x_374 = x_350; +} else { + lean_dec_ref(x_350); + x_374 = lean_box(0); +} +x_375 = lean_ctor_get(x_367, 0); +lean_inc(x_375); +x_376 = lean_ctor_get(x_367, 1); +lean_inc(x_376); +x_377 = lean_ctor_get(x_367, 3); +lean_inc(x_377); +x_378 = lean_ctor_get(x_367, 4); +lean_inc(x_378); +if (lean_is_exclusive(x_367)) { + lean_ctor_release(x_367, 0); + lean_ctor_release(x_367, 1); + lean_ctor_release(x_367, 2); + lean_ctor_release(x_367, 3); + lean_ctor_release(x_367, 4); + x_379 = x_367; +} else { + lean_dec_ref(x_367); + x_379 = lean_box(0); +} +if (lean_is_scalar(x_379)) { + x_380 = lean_alloc_ctor(0, 5, 0); +} else { + x_380 = x_379; +} +lean_ctor_set(x_380, 0, x_375); +lean_ctor_set(x_380, 1, x_376); +lean_ctor_set(x_380, 2, x_346); +lean_ctor_set(x_380, 3, x_377); +lean_ctor_set(x_380, 4, x_378); +if (lean_is_scalar(x_374)) { + x_381 = lean_alloc_ctor(0, 6, 0); +} else { + x_381 = x_374; +} +lean_ctor_set(x_381, 0, x_369); +lean_ctor_set(x_381, 1, x_370); +lean_ctor_set(x_381, 2, x_380); +lean_ctor_set(x_381, 3, x_371); +lean_ctor_set(x_381, 4, x_372); +lean_ctor_set(x_381, 5, x_373); +if (lean_is_scalar(x_254)) { + x_382 = lean_alloc_ctor(0, 2, 0); +} else { + x_382 = x_254; +} +lean_ctor_set(x_382, 0, x_368); +lean_ctor_set(x_382, 1, x_381); +return x_382; } } } } else { -lean_object* x_385; lean_object* x_386; lean_object* x_387; lean_object* x_388; lean_object* x_389; lean_object* x_390; lean_object* x_391; lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_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; -x_385 = lean_ctor_get(x_243, 2); -x_386 = lean_ctor_get(x_243, 0); -x_387 = lean_ctor_get(x_243, 1); -x_388 = lean_ctor_get(x_243, 3); -x_389 = lean_ctor_get(x_243, 4); -x_390 = lean_ctor_get(x_243, 5); -lean_inc(x_390); -lean_inc(x_389); -lean_inc(x_388); -lean_inc(x_385); -lean_inc(x_387); -lean_inc(x_386); -lean_dec(x_243); -x_391 = lean_ctor_get(x_385, 0); -lean_inc(x_391); -x_392 = lean_ctor_get(x_385, 1); -lean_inc(x_392); -x_393 = lean_ctor_get(x_385, 2); -lean_inc(x_393); -x_394 = lean_ctor_get(x_385, 3); -lean_inc(x_394); -if (lean_is_exclusive(x_385)) { - lean_ctor_release(x_385, 0); - lean_ctor_release(x_385, 1); - lean_ctor_release(x_385, 2); - lean_ctor_release(x_385, 3); - x_395 = x_385; +lean_object* x_402; lean_object* x_403; lean_object* x_404; lean_object* x_405; lean_object* x_406; lean_object* x_407; lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_object* x_412; lean_object* x_413; lean_object* x_414; lean_object* x_415; lean_object* x_449; lean_object* x_450; lean_object* x_451; lean_object* x_452; lean_object* x_453; lean_object* x_454; lean_object* x_455; lean_object* x_456; lean_object* x_457; lean_object* x_458; lean_object* x_459; lean_object* x_460; lean_object* x_461; +x_402 = lean_ctor_get(x_253, 2); +x_403 = lean_ctor_get(x_253, 0); +x_404 = lean_ctor_get(x_253, 1); +x_405 = lean_ctor_get(x_253, 3); +x_406 = lean_ctor_get(x_253, 4); +x_407 = lean_ctor_get(x_253, 5); +lean_inc(x_407); +lean_inc(x_406); +lean_inc(x_405); +lean_inc(x_402); +lean_inc(x_404); +lean_inc(x_403); +lean_dec(x_253); +x_408 = lean_ctor_get(x_402, 0); +lean_inc(x_408); +x_409 = lean_ctor_get(x_402, 1); +lean_inc(x_409); +x_410 = lean_ctor_get(x_402, 2); +lean_inc(x_410); +x_411 = lean_ctor_get(x_402, 3); +lean_inc(x_411); +x_412 = lean_ctor_get(x_402, 4); +lean_inc(x_412); +if (lean_is_exclusive(x_402)) { + lean_ctor_release(x_402, 0); + lean_ctor_release(x_402, 1); + lean_ctor_release(x_402, 2); + lean_ctor_release(x_402, 3); + lean_ctor_release(x_402, 4); + x_413 = x_402; } else { - lean_dec_ref(x_385); - x_395 = lean_box(0); + lean_dec_ref(x_402); + x_413 = lean_box(0); } -x_429 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_395)) { - x_430 = lean_alloc_ctor(0, 4, 0); +x_449 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_413)) { + x_450 = lean_alloc_ctor(0, 5, 0); } else { - x_430 = x_395; + x_450 = x_413; } -lean_ctor_set(x_430, 0, x_391); -lean_ctor_set(x_430, 1, x_392); -lean_ctor_set(x_430, 2, x_429); -lean_ctor_set(x_430, 3, x_394); -x_431 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_431, 0, x_386); -lean_ctor_set(x_431, 1, x_387); -lean_ctor_set(x_431, 2, x_430); -lean_ctor_set(x_431, 3, x_388); -lean_ctor_set(x_431, 4, x_389); -lean_ctor_set(x_431, 5, x_390); -x_432 = lean_ctor_get(x_12, 0); -lean_inc(x_432); -x_433 = lean_ctor_get(x_12, 1); -lean_inc(x_433); -x_434 = lean_ctor_get(x_12, 2); -lean_inc(x_434); -x_435 = lean_ctor_get(x_12, 3); -lean_inc(x_435); -x_436 = lean_ctor_get(x_12, 4); -lean_inc(x_436); +lean_ctor_set(x_450, 0, x_408); +lean_ctor_set(x_450, 1, x_409); +lean_ctor_set(x_450, 2, x_449); +lean_ctor_set(x_450, 3, x_411); +lean_ctor_set(x_450, 4, x_412); +x_451 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_451, 0, x_403); +lean_ctor_set(x_451, 1, x_404); +lean_ctor_set(x_451, 2, x_450); +lean_ctor_set(x_451, 3, x_405); +lean_ctor_set(x_451, 4, x_406); +lean_ctor_set(x_451, 5, x_407); +x_452 = lean_ctor_get(x_12, 0); +lean_inc(x_452); +x_453 = lean_ctor_get(x_12, 1); +lean_inc(x_453); +x_454 = lean_ctor_get(x_12, 2); +lean_inc(x_454); +x_455 = lean_ctor_get(x_12, 3); +lean_inc(x_455); +x_456 = lean_ctor_get(x_12, 4); +lean_inc(x_456); if (lean_is_exclusive(x_12)) { lean_ctor_release(x_12, 0); lean_ctor_release(x_12, 1); lean_ctor_release(x_12, 2); lean_ctor_release(x_12, 3); lean_ctor_release(x_12, 4); - x_437 = x_12; + x_457 = x_12; } else { lean_dec_ref(x_12); - x_437 = lean_box(0); + x_457 = lean_box(0); } -x_438 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_438, 0, x_245); -lean_ctor_set(x_438, 1, x_20); -x_439 = lean_array_push(x_434, x_438); -if (lean_is_scalar(x_437)) { - x_440 = lean_alloc_ctor(0, 5, 0); +x_458 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_458, 0, x_255); +lean_ctor_set(x_458, 1, x_20); +x_459 = lean_array_push(x_454, x_458); +if (lean_is_scalar(x_457)) { + x_460 = lean_alloc_ctor(0, 5, 0); } else { - x_440 = x_437; + x_460 = x_457; } -lean_ctor_set(x_440, 0, x_432); -lean_ctor_set(x_440, 1, x_433); -lean_ctor_set(x_440, 2, x_439); -lean_ctor_set(x_440, 3, x_435); -lean_ctor_set(x_440, 4, x_436); -x_441 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_30__replaceIndFVarsWithConsts___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_247, x_440, x_431); -if (lean_obj_tag(x_441) == 0) +lean_ctor_set(x_460, 0, x_452); +lean_ctor_set(x_460, 1, x_453); +lean_ctor_set(x_460, 2, x_459); +lean_ctor_set(x_460, 3, x_455); +lean_ctor_set(x_460, 4, x_456); +x_461 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_30__replaceIndFVarsWithConsts___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_257, x_460, x_451); +if (lean_obj_tag(x_461) == 0) { -lean_object* x_442; lean_object* x_443; lean_object* x_444; -x_442 = lean_ctor_get(x_441, 0); -lean_inc(x_442); -x_443 = lean_ctor_get(x_441, 1); -lean_inc(x_443); -lean_dec(x_441); -x_444 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_444, 0, x_442); -x_396 = x_444; -x_397 = x_443; -goto block_428; +lean_object* x_462; lean_object* x_463; lean_object* x_464; +x_462 = lean_ctor_get(x_461, 0); +lean_inc(x_462); +x_463 = lean_ctor_get(x_461, 1); +lean_inc(x_463); +lean_dec(x_461); +x_464 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_464, 0, x_462); +x_414 = x_464; +x_415 = x_463; +goto block_448; } else { -lean_object* x_445; lean_object* x_446; lean_object* x_447; -x_445 = lean_ctor_get(x_441, 0); -lean_inc(x_445); -x_446 = lean_ctor_get(x_441, 1); -lean_inc(x_446); -lean_dec(x_441); -x_447 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_447, 0, x_445); -x_396 = x_447; -x_397 = x_446; -goto block_428; +lean_object* x_465; lean_object* x_466; lean_object* x_467; +x_465 = lean_ctor_get(x_461, 0); +lean_inc(x_465); +x_466 = lean_ctor_get(x_461, 1); +lean_inc(x_466); +lean_dec(x_461); +x_467 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_467, 0, x_465); +x_414 = x_467; +x_415 = x_466; +goto block_448; } -block_428: +block_448: { -if (lean_obj_tag(x_396) == 0) +if (lean_obj_tag(x_414) == 0) { -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; lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_object* x_412; -x_398 = lean_ctor_get(x_397, 2); -lean_inc(x_398); -x_399 = lean_ctor_get(x_396, 0); -lean_inc(x_399); -lean_dec(x_396); -x_400 = lean_ctor_get(x_397, 0); -lean_inc(x_400); -x_401 = lean_ctor_get(x_397, 1); -lean_inc(x_401); -x_402 = lean_ctor_get(x_397, 3); -lean_inc(x_402); -x_403 = lean_ctor_get(x_397, 4); -lean_inc(x_403); -x_404 = lean_ctor_get(x_397, 5); -lean_inc(x_404); -if (lean_is_exclusive(x_397)) { - lean_ctor_release(x_397, 0); - lean_ctor_release(x_397, 1); - lean_ctor_release(x_397, 2); - lean_ctor_release(x_397, 3); - lean_ctor_release(x_397, 4); - lean_ctor_release(x_397, 5); - x_405 = x_397; -} else { - lean_dec_ref(x_397); - x_405 = lean_box(0); -} -x_406 = lean_ctor_get(x_398, 0); -lean_inc(x_406); -x_407 = lean_ctor_get(x_398, 1); -lean_inc(x_407); -x_408 = lean_ctor_get(x_398, 3); -lean_inc(x_408); -if (lean_is_exclusive(x_398)) { - lean_ctor_release(x_398, 0); - lean_ctor_release(x_398, 1); - lean_ctor_release(x_398, 2); - lean_ctor_release(x_398, 3); - x_409 = x_398; -} else { - lean_dec_ref(x_398); - x_409 = lean_box(0); -} -if (lean_is_scalar(x_409)) { - x_410 = lean_alloc_ctor(0, 4, 0); -} else { - x_410 = x_409; -} -lean_ctor_set(x_410, 0, x_406); -lean_ctor_set(x_410, 1, x_407); -lean_ctor_set(x_410, 2, x_393); -lean_ctor_set(x_410, 3, x_408); -if (lean_is_scalar(x_405)) { - x_411 = lean_alloc_ctor(0, 6, 0); -} else { - x_411 = x_405; -} -lean_ctor_set(x_411, 0, x_400); -lean_ctor_set(x_411, 1, x_401); -lean_ctor_set(x_411, 2, x_410); -lean_ctor_set(x_411, 3, x_402); -lean_ctor_set(x_411, 4, x_403); -lean_ctor_set(x_411, 5, x_404); -if (lean_is_scalar(x_244)) { - x_412 = lean_alloc_ctor(1, 2, 0); -} else { - x_412 = x_244; - lean_ctor_set_tag(x_412, 1); -} -lean_ctor_set(x_412, 0, x_399); -lean_ctor_set(x_412, 1, x_411); -return x_412; -} -else -{ -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; lean_object* x_426; lean_object* x_427; -x_413 = lean_ctor_get(x_397, 2); -lean_inc(x_413); -x_414 = lean_ctor_get(x_396, 0); -lean_inc(x_414); -lean_dec(x_396); -x_415 = lean_ctor_get(x_397, 0); -lean_inc(x_415); -x_416 = lean_ctor_get(x_397, 1); +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; lean_object* x_426; lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; +x_416 = lean_ctor_get(x_415, 2); lean_inc(x_416); -x_417 = lean_ctor_get(x_397, 3); +x_417 = lean_ctor_get(x_414, 0); lean_inc(x_417); -x_418 = lean_ctor_get(x_397, 4); +lean_dec(x_414); +x_418 = lean_ctor_get(x_415, 0); lean_inc(x_418); -x_419 = lean_ctor_get(x_397, 5); +x_419 = lean_ctor_get(x_415, 1); lean_inc(x_419); -if (lean_is_exclusive(x_397)) { - lean_ctor_release(x_397, 0); - lean_ctor_release(x_397, 1); - lean_ctor_release(x_397, 2); - lean_ctor_release(x_397, 3); - lean_ctor_release(x_397, 4); - lean_ctor_release(x_397, 5); - x_420 = x_397; -} else { - lean_dec_ref(x_397); - x_420 = lean_box(0); -} -x_421 = lean_ctor_get(x_413, 0); +x_420 = lean_ctor_get(x_415, 3); +lean_inc(x_420); +x_421 = lean_ctor_get(x_415, 4); lean_inc(x_421); -x_422 = lean_ctor_get(x_413, 1); +x_422 = lean_ctor_get(x_415, 5); lean_inc(x_422); -x_423 = lean_ctor_get(x_413, 3); -lean_inc(x_423); -if (lean_is_exclusive(x_413)) { - lean_ctor_release(x_413, 0); - lean_ctor_release(x_413, 1); - lean_ctor_release(x_413, 2); - lean_ctor_release(x_413, 3); - x_424 = x_413; +if (lean_is_exclusive(x_415)) { + lean_ctor_release(x_415, 0); + lean_ctor_release(x_415, 1); + lean_ctor_release(x_415, 2); + lean_ctor_release(x_415, 3); + lean_ctor_release(x_415, 4); + lean_ctor_release(x_415, 5); + x_423 = x_415; } else { - lean_dec_ref(x_413); - x_424 = lean_box(0); + lean_dec_ref(x_415); + x_423 = lean_box(0); } -if (lean_is_scalar(x_424)) { - x_425 = lean_alloc_ctor(0, 4, 0); +x_424 = lean_ctor_get(x_416, 0); +lean_inc(x_424); +x_425 = lean_ctor_get(x_416, 1); +lean_inc(x_425); +x_426 = lean_ctor_get(x_416, 3); +lean_inc(x_426); +x_427 = lean_ctor_get(x_416, 4); +lean_inc(x_427); +if (lean_is_exclusive(x_416)) { + lean_ctor_release(x_416, 0); + lean_ctor_release(x_416, 1); + lean_ctor_release(x_416, 2); + lean_ctor_release(x_416, 3); + lean_ctor_release(x_416, 4); + x_428 = x_416; } else { - x_425 = x_424; + lean_dec_ref(x_416); + x_428 = lean_box(0); } -lean_ctor_set(x_425, 0, x_421); -lean_ctor_set(x_425, 1, x_422); -lean_ctor_set(x_425, 2, x_393); -lean_ctor_set(x_425, 3, x_423); -if (lean_is_scalar(x_420)) { - x_426 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_428)) { + x_429 = lean_alloc_ctor(0, 5, 0); } else { - x_426 = x_420; + x_429 = x_428; } -lean_ctor_set(x_426, 0, x_415); -lean_ctor_set(x_426, 1, x_416); -lean_ctor_set(x_426, 2, x_425); -lean_ctor_set(x_426, 3, x_417); -lean_ctor_set(x_426, 4, x_418); -lean_ctor_set(x_426, 5, x_419); -if (lean_is_scalar(x_244)) { - x_427 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_429, 0, x_424); +lean_ctor_set(x_429, 1, x_425); +lean_ctor_set(x_429, 2, x_410); +lean_ctor_set(x_429, 3, x_426); +lean_ctor_set(x_429, 4, x_427); +if (lean_is_scalar(x_423)) { + x_430 = lean_alloc_ctor(0, 6, 0); } else { - x_427 = x_244; + x_430 = x_423; } -lean_ctor_set(x_427, 0, x_414); -lean_ctor_set(x_427, 1, x_426); -return x_427; +lean_ctor_set(x_430, 0, x_418); +lean_ctor_set(x_430, 1, x_419); +lean_ctor_set(x_430, 2, x_429); +lean_ctor_set(x_430, 3, x_420); +lean_ctor_set(x_430, 4, x_421); +lean_ctor_set(x_430, 5, x_422); +if (lean_is_scalar(x_254)) { + x_431 = lean_alloc_ctor(1, 2, 0); +} else { + x_431 = x_254; + lean_ctor_set_tag(x_431, 1); +} +lean_ctor_set(x_431, 0, x_417); +lean_ctor_set(x_431, 1, x_430); +return x_431; +} +else +{ +lean_object* x_432; lean_object* x_433; lean_object* x_434; lean_object* x_435; lean_object* x_436; lean_object* x_437; lean_object* x_438; lean_object* x_439; lean_object* x_440; lean_object* x_441; lean_object* x_442; lean_object* x_443; lean_object* x_444; lean_object* x_445; lean_object* x_446; lean_object* x_447; +x_432 = lean_ctor_get(x_415, 2); +lean_inc(x_432); +x_433 = lean_ctor_get(x_414, 0); +lean_inc(x_433); +lean_dec(x_414); +x_434 = lean_ctor_get(x_415, 0); +lean_inc(x_434); +x_435 = lean_ctor_get(x_415, 1); +lean_inc(x_435); +x_436 = lean_ctor_get(x_415, 3); +lean_inc(x_436); +x_437 = lean_ctor_get(x_415, 4); +lean_inc(x_437); +x_438 = lean_ctor_get(x_415, 5); +lean_inc(x_438); +if (lean_is_exclusive(x_415)) { + lean_ctor_release(x_415, 0); + lean_ctor_release(x_415, 1); + lean_ctor_release(x_415, 2); + lean_ctor_release(x_415, 3); + lean_ctor_release(x_415, 4); + lean_ctor_release(x_415, 5); + x_439 = x_415; +} else { + lean_dec_ref(x_415); + x_439 = lean_box(0); +} +x_440 = lean_ctor_get(x_432, 0); +lean_inc(x_440); +x_441 = lean_ctor_get(x_432, 1); +lean_inc(x_441); +x_442 = lean_ctor_get(x_432, 3); +lean_inc(x_442); +x_443 = lean_ctor_get(x_432, 4); +lean_inc(x_443); +if (lean_is_exclusive(x_432)) { + lean_ctor_release(x_432, 0); + lean_ctor_release(x_432, 1); + lean_ctor_release(x_432, 2); + lean_ctor_release(x_432, 3); + lean_ctor_release(x_432, 4); + x_444 = x_432; +} else { + lean_dec_ref(x_432); + x_444 = lean_box(0); +} +if (lean_is_scalar(x_444)) { + x_445 = lean_alloc_ctor(0, 5, 0); +} else { + x_445 = x_444; +} +lean_ctor_set(x_445, 0, x_440); +lean_ctor_set(x_445, 1, x_441); +lean_ctor_set(x_445, 2, x_410); +lean_ctor_set(x_445, 3, x_442); +lean_ctor_set(x_445, 4, x_443); +if (lean_is_scalar(x_439)) { + x_446 = lean_alloc_ctor(0, 6, 0); +} else { + x_446 = x_439; +} +lean_ctor_set(x_446, 0, x_434); +lean_ctor_set(x_446, 1, x_435); +lean_ctor_set(x_446, 2, x_445); +lean_ctor_set(x_446, 3, x_436); +lean_ctor_set(x_446, 4, x_437); +lean_ctor_set(x_446, 5, x_438); +if (lean_is_scalar(x_254)) { + x_447 = lean_alloc_ctor(0, 2, 0); +} else { + x_447 = x_254; +} +lean_ctor_set(x_447, 0, x_433); +lean_ctor_set(x_447, 1, x_446); +return x_447; } } } @@ -14213,7 +14361,7 @@ return x_427; } else { -uint8_t x_448; +uint8_t x_468; lean_dec(x_20); lean_dec(x_12); lean_dec(x_11); @@ -14223,23 +14371,23 @@ lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_448 = !lean_is_exclusive(x_237); -if (x_448 == 0) +x_468 = !lean_is_exclusive(x_247); +if (x_468 == 0) { -return x_237; +return x_247; } else { -lean_object* x_449; lean_object* x_450; lean_object* x_451; -x_449 = lean_ctor_get(x_237, 0); -x_450 = lean_ctor_get(x_237, 1); -lean_inc(x_450); -lean_inc(x_449); -lean_dec(x_237); -x_451 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_451, 0, x_449); -lean_ctor_set(x_451, 1, x_450); -return x_451; +lean_object* x_469; lean_object* x_470; lean_object* x_471; +x_469 = lean_ctor_get(x_247, 0); +x_470 = lean_ctor_get(x_247, 1); +lean_inc(x_470); +lean_inc(x_469); +lean_dec(x_247); +x_471 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_471, 0, x_469); +lean_ctor_set(x_471, 1, x_470); +return x_471; } } } @@ -14247,7 +14395,7 @@ return x_451; } else { -uint8_t x_452; +uint8_t x_472; lean_dec(x_24); lean_dec(x_20); lean_dec(x_12); @@ -14258,29 +14406,29 @@ lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_452 = !lean_is_exclusive(x_25); -if (x_452 == 0) +x_472 = !lean_is_exclusive(x_25); +if (x_472 == 0) { return x_25; } else { -lean_object* x_453; lean_object* x_454; lean_object* x_455; -x_453 = lean_ctor_get(x_25, 0); -x_454 = lean_ctor_get(x_25, 1); -lean_inc(x_454); -lean_inc(x_453); +lean_object* x_473; lean_object* x_474; lean_object* x_475; +x_473 = lean_ctor_get(x_25, 0); +x_474 = lean_ctor_get(x_25, 1); +lean_inc(x_474); +lean_inc(x_473); lean_dec(x_25); -x_455 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_455, 0, x_453); -lean_ctor_set(x_455, 1, x_454); -return x_455; +x_475 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_475, 0, x_473); +lean_ctor_set(x_475, 1, x_474); +return x_475; } } } else { -uint8_t x_456; +uint8_t x_476; lean_dec(x_20); lean_dec(x_12); lean_dec(x_11); @@ -14290,23 +14438,23 @@ lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_456 = !lean_is_exclusive(x_21); -if (x_456 == 0) +x_476 = !lean_is_exclusive(x_21); +if (x_476 == 0) { return x_21; } else { -lean_object* x_457; lean_object* x_458; lean_object* x_459; -x_457 = lean_ctor_get(x_21, 0); -x_458 = lean_ctor_get(x_21, 1); -lean_inc(x_458); -lean_inc(x_457); +lean_object* x_477; lean_object* x_478; lean_object* x_479; +x_477 = lean_ctor_get(x_21, 0); +x_478 = lean_ctor_get(x_21, 1); +lean_inc(x_478); +lean_inc(x_477); lean_dec(x_21); -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_479 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_479, 0, x_477); +lean_ctor_set(x_479, 1, x_478); +return x_479; } } } @@ -14400,105 +14548,105 @@ x_32 = lean_ctor_get(x_26, 2); x_33 = !lean_is_exclusive(x_32); if (x_33 == 0) { -lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_86; uint8_t x_87; +lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_90; uint8_t x_91; x_34 = lean_ctor_get(x_32, 2); -x_86 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_32, 2, x_86); -x_87 = !lean_is_exclusive(x_6); -if (x_87 == 0) +x_90 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_32, 2, x_90); +x_91 = !lean_is_exclusive(x_6); +if (x_91 == 0) { -lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; -x_88 = lean_ctor_get(x_6, 2); -x_89 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_89, 0, x_28); -lean_ctor_set(x_89, 1, x_15); -x_90 = lean_array_push(x_88, x_89); -lean_ctor_set(x_6, 2, x_90); -x_91 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_30__replaceIndFVarsWithConsts___spec__6(x_1, x_2, x_3, x_4, x_30, x_6, x_26); -if (lean_obj_tag(x_91) == 0) +lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; +x_92 = lean_ctor_get(x_6, 2); +x_93 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_93, 0, x_28); +lean_ctor_set(x_93, 1, x_15); +x_94 = lean_array_push(x_92, x_93); +lean_ctor_set(x_6, 2, x_94); +x_95 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_30__replaceIndFVarsWithConsts___spec__6(x_1, x_2, x_3, x_4, x_30, x_6, x_26); +if (lean_obj_tag(x_95) == 0) { -lean_object* x_92; lean_object* x_93; lean_object* x_94; -x_92 = lean_ctor_get(x_91, 0); -lean_inc(x_92); -x_93 = lean_ctor_get(x_91, 1); -lean_inc(x_93); -lean_dec(x_91); -x_94 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_94, 0, x_92); -x_35 = x_94; -x_36 = x_93; -goto block_85; -} -else -{ -lean_object* x_95; lean_object* x_96; lean_object* x_97; -x_95 = lean_ctor_get(x_91, 0); -lean_inc(x_95); -x_96 = lean_ctor_get(x_91, 1); +lean_object* x_96; lean_object* x_97; lean_object* x_98; +x_96 = lean_ctor_get(x_95, 0); lean_inc(x_96); -lean_dec(x_91); -x_97 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_97, 0, x_95); -x_35 = x_97; -x_36 = x_96; -goto block_85; -} +x_97 = lean_ctor_get(x_95, 1); +lean_inc(x_97); +lean_dec(x_95); +x_98 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_98, 0, x_96); +x_35 = x_98; +x_36 = x_97; +goto block_89; } else { -lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; -x_98 = lean_ctor_get(x_6, 0); -x_99 = lean_ctor_get(x_6, 1); -x_100 = lean_ctor_get(x_6, 2); -x_101 = lean_ctor_get(x_6, 3); -x_102 = lean_ctor_get(x_6, 4); -lean_inc(x_102); -lean_inc(x_101); -lean_inc(x_100); +lean_object* x_99; lean_object* x_100; lean_object* x_101; +x_99 = lean_ctor_get(x_95, 0); lean_inc(x_99); -lean_inc(x_98); -lean_dec(x_6); -x_103 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_103, 0, x_28); -lean_ctor_set(x_103, 1, x_15); -x_104 = lean_array_push(x_100, x_103); -x_105 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_105, 0, x_98); -lean_ctor_set(x_105, 1, x_99); -lean_ctor_set(x_105, 2, x_104); -lean_ctor_set(x_105, 3, x_101); -lean_ctor_set(x_105, 4, x_102); -x_106 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_30__replaceIndFVarsWithConsts___spec__6(x_1, x_2, x_3, x_4, x_30, x_105, x_26); -if (lean_obj_tag(x_106) == 0) -{ -lean_object* x_107; lean_object* x_108; lean_object* x_109; -x_107 = lean_ctor_get(x_106, 0); -lean_inc(x_107); -x_108 = lean_ctor_get(x_106, 1); -lean_inc(x_108); -lean_dec(x_106); -x_109 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_109, 0, x_107); -x_35 = x_109; -x_36 = x_108; -goto block_85; +x_100 = lean_ctor_get(x_95, 1); +lean_inc(x_100); +lean_dec(x_95); +x_101 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_101, 0, x_99); +x_35 = x_101; +x_36 = x_100; +goto block_89; +} } else { -lean_object* x_110; lean_object* x_111; lean_object* x_112; -x_110 = lean_ctor_get(x_106, 0); -lean_inc(x_110); -x_111 = lean_ctor_get(x_106, 1); +lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; +x_102 = lean_ctor_get(x_6, 0); +x_103 = lean_ctor_get(x_6, 1); +x_104 = lean_ctor_get(x_6, 2); +x_105 = lean_ctor_get(x_6, 3); +x_106 = lean_ctor_get(x_6, 4); +lean_inc(x_106); +lean_inc(x_105); +lean_inc(x_104); +lean_inc(x_103); +lean_inc(x_102); +lean_dec(x_6); +x_107 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_107, 0, x_28); +lean_ctor_set(x_107, 1, x_15); +x_108 = lean_array_push(x_104, x_107); +x_109 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_109, 0, x_102); +lean_ctor_set(x_109, 1, x_103); +lean_ctor_set(x_109, 2, x_108); +lean_ctor_set(x_109, 3, x_105); +lean_ctor_set(x_109, 4, x_106); +x_110 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_30__replaceIndFVarsWithConsts___spec__6(x_1, x_2, x_3, x_4, x_30, x_109, x_26); +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); -lean_dec(x_106); -x_112 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_112, 0, x_110); -x_35 = x_112; -x_36 = x_111; -goto block_85; +x_112 = lean_ctor_get(x_110, 1); +lean_inc(x_112); +lean_dec(x_110); +x_113 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_113, 0, x_111); +x_35 = x_113; +x_36 = x_112; +goto block_89; +} +else +{ +lean_object* x_114; lean_object* x_115; lean_object* x_116; +x_114 = lean_ctor_get(x_110, 0); +lean_inc(x_114); +x_115 = lean_ctor_get(x_110, 1); +lean_inc(x_115); +lean_dec(x_110); +x_116 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_116, 0, x_114); +x_35 = x_116; +x_36 = x_115; +goto block_89; } } -block_85: +block_89: { if (lean_obj_tag(x_35) == 0) { @@ -14533,1284 +14681,1262 @@ return x_43; } else { -lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; +lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; x_44 = lean_ctor_get(x_37, 0); x_45 = lean_ctor_get(x_37, 1); x_46 = lean_ctor_get(x_37, 3); +x_47 = lean_ctor_get(x_37, 4); +lean_inc(x_47); lean_inc(x_46); lean_inc(x_45); lean_inc(x_44); lean_dec(x_37); -x_47 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_47, 0, x_44); -lean_ctor_set(x_47, 1, x_45); -lean_ctor_set(x_47, 2, x_34); -lean_ctor_set(x_47, 3, x_46); -lean_ctor_set(x_36, 2, x_47); +x_48 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_48, 0, x_44); +lean_ctor_set(x_48, 1, x_45); +lean_ctor_set(x_48, 2, x_34); +lean_ctor_set(x_48, 3, x_46); +lean_ctor_set(x_48, 4, x_47); +lean_ctor_set(x_36, 2, x_48); if (lean_is_scalar(x_27)) { - x_48 = lean_alloc_ctor(1, 2, 0); + x_49 = lean_alloc_ctor(1, 2, 0); } else { - x_48 = x_27; - lean_ctor_set_tag(x_48, 1); + x_49 = x_27; + lean_ctor_set_tag(x_49, 1); } -lean_ctor_set(x_48, 0, x_38); -lean_ctor_set(x_48, 1, x_36); -return x_48; +lean_ctor_set(x_49, 0, x_38); +lean_ctor_set(x_49, 1, x_36); +return x_49; } } else { -lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; -x_49 = lean_ctor_get(x_36, 0); -x_50 = lean_ctor_get(x_36, 1); -x_51 = lean_ctor_get(x_36, 3); -x_52 = lean_ctor_get(x_36, 4); -x_53 = lean_ctor_get(x_36, 5); +lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; +x_50 = lean_ctor_get(x_36, 0); +x_51 = lean_ctor_get(x_36, 1); +x_52 = lean_ctor_get(x_36, 3); +x_53 = lean_ctor_get(x_36, 4); +x_54 = lean_ctor_get(x_36, 5); +lean_inc(x_54); lean_inc(x_53); lean_inc(x_52); lean_inc(x_51); lean_inc(x_50); -lean_inc(x_49); lean_dec(x_36); -x_54 = lean_ctor_get(x_37, 0); -lean_inc(x_54); -x_55 = lean_ctor_get(x_37, 1); +x_55 = lean_ctor_get(x_37, 0); lean_inc(x_55); -x_56 = lean_ctor_get(x_37, 3); +x_56 = lean_ctor_get(x_37, 1); lean_inc(x_56); +x_57 = lean_ctor_get(x_37, 3); +lean_inc(x_57); +x_58 = lean_ctor_get(x_37, 4); +lean_inc(x_58); if (lean_is_exclusive(x_37)) { lean_ctor_release(x_37, 0); lean_ctor_release(x_37, 1); lean_ctor_release(x_37, 2); lean_ctor_release(x_37, 3); - x_57 = x_37; + lean_ctor_release(x_37, 4); + x_59 = x_37; } else { lean_dec_ref(x_37); - x_57 = lean_box(0); + x_59 = lean_box(0); } -if (lean_is_scalar(x_57)) { - x_58 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_59)) { + x_60 = lean_alloc_ctor(0, 5, 0); } else { - x_58 = x_57; + x_60 = x_59; } -lean_ctor_set(x_58, 0, x_54); -lean_ctor_set(x_58, 1, x_55); -lean_ctor_set(x_58, 2, x_34); -lean_ctor_set(x_58, 3, x_56); -x_59 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_59, 0, x_49); -lean_ctor_set(x_59, 1, x_50); -lean_ctor_set(x_59, 2, x_58); -lean_ctor_set(x_59, 3, x_51); -lean_ctor_set(x_59, 4, x_52); -lean_ctor_set(x_59, 5, x_53); +lean_ctor_set(x_60, 0, x_55); +lean_ctor_set(x_60, 1, x_56); +lean_ctor_set(x_60, 2, x_34); +lean_ctor_set(x_60, 3, x_57); +lean_ctor_set(x_60, 4, x_58); +x_61 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_61, 0, x_50); +lean_ctor_set(x_61, 1, x_51); +lean_ctor_set(x_61, 2, x_60); +lean_ctor_set(x_61, 3, x_52); +lean_ctor_set(x_61, 4, x_53); +lean_ctor_set(x_61, 5, x_54); if (lean_is_scalar(x_27)) { - x_60 = lean_alloc_ctor(1, 2, 0); + x_62 = lean_alloc_ctor(1, 2, 0); } else { - x_60 = x_27; - lean_ctor_set_tag(x_60, 1); + x_62 = x_27; + lean_ctor_set_tag(x_62, 1); } -lean_ctor_set(x_60, 0, x_38); -lean_ctor_set(x_60, 1, x_59); -return x_60; +lean_ctor_set(x_62, 0, x_38); +lean_ctor_set(x_62, 1, x_61); +return x_62; } } else { -lean_object* x_61; lean_object* x_62; uint8_t x_63; -x_61 = lean_ctor_get(x_36, 2); -lean_inc(x_61); -x_62 = lean_ctor_get(x_35, 0); -lean_inc(x_62); +lean_object* x_63; lean_object* x_64; uint8_t x_65; +x_63 = lean_ctor_get(x_36, 2); +lean_inc(x_63); +x_64 = lean_ctor_get(x_35, 0); +lean_inc(x_64); lean_dec(x_35); -x_63 = !lean_is_exclusive(x_36); -if (x_63 == 0) -{ -lean_object* x_64; uint8_t x_65; -x_64 = lean_ctor_get(x_36, 2); -lean_dec(x_64); -x_65 = !lean_is_exclusive(x_61); +x_65 = !lean_is_exclusive(x_36); if (x_65 == 0) { -lean_object* x_66; lean_object* x_67; -x_66 = lean_ctor_get(x_61, 2); +lean_object* x_66; uint8_t x_67; +x_66 = lean_ctor_get(x_36, 2); lean_dec(x_66); -lean_ctor_set(x_61, 2, x_34); +x_67 = !lean_is_exclusive(x_63); +if (x_67 == 0) +{ +lean_object* x_68; lean_object* x_69; +x_68 = lean_ctor_get(x_63, 2); +lean_dec(x_68); +lean_ctor_set(x_63, 2, x_34); if (lean_is_scalar(x_27)) { - x_67 = lean_alloc_ctor(0, 2, 0); + x_69 = lean_alloc_ctor(0, 2, 0); } else { - x_67 = x_27; + x_69 = x_27; } -lean_ctor_set(x_67, 0, x_62); -lean_ctor_set(x_67, 1, x_36); -return x_67; +lean_ctor_set(x_69, 0, x_64); +lean_ctor_set(x_69, 1, x_36); +return x_69; } else { -lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; -x_68 = lean_ctor_get(x_61, 0); -x_69 = lean_ctor_get(x_61, 1); -x_70 = lean_ctor_get(x_61, 3); +lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; +x_70 = lean_ctor_get(x_63, 0); +x_71 = lean_ctor_get(x_63, 1); +x_72 = lean_ctor_get(x_63, 3); +x_73 = lean_ctor_get(x_63, 4); +lean_inc(x_73); +lean_inc(x_72); +lean_inc(x_71); lean_inc(x_70); -lean_inc(x_69); -lean_inc(x_68); -lean_dec(x_61); -x_71 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_71, 0, x_68); -lean_ctor_set(x_71, 1, x_69); -lean_ctor_set(x_71, 2, x_34); -lean_ctor_set(x_71, 3, x_70); -lean_ctor_set(x_36, 2, x_71); +lean_dec(x_63); +x_74 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_74, 0, x_70); +lean_ctor_set(x_74, 1, x_71); +lean_ctor_set(x_74, 2, x_34); +lean_ctor_set(x_74, 3, x_72); +lean_ctor_set(x_74, 4, x_73); +lean_ctor_set(x_36, 2, x_74); if (lean_is_scalar(x_27)) { - x_72 = lean_alloc_ctor(0, 2, 0); + x_75 = lean_alloc_ctor(0, 2, 0); } else { - x_72 = x_27; + x_75 = x_27; } -lean_ctor_set(x_72, 0, x_62); -lean_ctor_set(x_72, 1, x_36); -return x_72; +lean_ctor_set(x_75, 0, x_64); +lean_ctor_set(x_75, 1, x_36); +return x_75; } } else { -lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; -x_73 = lean_ctor_get(x_36, 0); -x_74 = lean_ctor_get(x_36, 1); -x_75 = lean_ctor_get(x_36, 3); -x_76 = lean_ctor_get(x_36, 4); -x_77 = lean_ctor_get(x_36, 5); +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; +x_76 = lean_ctor_get(x_36, 0); +x_77 = lean_ctor_get(x_36, 1); +x_78 = lean_ctor_get(x_36, 3); +x_79 = lean_ctor_get(x_36, 4); +x_80 = lean_ctor_get(x_36, 5); +lean_inc(x_80); +lean_inc(x_79); +lean_inc(x_78); lean_inc(x_77); lean_inc(x_76); -lean_inc(x_75); -lean_inc(x_74); -lean_inc(x_73); lean_dec(x_36); -x_78 = lean_ctor_get(x_61, 0); -lean_inc(x_78); -x_79 = lean_ctor_get(x_61, 1); -lean_inc(x_79); -x_80 = lean_ctor_get(x_61, 3); -lean_inc(x_80); -if (lean_is_exclusive(x_61)) { - lean_ctor_release(x_61, 0); - lean_ctor_release(x_61, 1); - lean_ctor_release(x_61, 2); - lean_ctor_release(x_61, 3); - x_81 = x_61; +x_81 = lean_ctor_get(x_63, 0); +lean_inc(x_81); +x_82 = lean_ctor_get(x_63, 1); +lean_inc(x_82); +x_83 = lean_ctor_get(x_63, 3); +lean_inc(x_83); +x_84 = lean_ctor_get(x_63, 4); +lean_inc(x_84); +if (lean_is_exclusive(x_63)) { + lean_ctor_release(x_63, 0); + lean_ctor_release(x_63, 1); + lean_ctor_release(x_63, 2); + lean_ctor_release(x_63, 3); + lean_ctor_release(x_63, 4); + x_85 = x_63; } else { - lean_dec_ref(x_61); - x_81 = lean_box(0); + lean_dec_ref(x_63); + x_85 = lean_box(0); } -if (lean_is_scalar(x_81)) { - x_82 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_85)) { + x_86 = lean_alloc_ctor(0, 5, 0); } else { - x_82 = x_81; + x_86 = x_85; } -lean_ctor_set(x_82, 0, x_78); -lean_ctor_set(x_82, 1, x_79); -lean_ctor_set(x_82, 2, x_34); -lean_ctor_set(x_82, 3, x_80); -x_83 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_83, 0, x_73); -lean_ctor_set(x_83, 1, x_74); -lean_ctor_set(x_83, 2, x_82); -lean_ctor_set(x_83, 3, x_75); -lean_ctor_set(x_83, 4, x_76); -lean_ctor_set(x_83, 5, x_77); +lean_ctor_set(x_86, 0, x_81); +lean_ctor_set(x_86, 1, x_82); +lean_ctor_set(x_86, 2, x_34); +lean_ctor_set(x_86, 3, x_83); +lean_ctor_set(x_86, 4, x_84); +x_87 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_87, 0, x_76); +lean_ctor_set(x_87, 1, x_77); +lean_ctor_set(x_87, 2, x_86); +lean_ctor_set(x_87, 3, x_78); +lean_ctor_set(x_87, 4, x_79); +lean_ctor_set(x_87, 5, x_80); if (lean_is_scalar(x_27)) { - x_84 = lean_alloc_ctor(0, 2, 0); + x_88 = lean_alloc_ctor(0, 2, 0); } else { - x_84 = x_27; + x_88 = x_27; } -lean_ctor_set(x_84, 0, x_62); -lean_ctor_set(x_84, 1, x_83); -return x_84; +lean_ctor_set(x_88, 0, x_64); +lean_ctor_set(x_88, 1, x_87); +return x_88; } } } } else { -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_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; -x_113 = lean_ctor_get(x_32, 0); -x_114 = lean_ctor_get(x_32, 1); -x_115 = lean_ctor_get(x_32, 2); -x_116 = lean_ctor_get(x_32, 3); -lean_inc(x_116); -lean_inc(x_115); -lean_inc(x_114); -lean_inc(x_113); -lean_dec(x_32); -x_150 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_151 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_151, 0, x_113); -lean_ctor_set(x_151, 1, x_114); -lean_ctor_set(x_151, 2, x_150); -lean_ctor_set(x_151, 3, x_116); -lean_ctor_set(x_26, 2, x_151); -x_152 = lean_ctor_get(x_6, 0); -lean_inc(x_152); -x_153 = lean_ctor_get(x_6, 1); -lean_inc(x_153); -x_154 = lean_ctor_get(x_6, 2); -lean_inc(x_154); -x_155 = lean_ctor_get(x_6, 3); -lean_inc(x_155); -x_156 = lean_ctor_get(x_6, 4); -lean_inc(x_156); -if (lean_is_exclusive(x_6)) { - lean_ctor_release(x_6, 0); - lean_ctor_release(x_6, 1); - lean_ctor_release(x_6, 2); - lean_ctor_release(x_6, 3); - lean_ctor_release(x_6, 4); - x_157 = x_6; -} else { - lean_dec_ref(x_6); - x_157 = lean_box(0); -} -x_158 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_158, 0, x_28); -lean_ctor_set(x_158, 1, x_15); -x_159 = lean_array_push(x_154, x_158); -if (lean_is_scalar(x_157)) { - x_160 = lean_alloc_ctor(0, 5, 0); -} else { - x_160 = x_157; -} -lean_ctor_set(x_160, 0, x_152); -lean_ctor_set(x_160, 1, x_153); -lean_ctor_set(x_160, 2, x_159); -lean_ctor_set(x_160, 3, x_155); -lean_ctor_set(x_160, 4, x_156); -x_161 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_30__replaceIndFVarsWithConsts___spec__6(x_1, x_2, x_3, x_4, x_30, x_160, x_26); -if (lean_obj_tag(x_161) == 0) -{ -lean_object* x_162; lean_object* x_163; lean_object* x_164; -x_162 = lean_ctor_get(x_161, 0); -lean_inc(x_162); -x_163 = lean_ctor_get(x_161, 1); -lean_inc(x_163); -lean_dec(x_161); -x_164 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_164, 0, x_162); -x_117 = x_164; -x_118 = x_163; -goto block_149; -} -else -{ -lean_object* x_165; lean_object* x_166; lean_object* x_167; -x_165 = lean_ctor_get(x_161, 0); -lean_inc(x_165); -x_166 = lean_ctor_get(x_161, 1); -lean_inc(x_166); -lean_dec(x_161); -x_167 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_167, 0, x_165); -x_117 = x_167; -x_118 = x_166; -goto block_149; -} -block_149: -{ -if (lean_obj_tag(x_117) == 0) -{ -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; -x_119 = lean_ctor_get(x_118, 2); -lean_inc(x_119); -x_120 = lean_ctor_get(x_117, 0); -lean_inc(x_120); -lean_dec(x_117); -x_121 = lean_ctor_get(x_118, 0); +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_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_117 = lean_ctor_get(x_32, 0); +x_118 = lean_ctor_get(x_32, 1); +x_119 = lean_ctor_get(x_32, 2); +x_120 = lean_ctor_get(x_32, 3); +x_121 = lean_ctor_get(x_32, 4); lean_inc(x_121); -x_122 = lean_ctor_get(x_118, 1); -lean_inc(x_122); -x_123 = lean_ctor_get(x_118, 3); -lean_inc(x_123); -x_124 = lean_ctor_get(x_118, 4); -lean_inc(x_124); -x_125 = lean_ctor_get(x_118, 5); -lean_inc(x_125); -if (lean_is_exclusive(x_118)) { - lean_ctor_release(x_118, 0); - lean_ctor_release(x_118, 1); - lean_ctor_release(x_118, 2); - lean_ctor_release(x_118, 3); - lean_ctor_release(x_118, 4); - lean_ctor_release(x_118, 5); - x_126 = x_118; -} else { - lean_dec_ref(x_118); - x_126 = lean_box(0); -} -x_127 = lean_ctor_get(x_119, 0); -lean_inc(x_127); -x_128 = lean_ctor_get(x_119, 1); -lean_inc(x_128); -x_129 = lean_ctor_get(x_119, 3); -lean_inc(x_129); -if (lean_is_exclusive(x_119)) { - lean_ctor_release(x_119, 0); - lean_ctor_release(x_119, 1); - lean_ctor_release(x_119, 2); - lean_ctor_release(x_119, 3); - x_130 = x_119; -} else { - lean_dec_ref(x_119); - x_130 = lean_box(0); -} -if (lean_is_scalar(x_130)) { - x_131 = lean_alloc_ctor(0, 4, 0); -} else { - x_131 = x_130; -} -lean_ctor_set(x_131, 0, x_127); -lean_ctor_set(x_131, 1, x_128); -lean_ctor_set(x_131, 2, x_115); -lean_ctor_set(x_131, 3, x_129); -if (lean_is_scalar(x_126)) { - x_132 = lean_alloc_ctor(0, 6, 0); -} else { - x_132 = x_126; -} -lean_ctor_set(x_132, 0, x_121); -lean_ctor_set(x_132, 1, x_122); -lean_ctor_set(x_132, 2, x_131); -lean_ctor_set(x_132, 3, x_123); -lean_ctor_set(x_132, 4, x_124); -lean_ctor_set(x_132, 5, x_125); -if (lean_is_scalar(x_27)) { - x_133 = lean_alloc_ctor(1, 2, 0); -} else { - x_133 = x_27; - lean_ctor_set_tag(x_133, 1); -} -lean_ctor_set(x_133, 0, x_120); -lean_ctor_set(x_133, 1, x_132); -return x_133; -} -else -{ -lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; 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; -x_134 = lean_ctor_get(x_118, 2); -lean_inc(x_134); -x_135 = lean_ctor_get(x_117, 0); -lean_inc(x_135); -lean_dec(x_117); -x_136 = lean_ctor_get(x_118, 0); -lean_inc(x_136); -x_137 = lean_ctor_get(x_118, 1); -lean_inc(x_137); -x_138 = lean_ctor_get(x_118, 3); -lean_inc(x_138); -x_139 = lean_ctor_get(x_118, 4); -lean_inc(x_139); -x_140 = lean_ctor_get(x_118, 5); -lean_inc(x_140); -if (lean_is_exclusive(x_118)) { - lean_ctor_release(x_118, 0); - lean_ctor_release(x_118, 1); - lean_ctor_release(x_118, 2); - lean_ctor_release(x_118, 3); - lean_ctor_release(x_118, 4); - lean_ctor_release(x_118, 5); - x_141 = x_118; -} else { - lean_dec_ref(x_118); - x_141 = lean_box(0); -} -x_142 = lean_ctor_get(x_134, 0); -lean_inc(x_142); -x_143 = lean_ctor_get(x_134, 1); -lean_inc(x_143); -x_144 = lean_ctor_get(x_134, 3); -lean_inc(x_144); -if (lean_is_exclusive(x_134)) { - lean_ctor_release(x_134, 0); - lean_ctor_release(x_134, 1); - lean_ctor_release(x_134, 2); - lean_ctor_release(x_134, 3); - x_145 = x_134; -} else { - lean_dec_ref(x_134); - x_145 = lean_box(0); -} -if (lean_is_scalar(x_145)) { - x_146 = lean_alloc_ctor(0, 4, 0); -} else { - x_146 = x_145; -} -lean_ctor_set(x_146, 0, x_142); -lean_ctor_set(x_146, 1, x_143); -lean_ctor_set(x_146, 2, x_115); -lean_ctor_set(x_146, 3, x_144); -if (lean_is_scalar(x_141)) { - x_147 = lean_alloc_ctor(0, 6, 0); -} else { - x_147 = x_141; -} -lean_ctor_set(x_147, 0, x_136); -lean_ctor_set(x_147, 1, x_137); -lean_ctor_set(x_147, 2, x_146); -lean_ctor_set(x_147, 3, x_138); -lean_ctor_set(x_147, 4, x_139); -lean_ctor_set(x_147, 5, x_140); -if (lean_is_scalar(x_27)) { - x_148 = lean_alloc_ctor(0, 2, 0); -} else { - x_148 = x_27; -} -lean_ctor_set(x_148, 0, x_135); -lean_ctor_set(x_148, 1, x_147); -return x_148; -} -} -} -} -else -{ -lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; lean_object* x_173; lean_object* x_174; lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; lean_object* x_224; -x_168 = lean_ctor_get(x_26, 2); -x_169 = lean_ctor_get(x_26, 0); -x_170 = lean_ctor_get(x_26, 1); -x_171 = lean_ctor_get(x_26, 3); -x_172 = lean_ctor_get(x_26, 4); -x_173 = lean_ctor_get(x_26, 5); -lean_inc(x_173); -lean_inc(x_172); -lean_inc(x_171); -lean_inc(x_168); -lean_inc(x_170); -lean_inc(x_169); -lean_dec(x_26); -x_174 = lean_ctor_get(x_168, 0); -lean_inc(x_174); -x_175 = lean_ctor_get(x_168, 1); -lean_inc(x_175); -x_176 = lean_ctor_get(x_168, 2); -lean_inc(x_176); -x_177 = lean_ctor_get(x_168, 3); -lean_inc(x_177); -if (lean_is_exclusive(x_168)) { - lean_ctor_release(x_168, 0); - lean_ctor_release(x_168, 1); - lean_ctor_release(x_168, 2); - lean_ctor_release(x_168, 3); - x_178 = x_168; -} else { - lean_dec_ref(x_168); - x_178 = lean_box(0); -} -x_212 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_178)) { - x_213 = lean_alloc_ctor(0, 4, 0); -} else { - x_213 = x_178; -} -lean_ctor_set(x_213, 0, x_174); -lean_ctor_set(x_213, 1, x_175); -lean_ctor_set(x_213, 2, x_212); -lean_ctor_set(x_213, 3, x_177); -x_214 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_214, 0, x_169); -lean_ctor_set(x_214, 1, x_170); -lean_ctor_set(x_214, 2, x_213); -lean_ctor_set(x_214, 3, x_171); -lean_ctor_set(x_214, 4, x_172); -lean_ctor_set(x_214, 5, x_173); -x_215 = lean_ctor_get(x_6, 0); -lean_inc(x_215); -x_216 = lean_ctor_get(x_6, 1); -lean_inc(x_216); -x_217 = lean_ctor_get(x_6, 2); -lean_inc(x_217); -x_218 = lean_ctor_get(x_6, 3); -lean_inc(x_218); -x_219 = lean_ctor_get(x_6, 4); -lean_inc(x_219); +lean_inc(x_120); +lean_inc(x_119); +lean_inc(x_118); +lean_inc(x_117); +lean_dec(x_32); +x_157 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_158 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_158, 0, x_117); +lean_ctor_set(x_158, 1, x_118); +lean_ctor_set(x_158, 2, x_157); +lean_ctor_set(x_158, 3, x_120); +lean_ctor_set(x_158, 4, x_121); +lean_ctor_set(x_26, 2, x_158); +x_159 = lean_ctor_get(x_6, 0); +lean_inc(x_159); +x_160 = lean_ctor_get(x_6, 1); +lean_inc(x_160); +x_161 = lean_ctor_get(x_6, 2); +lean_inc(x_161); +x_162 = lean_ctor_get(x_6, 3); +lean_inc(x_162); +x_163 = lean_ctor_get(x_6, 4); +lean_inc(x_163); if (lean_is_exclusive(x_6)) { lean_ctor_release(x_6, 0); lean_ctor_release(x_6, 1); lean_ctor_release(x_6, 2); lean_ctor_release(x_6, 3); lean_ctor_release(x_6, 4); - x_220 = x_6; + x_164 = x_6; } else { lean_dec_ref(x_6); - x_220 = lean_box(0); + x_164 = lean_box(0); } -x_221 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_221, 0, x_28); -lean_ctor_set(x_221, 1, x_15); -x_222 = lean_array_push(x_217, x_221); -if (lean_is_scalar(x_220)) { +x_165 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_165, 0, x_28); +lean_ctor_set(x_165, 1, x_15); +x_166 = lean_array_push(x_161, x_165); +if (lean_is_scalar(x_164)) { + x_167 = lean_alloc_ctor(0, 5, 0); +} else { + x_167 = x_164; +} +lean_ctor_set(x_167, 0, x_159); +lean_ctor_set(x_167, 1, x_160); +lean_ctor_set(x_167, 2, x_166); +lean_ctor_set(x_167, 3, x_162); +lean_ctor_set(x_167, 4, x_163); +x_168 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_30__replaceIndFVarsWithConsts___spec__6(x_1, x_2, x_3, x_4, x_30, x_167, x_26); +if (lean_obj_tag(x_168) == 0) +{ +lean_object* x_169; lean_object* x_170; lean_object* x_171; +x_169 = lean_ctor_get(x_168, 0); +lean_inc(x_169); +x_170 = lean_ctor_get(x_168, 1); +lean_inc(x_170); +lean_dec(x_168); +x_171 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_171, 0, x_169); +x_122 = x_171; +x_123 = x_170; +goto block_156; +} +else +{ +lean_object* x_172; lean_object* x_173; lean_object* x_174; +x_172 = lean_ctor_get(x_168, 0); +lean_inc(x_172); +x_173 = lean_ctor_get(x_168, 1); +lean_inc(x_173); +lean_dec(x_168); +x_174 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_174, 0, x_172); +x_122 = x_174; +x_123 = x_173; +goto block_156; +} +block_156: +{ +if (lean_obj_tag(x_122) == 0) +{ +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; +x_124 = lean_ctor_get(x_123, 2); +lean_inc(x_124); +x_125 = lean_ctor_get(x_122, 0); +lean_inc(x_125); +lean_dec(x_122); +x_126 = lean_ctor_get(x_123, 0); +lean_inc(x_126); +x_127 = lean_ctor_get(x_123, 1); +lean_inc(x_127); +x_128 = lean_ctor_get(x_123, 3); +lean_inc(x_128); +x_129 = lean_ctor_get(x_123, 4); +lean_inc(x_129); +x_130 = lean_ctor_get(x_123, 5); +lean_inc(x_130); +if (lean_is_exclusive(x_123)) { + lean_ctor_release(x_123, 0); + lean_ctor_release(x_123, 1); + lean_ctor_release(x_123, 2); + lean_ctor_release(x_123, 3); + lean_ctor_release(x_123, 4); + lean_ctor_release(x_123, 5); + x_131 = x_123; +} else { + lean_dec_ref(x_123); + x_131 = lean_box(0); +} +x_132 = lean_ctor_get(x_124, 0); +lean_inc(x_132); +x_133 = lean_ctor_get(x_124, 1); +lean_inc(x_133); +x_134 = lean_ctor_get(x_124, 3); +lean_inc(x_134); +x_135 = lean_ctor_get(x_124, 4); +lean_inc(x_135); +if (lean_is_exclusive(x_124)) { + lean_ctor_release(x_124, 0); + lean_ctor_release(x_124, 1); + lean_ctor_release(x_124, 2); + lean_ctor_release(x_124, 3); + lean_ctor_release(x_124, 4); + x_136 = x_124; +} else { + lean_dec_ref(x_124); + x_136 = lean_box(0); +} +if (lean_is_scalar(x_136)) { + x_137 = lean_alloc_ctor(0, 5, 0); +} else { + x_137 = x_136; +} +lean_ctor_set(x_137, 0, x_132); +lean_ctor_set(x_137, 1, x_133); +lean_ctor_set(x_137, 2, x_119); +lean_ctor_set(x_137, 3, x_134); +lean_ctor_set(x_137, 4, x_135); +if (lean_is_scalar(x_131)) { + x_138 = lean_alloc_ctor(0, 6, 0); +} else { + x_138 = x_131; +} +lean_ctor_set(x_138, 0, x_126); +lean_ctor_set(x_138, 1, x_127); +lean_ctor_set(x_138, 2, x_137); +lean_ctor_set(x_138, 3, x_128); +lean_ctor_set(x_138, 4, x_129); +lean_ctor_set(x_138, 5, x_130); +if (lean_is_scalar(x_27)) { + x_139 = lean_alloc_ctor(1, 2, 0); +} else { + x_139 = x_27; + lean_ctor_set_tag(x_139, 1); +} +lean_ctor_set(x_139, 0, x_125); +lean_ctor_set(x_139, 1, x_138); +return x_139; +} +else +{ +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; +x_140 = lean_ctor_get(x_123, 2); +lean_inc(x_140); +x_141 = lean_ctor_get(x_122, 0); +lean_inc(x_141); +lean_dec(x_122); +x_142 = lean_ctor_get(x_123, 0); +lean_inc(x_142); +x_143 = lean_ctor_get(x_123, 1); +lean_inc(x_143); +x_144 = lean_ctor_get(x_123, 3); +lean_inc(x_144); +x_145 = lean_ctor_get(x_123, 4); +lean_inc(x_145); +x_146 = lean_ctor_get(x_123, 5); +lean_inc(x_146); +if (lean_is_exclusive(x_123)) { + lean_ctor_release(x_123, 0); + lean_ctor_release(x_123, 1); + lean_ctor_release(x_123, 2); + lean_ctor_release(x_123, 3); + lean_ctor_release(x_123, 4); + lean_ctor_release(x_123, 5); + x_147 = x_123; +} else { + lean_dec_ref(x_123); + x_147 = lean_box(0); +} +x_148 = lean_ctor_get(x_140, 0); +lean_inc(x_148); +x_149 = lean_ctor_get(x_140, 1); +lean_inc(x_149); +x_150 = lean_ctor_get(x_140, 3); +lean_inc(x_150); +x_151 = lean_ctor_get(x_140, 4); +lean_inc(x_151); +if (lean_is_exclusive(x_140)) { + lean_ctor_release(x_140, 0); + lean_ctor_release(x_140, 1); + lean_ctor_release(x_140, 2); + lean_ctor_release(x_140, 3); + lean_ctor_release(x_140, 4); + x_152 = x_140; +} else { + lean_dec_ref(x_140); + x_152 = lean_box(0); +} +if (lean_is_scalar(x_152)) { + x_153 = lean_alloc_ctor(0, 5, 0); +} else { + x_153 = x_152; +} +lean_ctor_set(x_153, 0, x_148); +lean_ctor_set(x_153, 1, x_149); +lean_ctor_set(x_153, 2, x_119); +lean_ctor_set(x_153, 3, x_150); +lean_ctor_set(x_153, 4, x_151); +if (lean_is_scalar(x_147)) { + x_154 = lean_alloc_ctor(0, 6, 0); +} else { + x_154 = x_147; +} +lean_ctor_set(x_154, 0, x_142); +lean_ctor_set(x_154, 1, x_143); +lean_ctor_set(x_154, 2, x_153); +lean_ctor_set(x_154, 3, x_144); +lean_ctor_set(x_154, 4, x_145); +lean_ctor_set(x_154, 5, x_146); +if (lean_is_scalar(x_27)) { + x_155 = lean_alloc_ctor(0, 2, 0); +} else { + x_155 = x_27; +} +lean_ctor_set(x_155, 0, x_141); +lean_ctor_set(x_155, 1, x_154); +return x_155; +} +} +} +} +else +{ +lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; 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; lean_object* x_231; lean_object* x_232; lean_object* x_233; lean_object* x_234; +x_175 = lean_ctor_get(x_26, 2); +x_176 = lean_ctor_get(x_26, 0); +x_177 = lean_ctor_get(x_26, 1); +x_178 = lean_ctor_get(x_26, 3); +x_179 = lean_ctor_get(x_26, 4); +x_180 = lean_ctor_get(x_26, 5); +lean_inc(x_180); +lean_inc(x_179); +lean_inc(x_178); +lean_inc(x_175); +lean_inc(x_177); +lean_inc(x_176); +lean_dec(x_26); +x_181 = lean_ctor_get(x_175, 0); +lean_inc(x_181); +x_182 = lean_ctor_get(x_175, 1); +lean_inc(x_182); +x_183 = lean_ctor_get(x_175, 2); +lean_inc(x_183); +x_184 = lean_ctor_get(x_175, 3); +lean_inc(x_184); +x_185 = lean_ctor_get(x_175, 4); +lean_inc(x_185); +if (lean_is_exclusive(x_175)) { + lean_ctor_release(x_175, 0); + lean_ctor_release(x_175, 1); + lean_ctor_release(x_175, 2); + lean_ctor_release(x_175, 3); + lean_ctor_release(x_175, 4); + x_186 = x_175; +} else { + lean_dec_ref(x_175); + x_186 = lean_box(0); +} +x_222 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_186)) { x_223 = lean_alloc_ctor(0, 5, 0); } else { - x_223 = x_220; + x_223 = x_186; } -lean_ctor_set(x_223, 0, x_215); -lean_ctor_set(x_223, 1, x_216); +lean_ctor_set(x_223, 0, x_181); +lean_ctor_set(x_223, 1, x_182); lean_ctor_set(x_223, 2, x_222); -lean_ctor_set(x_223, 3, x_218); -lean_ctor_set(x_223, 4, x_219); -x_224 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_30__replaceIndFVarsWithConsts___spec__6(x_1, x_2, x_3, x_4, x_30, x_223, x_214); -if (lean_obj_tag(x_224) == 0) -{ -lean_object* x_225; lean_object* x_226; lean_object* x_227; -x_225 = lean_ctor_get(x_224, 0); +lean_ctor_set(x_223, 3, x_184); +lean_ctor_set(x_223, 4, x_185); +x_224 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_224, 0, x_176); +lean_ctor_set(x_224, 1, x_177); +lean_ctor_set(x_224, 2, x_223); +lean_ctor_set(x_224, 3, x_178); +lean_ctor_set(x_224, 4, x_179); +lean_ctor_set(x_224, 5, x_180); +x_225 = lean_ctor_get(x_6, 0); lean_inc(x_225); -x_226 = lean_ctor_get(x_224, 1); +x_226 = lean_ctor_get(x_6, 1); lean_inc(x_226); -lean_dec(x_224); -x_227 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_227, 0, x_225); -x_179 = x_227; -x_180 = x_226; -goto block_211; -} -else -{ -lean_object* x_228; lean_object* x_229; lean_object* x_230; -x_228 = lean_ctor_get(x_224, 0); +x_227 = lean_ctor_get(x_6, 2); +lean_inc(x_227); +x_228 = lean_ctor_get(x_6, 3); lean_inc(x_228); -x_229 = lean_ctor_get(x_224, 1); +x_229 = lean_ctor_get(x_6, 4); lean_inc(x_229); -lean_dec(x_224); -x_230 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_230, 0, x_228); -x_179 = x_230; -x_180 = x_229; -goto block_211; +if (lean_is_exclusive(x_6)) { + lean_ctor_release(x_6, 0); + lean_ctor_release(x_6, 1); + lean_ctor_release(x_6, 2); + lean_ctor_release(x_6, 3); + lean_ctor_release(x_6, 4); + x_230 = x_6; +} else { + lean_dec_ref(x_6); + x_230 = lean_box(0); } -block_211: +x_231 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_231, 0, x_28); +lean_ctor_set(x_231, 1, x_15); +x_232 = lean_array_push(x_227, x_231); +if (lean_is_scalar(x_230)) { + x_233 = lean_alloc_ctor(0, 5, 0); +} else { + x_233 = x_230; +} +lean_ctor_set(x_233, 0, x_225); +lean_ctor_set(x_233, 1, x_226); +lean_ctor_set(x_233, 2, x_232); +lean_ctor_set(x_233, 3, x_228); +lean_ctor_set(x_233, 4, x_229); +x_234 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_30__replaceIndFVarsWithConsts___spec__6(x_1, x_2, x_3, x_4, x_30, x_233, x_224); +if (lean_obj_tag(x_234) == 0) { -if (lean_obj_tag(x_179) == 0) -{ -lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; -x_181 = lean_ctor_get(x_180, 2); -lean_inc(x_181); -x_182 = lean_ctor_get(x_179, 0); -lean_inc(x_182); -lean_dec(x_179); -x_183 = lean_ctor_get(x_180, 0); -lean_inc(x_183); -x_184 = lean_ctor_get(x_180, 1); -lean_inc(x_184); -x_185 = lean_ctor_get(x_180, 3); -lean_inc(x_185); -x_186 = lean_ctor_get(x_180, 4); -lean_inc(x_186); -x_187 = lean_ctor_get(x_180, 5); -lean_inc(x_187); -if (lean_is_exclusive(x_180)) { - lean_ctor_release(x_180, 0); - lean_ctor_release(x_180, 1); - lean_ctor_release(x_180, 2); - lean_ctor_release(x_180, 3); - lean_ctor_release(x_180, 4); - lean_ctor_release(x_180, 5); - x_188 = x_180; -} else { - lean_dec_ref(x_180); - x_188 = lean_box(0); -} -x_189 = lean_ctor_get(x_181, 0); -lean_inc(x_189); -x_190 = lean_ctor_get(x_181, 1); -lean_inc(x_190); -x_191 = lean_ctor_get(x_181, 3); -lean_inc(x_191); -if (lean_is_exclusive(x_181)) { - lean_ctor_release(x_181, 0); - lean_ctor_release(x_181, 1); - lean_ctor_release(x_181, 2); - lean_ctor_release(x_181, 3); - x_192 = x_181; -} else { - lean_dec_ref(x_181); - x_192 = lean_box(0); -} -if (lean_is_scalar(x_192)) { - x_193 = lean_alloc_ctor(0, 4, 0); -} else { - x_193 = x_192; -} -lean_ctor_set(x_193, 0, x_189); -lean_ctor_set(x_193, 1, x_190); -lean_ctor_set(x_193, 2, x_176); -lean_ctor_set(x_193, 3, x_191); -if (lean_is_scalar(x_188)) { - x_194 = lean_alloc_ctor(0, 6, 0); -} else { - x_194 = x_188; -} -lean_ctor_set(x_194, 0, x_183); -lean_ctor_set(x_194, 1, x_184); -lean_ctor_set(x_194, 2, x_193); -lean_ctor_set(x_194, 3, x_185); -lean_ctor_set(x_194, 4, x_186); -lean_ctor_set(x_194, 5, x_187); -if (lean_is_scalar(x_27)) { - x_195 = lean_alloc_ctor(1, 2, 0); -} else { - x_195 = x_27; - lean_ctor_set_tag(x_195, 1); -} -lean_ctor_set(x_195, 0, x_182); -lean_ctor_set(x_195, 1, x_194); -return x_195; +lean_object* x_235; lean_object* x_236; lean_object* x_237; +x_235 = lean_ctor_get(x_234, 0); +lean_inc(x_235); +x_236 = lean_ctor_get(x_234, 1); +lean_inc(x_236); +lean_dec(x_234); +x_237 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_237, 0, x_235); +x_187 = x_237; +x_188 = x_236; +goto block_221; } else { -lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; -x_196 = lean_ctor_get(x_180, 2); -lean_inc(x_196); -x_197 = lean_ctor_get(x_179, 0); +lean_object* x_238; lean_object* x_239; lean_object* x_240; +x_238 = lean_ctor_get(x_234, 0); +lean_inc(x_238); +x_239 = lean_ctor_get(x_234, 1); +lean_inc(x_239); +lean_dec(x_234); +x_240 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_240, 0, x_238); +x_187 = x_240; +x_188 = x_239; +goto block_221; +} +block_221: +{ +if (lean_obj_tag(x_187) == 0) +{ +lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; +x_189 = lean_ctor_get(x_188, 2); +lean_inc(x_189); +x_190 = lean_ctor_get(x_187, 0); +lean_inc(x_190); +lean_dec(x_187); +x_191 = lean_ctor_get(x_188, 0); +lean_inc(x_191); +x_192 = lean_ctor_get(x_188, 1); +lean_inc(x_192); +x_193 = lean_ctor_get(x_188, 3); +lean_inc(x_193); +x_194 = lean_ctor_get(x_188, 4); +lean_inc(x_194); +x_195 = lean_ctor_get(x_188, 5); +lean_inc(x_195); +if (lean_is_exclusive(x_188)) { + lean_ctor_release(x_188, 0); + lean_ctor_release(x_188, 1); + lean_ctor_release(x_188, 2); + lean_ctor_release(x_188, 3); + lean_ctor_release(x_188, 4); + lean_ctor_release(x_188, 5); + x_196 = x_188; +} else { + lean_dec_ref(x_188); + x_196 = lean_box(0); +} +x_197 = lean_ctor_get(x_189, 0); lean_inc(x_197); -lean_dec(x_179); -x_198 = lean_ctor_get(x_180, 0); +x_198 = lean_ctor_get(x_189, 1); lean_inc(x_198); -x_199 = lean_ctor_get(x_180, 1); +x_199 = lean_ctor_get(x_189, 3); lean_inc(x_199); -x_200 = lean_ctor_get(x_180, 3); +x_200 = lean_ctor_get(x_189, 4); lean_inc(x_200); -x_201 = lean_ctor_get(x_180, 4); -lean_inc(x_201); -x_202 = lean_ctor_get(x_180, 5); -lean_inc(x_202); -if (lean_is_exclusive(x_180)) { - lean_ctor_release(x_180, 0); - lean_ctor_release(x_180, 1); - lean_ctor_release(x_180, 2); - lean_ctor_release(x_180, 3); - lean_ctor_release(x_180, 4); - lean_ctor_release(x_180, 5); - x_203 = x_180; +if (lean_is_exclusive(x_189)) { + lean_ctor_release(x_189, 0); + lean_ctor_release(x_189, 1); + lean_ctor_release(x_189, 2); + lean_ctor_release(x_189, 3); + lean_ctor_release(x_189, 4); + x_201 = x_189; } else { - lean_dec_ref(x_180); - x_203 = lean_box(0); + lean_dec_ref(x_189); + x_201 = lean_box(0); } -x_204 = lean_ctor_get(x_196, 0); -lean_inc(x_204); -x_205 = lean_ctor_get(x_196, 1); -lean_inc(x_205); -x_206 = lean_ctor_get(x_196, 3); -lean_inc(x_206); -if (lean_is_exclusive(x_196)) { - lean_ctor_release(x_196, 0); - lean_ctor_release(x_196, 1); - lean_ctor_release(x_196, 2); - lean_ctor_release(x_196, 3); - x_207 = x_196; +if (lean_is_scalar(x_201)) { + x_202 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_196); - x_207 = lean_box(0); + x_202 = x_201; } -if (lean_is_scalar(x_207)) { - x_208 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_202, 0, x_197); +lean_ctor_set(x_202, 1, x_198); +lean_ctor_set(x_202, 2, x_183); +lean_ctor_set(x_202, 3, x_199); +lean_ctor_set(x_202, 4, x_200); +if (lean_is_scalar(x_196)) { + x_203 = lean_alloc_ctor(0, 6, 0); } else { - x_208 = x_207; + x_203 = x_196; } -lean_ctor_set(x_208, 0, x_204); -lean_ctor_set(x_208, 1, x_205); -lean_ctor_set(x_208, 2, x_176); -lean_ctor_set(x_208, 3, x_206); -if (lean_is_scalar(x_203)) { - x_209 = lean_alloc_ctor(0, 6, 0); -} else { - x_209 = x_203; -} -lean_ctor_set(x_209, 0, x_198); -lean_ctor_set(x_209, 1, x_199); -lean_ctor_set(x_209, 2, x_208); -lean_ctor_set(x_209, 3, x_200); -lean_ctor_set(x_209, 4, x_201); -lean_ctor_set(x_209, 5, x_202); +lean_ctor_set(x_203, 0, x_191); +lean_ctor_set(x_203, 1, x_192); +lean_ctor_set(x_203, 2, x_202); +lean_ctor_set(x_203, 3, x_193); +lean_ctor_set(x_203, 4, x_194); +lean_ctor_set(x_203, 5, x_195); if (lean_is_scalar(x_27)) { - x_210 = lean_alloc_ctor(0, 2, 0); + x_204 = lean_alloc_ctor(1, 2, 0); } else { - x_210 = x_27; + x_204 = x_27; + lean_ctor_set_tag(x_204, 1); } -lean_ctor_set(x_210, 0, x_197); -lean_ctor_set(x_210, 1, x_209); -return x_210; +lean_ctor_set(x_204, 0, x_190); +lean_ctor_set(x_204, 1, x_203); +return x_204; +} +else +{ +lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; +x_205 = lean_ctor_get(x_188, 2); +lean_inc(x_205); +x_206 = lean_ctor_get(x_187, 0); +lean_inc(x_206); +lean_dec(x_187); +x_207 = lean_ctor_get(x_188, 0); +lean_inc(x_207); +x_208 = lean_ctor_get(x_188, 1); +lean_inc(x_208); +x_209 = lean_ctor_get(x_188, 3); +lean_inc(x_209); +x_210 = lean_ctor_get(x_188, 4); +lean_inc(x_210); +x_211 = lean_ctor_get(x_188, 5); +lean_inc(x_211); +if (lean_is_exclusive(x_188)) { + lean_ctor_release(x_188, 0); + lean_ctor_release(x_188, 1); + lean_ctor_release(x_188, 2); + lean_ctor_release(x_188, 3); + lean_ctor_release(x_188, 4); + lean_ctor_release(x_188, 5); + x_212 = x_188; +} else { + lean_dec_ref(x_188); + x_212 = lean_box(0); +} +x_213 = lean_ctor_get(x_205, 0); +lean_inc(x_213); +x_214 = lean_ctor_get(x_205, 1); +lean_inc(x_214); +x_215 = lean_ctor_get(x_205, 3); +lean_inc(x_215); +x_216 = lean_ctor_get(x_205, 4); +lean_inc(x_216); +if (lean_is_exclusive(x_205)) { + lean_ctor_release(x_205, 0); + lean_ctor_release(x_205, 1); + lean_ctor_release(x_205, 2); + lean_ctor_release(x_205, 3); + lean_ctor_release(x_205, 4); + x_217 = x_205; +} else { + lean_dec_ref(x_205); + x_217 = lean_box(0); +} +if (lean_is_scalar(x_217)) { + x_218 = lean_alloc_ctor(0, 5, 0); +} else { + x_218 = x_217; +} +lean_ctor_set(x_218, 0, x_213); +lean_ctor_set(x_218, 1, x_214); +lean_ctor_set(x_218, 2, x_183); +lean_ctor_set(x_218, 3, x_215); +lean_ctor_set(x_218, 4, x_216); +if (lean_is_scalar(x_212)) { + x_219 = lean_alloc_ctor(0, 6, 0); +} else { + x_219 = x_212; +} +lean_ctor_set(x_219, 0, x_207); +lean_ctor_set(x_219, 1, x_208); +lean_ctor_set(x_219, 2, x_218); +lean_ctor_set(x_219, 3, x_209); +lean_ctor_set(x_219, 4, x_210); +lean_ctor_set(x_219, 5, x_211); +if (lean_is_scalar(x_27)) { + x_220 = lean_alloc_ctor(0, 2, 0); +} else { + x_220 = x_27; +} +lean_ctor_set(x_220, 0, x_206); +lean_ctor_set(x_220, 1, x_219); +return x_220; } } } } default: { -lean_object* x_231; lean_object* x_232; -x_231 = lean_ctor_get(x_20, 1); -lean_inc(x_231); +lean_object* x_241; lean_object* x_242; +x_241 = lean_ctor_get(x_20, 1); +lean_inc(x_241); lean_dec(x_20); lean_inc(x_6); -x_232 = l_Lean_Meta_isClassExpensive___main(x_19, x_6, x_231); -if (lean_obj_tag(x_232) == 0) +x_242 = l_Lean_Meta_isClassExpensive___main(x_19, x_6, x_241); +if (lean_obj_tag(x_242) == 0) { -lean_object* x_233; -x_233 = lean_ctor_get(x_232, 0); -lean_inc(x_233); -if (lean_obj_tag(x_233) == 0) +lean_object* x_243; +x_243 = lean_ctor_get(x_242, 0); +lean_inc(x_243); +if (lean_obj_tag(x_243) == 0) { -lean_object* x_234; lean_object* x_235; lean_object* x_236; +lean_object* x_244; lean_object* x_245; lean_object* x_246; lean_dec(x_15); -x_234 = lean_ctor_get(x_232, 1); -lean_inc(x_234); -lean_dec(x_232); -x_235 = lean_unsigned_to_nat(1u); -x_236 = lean_nat_add(x_5, x_235); +x_244 = lean_ctor_get(x_242, 1); +lean_inc(x_244); +lean_dec(x_242); +x_245 = lean_unsigned_to_nat(1u); +x_246 = lean_nat_add(x_5, x_245); lean_dec(x_5); -x_5 = x_236; -x_7 = x_234; +x_5 = x_246; +x_7 = x_244; goto _start; } else { -lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; lean_object* x_242; uint8_t x_243; -x_238 = lean_ctor_get(x_232, 1); -lean_inc(x_238); -if (lean_is_exclusive(x_232)) { - lean_ctor_release(x_232, 0); - lean_ctor_release(x_232, 1); - x_239 = x_232; +lean_object* x_248; lean_object* x_249; lean_object* x_250; lean_object* x_251; lean_object* x_252; uint8_t x_253; +x_248 = lean_ctor_get(x_242, 1); +lean_inc(x_248); +if (lean_is_exclusive(x_242)) { + lean_ctor_release(x_242, 0); + lean_ctor_release(x_242, 1); + x_249 = x_242; } else { - lean_dec_ref(x_232); - x_239 = lean_box(0); + lean_dec_ref(x_242); + x_249 = lean_box(0); } -x_240 = lean_ctor_get(x_233, 0); -lean_inc(x_240); -lean_dec(x_233); -x_241 = lean_unsigned_to_nat(1u); -x_242 = lean_nat_add(x_5, x_241); -lean_dec(x_5); -x_243 = !lean_is_exclusive(x_238); -if (x_243 == 0) -{ -lean_object* x_244; uint8_t x_245; -x_244 = lean_ctor_get(x_238, 2); -x_245 = !lean_is_exclusive(x_244); -if (x_245 == 0) -{ -lean_object* x_246; lean_object* x_247; lean_object* x_248; lean_object* x_298; uint8_t x_299; -x_246 = lean_ctor_get(x_244, 2); -x_298 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_244, 2, x_298); -x_299 = !lean_is_exclusive(x_6); -if (x_299 == 0) -{ -lean_object* x_300; lean_object* x_301; lean_object* x_302; lean_object* x_303; -x_300 = lean_ctor_get(x_6, 2); -x_301 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_301, 0, x_240); -lean_ctor_set(x_301, 1, x_15); -x_302 = lean_array_push(x_300, x_301); -lean_ctor_set(x_6, 2, x_302); -x_303 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_30__replaceIndFVarsWithConsts___spec__6(x_1, x_2, x_3, x_4, x_242, x_6, x_238); -if (lean_obj_tag(x_303) == 0) -{ -lean_object* x_304; lean_object* x_305; lean_object* x_306; -x_304 = lean_ctor_get(x_303, 0); -lean_inc(x_304); -x_305 = lean_ctor_get(x_303, 1); -lean_inc(x_305); -lean_dec(x_303); -x_306 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_306, 0, x_304); -x_247 = x_306; -x_248 = x_305; -goto block_297; -} -else -{ -lean_object* x_307; lean_object* x_308; lean_object* x_309; -x_307 = lean_ctor_get(x_303, 0); -lean_inc(x_307); -x_308 = lean_ctor_get(x_303, 1); -lean_inc(x_308); -lean_dec(x_303); -x_309 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_309, 0, x_307); -x_247 = x_309; -x_248 = x_308; -goto block_297; -} -} -else -{ -lean_object* x_310; lean_object* x_311; lean_object* x_312; lean_object* x_313; lean_object* x_314; lean_object* x_315; lean_object* x_316; lean_object* x_317; lean_object* x_318; -x_310 = lean_ctor_get(x_6, 0); -x_311 = lean_ctor_get(x_6, 1); -x_312 = lean_ctor_get(x_6, 2); -x_313 = lean_ctor_get(x_6, 3); -x_314 = lean_ctor_get(x_6, 4); -lean_inc(x_314); -lean_inc(x_313); -lean_inc(x_312); -lean_inc(x_311); -lean_inc(x_310); -lean_dec(x_6); -x_315 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_315, 0, x_240); -lean_ctor_set(x_315, 1, x_15); -x_316 = lean_array_push(x_312, x_315); -x_317 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_317, 0, x_310); -lean_ctor_set(x_317, 1, x_311); -lean_ctor_set(x_317, 2, x_316); -lean_ctor_set(x_317, 3, x_313); -lean_ctor_set(x_317, 4, x_314); -x_318 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_30__replaceIndFVarsWithConsts___spec__6(x_1, x_2, x_3, x_4, x_242, x_317, x_238); -if (lean_obj_tag(x_318) == 0) -{ -lean_object* x_319; lean_object* x_320; lean_object* x_321; -x_319 = lean_ctor_get(x_318, 0); -lean_inc(x_319); -x_320 = lean_ctor_get(x_318, 1); -lean_inc(x_320); -lean_dec(x_318); -x_321 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_321, 0, x_319); -x_247 = x_321; -x_248 = x_320; -goto block_297; -} -else -{ -lean_object* x_322; lean_object* x_323; lean_object* x_324; -x_322 = lean_ctor_get(x_318, 0); -lean_inc(x_322); -x_323 = lean_ctor_get(x_318, 1); -lean_inc(x_323); -lean_dec(x_318); -x_324 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_324, 0, x_322); -x_247 = x_324; -x_248 = x_323; -goto block_297; -} -} -block_297: -{ -if (lean_obj_tag(x_247) == 0) -{ -lean_object* x_249; lean_object* x_250; uint8_t x_251; -x_249 = lean_ctor_get(x_248, 2); -lean_inc(x_249); -x_250 = lean_ctor_get(x_247, 0); +x_250 = lean_ctor_get(x_243, 0); lean_inc(x_250); -lean_dec(x_247); -x_251 = !lean_is_exclusive(x_248); -if (x_251 == 0) -{ -lean_object* x_252; uint8_t x_253; -x_252 = lean_ctor_get(x_248, 2); -lean_dec(x_252); -x_253 = !lean_is_exclusive(x_249); +lean_dec(x_243); +x_251 = lean_unsigned_to_nat(1u); +x_252 = lean_nat_add(x_5, x_251); +lean_dec(x_5); +x_253 = !lean_is_exclusive(x_248); if (x_253 == 0) { -lean_object* x_254; lean_object* x_255; -x_254 = lean_ctor_get(x_249, 2); -lean_dec(x_254); -lean_ctor_set(x_249, 2, x_246); -if (lean_is_scalar(x_239)) { - x_255 = lean_alloc_ctor(1, 2, 0); -} else { - x_255 = x_239; - lean_ctor_set_tag(x_255, 1); -} -lean_ctor_set(x_255, 0, x_250); -lean_ctor_set(x_255, 1, x_248); -return x_255; +lean_object* x_254; uint8_t x_255; +x_254 = lean_ctor_get(x_248, 2); +x_255 = !lean_is_exclusive(x_254); +if (x_255 == 0) +{ +lean_object* x_256; lean_object* x_257; lean_object* x_258; lean_object* x_312; uint8_t x_313; +x_256 = lean_ctor_get(x_254, 2); +x_312 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_254, 2, x_312); +x_313 = !lean_is_exclusive(x_6); +if (x_313 == 0) +{ +lean_object* x_314; lean_object* x_315; lean_object* x_316; lean_object* x_317; +x_314 = lean_ctor_get(x_6, 2); +x_315 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_315, 0, x_250); +lean_ctor_set(x_315, 1, x_15); +x_316 = lean_array_push(x_314, x_315); +lean_ctor_set(x_6, 2, x_316); +x_317 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_30__replaceIndFVarsWithConsts___spec__6(x_1, x_2, x_3, x_4, x_252, x_6, x_248); +if (lean_obj_tag(x_317) == 0) +{ +lean_object* x_318; lean_object* x_319; lean_object* x_320; +x_318 = lean_ctor_get(x_317, 0); +lean_inc(x_318); +x_319 = lean_ctor_get(x_317, 1); +lean_inc(x_319); +lean_dec(x_317); +x_320 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_320, 0, x_318); +x_257 = x_320; +x_258 = x_319; +goto block_311; } else { -lean_object* x_256; lean_object* x_257; lean_object* x_258; lean_object* x_259; lean_object* x_260; -x_256 = lean_ctor_get(x_249, 0); -x_257 = lean_ctor_get(x_249, 1); -x_258 = lean_ctor_get(x_249, 3); -lean_inc(x_258); -lean_inc(x_257); -lean_inc(x_256); -lean_dec(x_249); -x_259 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_259, 0, x_256); -lean_ctor_set(x_259, 1, x_257); -lean_ctor_set(x_259, 2, x_246); -lean_ctor_set(x_259, 3, x_258); -lean_ctor_set(x_248, 2, x_259); -if (lean_is_scalar(x_239)) { - x_260 = lean_alloc_ctor(1, 2, 0); -} else { - x_260 = x_239; - lean_ctor_set_tag(x_260, 1); -} -lean_ctor_set(x_260, 0, x_250); -lean_ctor_set(x_260, 1, x_248); -return x_260; +lean_object* x_321; lean_object* x_322; lean_object* x_323; +x_321 = lean_ctor_get(x_317, 0); +lean_inc(x_321); +x_322 = lean_ctor_get(x_317, 1); +lean_inc(x_322); +lean_dec(x_317); +x_323 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_323, 0, x_321); +x_257 = x_323; +x_258 = x_322; +goto block_311; } } else { -lean_object* x_261; lean_object* x_262; lean_object* x_263; lean_object* x_264; lean_object* x_265; lean_object* x_266; lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_object* x_270; lean_object* x_271; lean_object* x_272; -x_261 = lean_ctor_get(x_248, 0); -x_262 = lean_ctor_get(x_248, 1); -x_263 = lean_ctor_get(x_248, 3); -x_264 = lean_ctor_get(x_248, 4); -x_265 = lean_ctor_get(x_248, 5); -lean_inc(x_265); -lean_inc(x_264); -lean_inc(x_263); -lean_inc(x_262); -lean_inc(x_261); -lean_dec(x_248); -x_266 = lean_ctor_get(x_249, 0); -lean_inc(x_266); -x_267 = lean_ctor_get(x_249, 1); -lean_inc(x_267); -x_268 = lean_ctor_get(x_249, 3); +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; +x_324 = lean_ctor_get(x_6, 0); +x_325 = lean_ctor_get(x_6, 1); +x_326 = lean_ctor_get(x_6, 2); +x_327 = lean_ctor_get(x_6, 3); +x_328 = lean_ctor_get(x_6, 4); +lean_inc(x_328); +lean_inc(x_327); +lean_inc(x_326); +lean_inc(x_325); +lean_inc(x_324); +lean_dec(x_6); +x_329 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_329, 0, x_250); +lean_ctor_set(x_329, 1, x_15); +x_330 = lean_array_push(x_326, x_329); +x_331 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_331, 0, x_324); +lean_ctor_set(x_331, 1, x_325); +lean_ctor_set(x_331, 2, x_330); +lean_ctor_set(x_331, 3, x_327); +lean_ctor_set(x_331, 4, x_328); +x_332 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_30__replaceIndFVarsWithConsts___spec__6(x_1, x_2, x_3, x_4, x_252, x_331, x_248); +if (lean_obj_tag(x_332) == 0) +{ +lean_object* x_333; lean_object* x_334; lean_object* x_335; +x_333 = lean_ctor_get(x_332, 0); +lean_inc(x_333); +x_334 = lean_ctor_get(x_332, 1); +lean_inc(x_334); +lean_dec(x_332); +x_335 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_335, 0, x_333); +x_257 = x_335; +x_258 = x_334; +goto block_311; +} +else +{ +lean_object* x_336; lean_object* x_337; lean_object* x_338; +x_336 = lean_ctor_get(x_332, 0); +lean_inc(x_336); +x_337 = lean_ctor_get(x_332, 1); +lean_inc(x_337); +lean_dec(x_332); +x_338 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_338, 0, x_336); +x_257 = x_338; +x_258 = x_337; +goto block_311; +} +} +block_311: +{ +if (lean_obj_tag(x_257) == 0) +{ +lean_object* x_259; lean_object* x_260; uint8_t x_261; +x_259 = lean_ctor_get(x_258, 2); +lean_inc(x_259); +x_260 = lean_ctor_get(x_257, 0); +lean_inc(x_260); +lean_dec(x_257); +x_261 = !lean_is_exclusive(x_258); +if (x_261 == 0) +{ +lean_object* x_262; uint8_t x_263; +x_262 = lean_ctor_get(x_258, 2); +lean_dec(x_262); +x_263 = !lean_is_exclusive(x_259); +if (x_263 == 0) +{ +lean_object* x_264; lean_object* x_265; +x_264 = lean_ctor_get(x_259, 2); +lean_dec(x_264); +lean_ctor_set(x_259, 2, x_256); +if (lean_is_scalar(x_249)) { + x_265 = lean_alloc_ctor(1, 2, 0); +} else { + x_265 = x_249; + lean_ctor_set_tag(x_265, 1); +} +lean_ctor_set(x_265, 0, x_260); +lean_ctor_set(x_265, 1, x_258); +return x_265; +} +else +{ +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_266 = lean_ctor_get(x_259, 0); +x_267 = lean_ctor_get(x_259, 1); +x_268 = lean_ctor_get(x_259, 3); +x_269 = lean_ctor_get(x_259, 4); +lean_inc(x_269); lean_inc(x_268); -if (lean_is_exclusive(x_249)) { - lean_ctor_release(x_249, 0); - lean_ctor_release(x_249, 1); - lean_ctor_release(x_249, 2); - lean_ctor_release(x_249, 3); - x_269 = x_249; -} else { - lean_dec_ref(x_249); - x_269 = lean_box(0); -} -if (lean_is_scalar(x_269)) { - x_270 = lean_alloc_ctor(0, 4, 0); -} else { - x_270 = x_269; -} +lean_inc(x_267); +lean_inc(x_266); +lean_dec(x_259); +x_270 = lean_alloc_ctor(0, 5, 0); lean_ctor_set(x_270, 0, x_266); lean_ctor_set(x_270, 1, x_267); -lean_ctor_set(x_270, 2, x_246); +lean_ctor_set(x_270, 2, x_256); lean_ctor_set(x_270, 3, x_268); -x_271 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_271, 0, x_261); -lean_ctor_set(x_271, 1, x_262); -lean_ctor_set(x_271, 2, x_270); -lean_ctor_set(x_271, 3, x_263); -lean_ctor_set(x_271, 4, x_264); -lean_ctor_set(x_271, 5, x_265); -if (lean_is_scalar(x_239)) { - x_272 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_270, 4, x_269); +lean_ctor_set(x_258, 2, x_270); +if (lean_is_scalar(x_249)) { + x_271 = lean_alloc_ctor(1, 2, 0); } else { - x_272 = x_239; - lean_ctor_set_tag(x_272, 1); + x_271 = x_249; + lean_ctor_set_tag(x_271, 1); } -lean_ctor_set(x_272, 0, x_250); -lean_ctor_set(x_272, 1, x_271); -return x_272; +lean_ctor_set(x_271, 0, x_260); +lean_ctor_set(x_271, 1, x_258); +return x_271; } } else { -lean_object* x_273; lean_object* x_274; uint8_t x_275; -x_273 = lean_ctor_get(x_248, 2); -lean_inc(x_273); -x_274 = lean_ctor_get(x_247, 0); +lean_object* x_272; lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_object* x_276; lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; lean_object* x_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; +x_272 = lean_ctor_get(x_258, 0); +x_273 = lean_ctor_get(x_258, 1); +x_274 = lean_ctor_get(x_258, 3); +x_275 = lean_ctor_get(x_258, 4); +x_276 = lean_ctor_get(x_258, 5); +lean_inc(x_276); +lean_inc(x_275); lean_inc(x_274); -lean_dec(x_247); -x_275 = !lean_is_exclusive(x_248); -if (x_275 == 0) -{ -lean_object* x_276; uint8_t x_277; -x_276 = lean_ctor_get(x_248, 2); -lean_dec(x_276); -x_277 = !lean_is_exclusive(x_273); -if (x_277 == 0) -{ -lean_object* x_278; lean_object* x_279; -x_278 = lean_ctor_get(x_273, 2); -lean_dec(x_278); -lean_ctor_set(x_273, 2, x_246); -if (lean_is_scalar(x_239)) { - x_279 = lean_alloc_ctor(0, 2, 0); -} else { - x_279 = x_239; -} -lean_ctor_set(x_279, 0, x_274); -lean_ctor_set(x_279, 1, x_248); -return x_279; -} -else -{ -lean_object* x_280; lean_object* x_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; -x_280 = lean_ctor_get(x_273, 0); -x_281 = lean_ctor_get(x_273, 1); -x_282 = lean_ctor_get(x_273, 3); -lean_inc(x_282); -lean_inc(x_281); +lean_inc(x_273); +lean_inc(x_272); +lean_dec(x_258); +x_277 = lean_ctor_get(x_259, 0); +lean_inc(x_277); +x_278 = lean_ctor_get(x_259, 1); +lean_inc(x_278); +x_279 = lean_ctor_get(x_259, 3); +lean_inc(x_279); +x_280 = lean_ctor_get(x_259, 4); lean_inc(x_280); -lean_dec(x_273); -x_283 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_283, 0, x_280); -lean_ctor_set(x_283, 1, x_281); -lean_ctor_set(x_283, 2, x_246); -lean_ctor_set(x_283, 3, x_282); -lean_ctor_set(x_248, 2, x_283); -if (lean_is_scalar(x_239)) { - x_284 = lean_alloc_ctor(0, 2, 0); +if (lean_is_exclusive(x_259)) { + lean_ctor_release(x_259, 0); + lean_ctor_release(x_259, 1); + lean_ctor_release(x_259, 2); + lean_ctor_release(x_259, 3); + lean_ctor_release(x_259, 4); + x_281 = x_259; } else { - x_284 = x_239; + lean_dec_ref(x_259); + x_281 = lean_box(0); } -lean_ctor_set(x_284, 0, x_274); -lean_ctor_set(x_284, 1, x_248); +if (lean_is_scalar(x_281)) { + x_282 = lean_alloc_ctor(0, 5, 0); +} else { + x_282 = x_281; +} +lean_ctor_set(x_282, 0, x_277); +lean_ctor_set(x_282, 1, x_278); +lean_ctor_set(x_282, 2, x_256); +lean_ctor_set(x_282, 3, x_279); +lean_ctor_set(x_282, 4, x_280); +x_283 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_283, 0, x_272); +lean_ctor_set(x_283, 1, x_273); +lean_ctor_set(x_283, 2, x_282); +lean_ctor_set(x_283, 3, x_274); +lean_ctor_set(x_283, 4, x_275); +lean_ctor_set(x_283, 5, x_276); +if (lean_is_scalar(x_249)) { + x_284 = lean_alloc_ctor(1, 2, 0); +} else { + x_284 = x_249; + lean_ctor_set_tag(x_284, 1); +} +lean_ctor_set(x_284, 0, x_260); +lean_ctor_set(x_284, 1, x_283); return x_284; } } else { -lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; lean_object* x_289; lean_object* x_290; lean_object* x_291; lean_object* x_292; lean_object* x_293; lean_object* x_294; lean_object* x_295; lean_object* x_296; -x_285 = lean_ctor_get(x_248, 0); -x_286 = lean_ctor_get(x_248, 1); -x_287 = lean_ctor_get(x_248, 3); -x_288 = lean_ctor_get(x_248, 4); -x_289 = lean_ctor_get(x_248, 5); -lean_inc(x_289); -lean_inc(x_288); -lean_inc(x_287); -lean_inc(x_286); +lean_object* x_285; lean_object* x_286; uint8_t x_287; +x_285 = lean_ctor_get(x_258, 2); lean_inc(x_285); -lean_dec(x_248); -x_290 = lean_ctor_get(x_273, 0); -lean_inc(x_290); -x_291 = lean_ctor_get(x_273, 1); -lean_inc(x_291); -x_292 = lean_ctor_get(x_273, 3); +x_286 = lean_ctor_get(x_257, 0); +lean_inc(x_286); +lean_dec(x_257); +x_287 = !lean_is_exclusive(x_258); +if (x_287 == 0) +{ +lean_object* x_288; uint8_t x_289; +x_288 = lean_ctor_get(x_258, 2); +lean_dec(x_288); +x_289 = !lean_is_exclusive(x_285); +if (x_289 == 0) +{ +lean_object* x_290; lean_object* x_291; +x_290 = lean_ctor_get(x_285, 2); +lean_dec(x_290); +lean_ctor_set(x_285, 2, x_256); +if (lean_is_scalar(x_249)) { + x_291 = lean_alloc_ctor(0, 2, 0); +} else { + x_291 = x_249; +} +lean_ctor_set(x_291, 0, x_286); +lean_ctor_set(x_291, 1, x_258); +return x_291; +} +else +{ +lean_object* x_292; lean_object* x_293; lean_object* x_294; lean_object* x_295; lean_object* x_296; lean_object* x_297; +x_292 = lean_ctor_get(x_285, 0); +x_293 = lean_ctor_get(x_285, 1); +x_294 = lean_ctor_get(x_285, 3); +x_295 = lean_ctor_get(x_285, 4); +lean_inc(x_295); +lean_inc(x_294); +lean_inc(x_293); lean_inc(x_292); -if (lean_is_exclusive(x_273)) { - lean_ctor_release(x_273, 0); - lean_ctor_release(x_273, 1); - lean_ctor_release(x_273, 2); - lean_ctor_release(x_273, 3); - x_293 = x_273; +lean_dec(x_285); +x_296 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_296, 0, x_292); +lean_ctor_set(x_296, 1, x_293); +lean_ctor_set(x_296, 2, x_256); +lean_ctor_set(x_296, 3, x_294); +lean_ctor_set(x_296, 4, x_295); +lean_ctor_set(x_258, 2, x_296); +if (lean_is_scalar(x_249)) { + x_297 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_273); - x_293 = lean_box(0); + x_297 = x_249; } -if (lean_is_scalar(x_293)) { - x_294 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_297, 0, x_286); +lean_ctor_set(x_297, 1, x_258); +return x_297; +} +} +else +{ +lean_object* x_298; lean_object* x_299; lean_object* x_300; lean_object* x_301; lean_object* x_302; lean_object* x_303; lean_object* x_304; lean_object* x_305; lean_object* x_306; lean_object* x_307; lean_object* x_308; lean_object* x_309; lean_object* x_310; +x_298 = lean_ctor_get(x_258, 0); +x_299 = lean_ctor_get(x_258, 1); +x_300 = lean_ctor_get(x_258, 3); +x_301 = lean_ctor_get(x_258, 4); +x_302 = lean_ctor_get(x_258, 5); +lean_inc(x_302); +lean_inc(x_301); +lean_inc(x_300); +lean_inc(x_299); +lean_inc(x_298); +lean_dec(x_258); +x_303 = lean_ctor_get(x_285, 0); +lean_inc(x_303); +x_304 = lean_ctor_get(x_285, 1); +lean_inc(x_304); +x_305 = lean_ctor_get(x_285, 3); +lean_inc(x_305); +x_306 = lean_ctor_get(x_285, 4); +lean_inc(x_306); +if (lean_is_exclusive(x_285)) { + lean_ctor_release(x_285, 0); + lean_ctor_release(x_285, 1); + lean_ctor_release(x_285, 2); + lean_ctor_release(x_285, 3); + lean_ctor_release(x_285, 4); + x_307 = x_285; } else { - x_294 = x_293; + lean_dec_ref(x_285); + x_307 = lean_box(0); } -lean_ctor_set(x_294, 0, x_290); -lean_ctor_set(x_294, 1, x_291); -lean_ctor_set(x_294, 2, x_246); -lean_ctor_set(x_294, 3, x_292); -x_295 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_295, 0, x_285); -lean_ctor_set(x_295, 1, x_286); -lean_ctor_set(x_295, 2, x_294); -lean_ctor_set(x_295, 3, x_287); -lean_ctor_set(x_295, 4, x_288); -lean_ctor_set(x_295, 5, x_289); -if (lean_is_scalar(x_239)) { - x_296 = lean_alloc_ctor(0, 2, 0); +if (lean_is_scalar(x_307)) { + x_308 = lean_alloc_ctor(0, 5, 0); } else { - x_296 = x_239; + x_308 = x_307; } -lean_ctor_set(x_296, 0, x_274); -lean_ctor_set(x_296, 1, x_295); -return x_296; +lean_ctor_set(x_308, 0, x_303); +lean_ctor_set(x_308, 1, x_304); +lean_ctor_set(x_308, 2, x_256); +lean_ctor_set(x_308, 3, x_305); +lean_ctor_set(x_308, 4, x_306); +x_309 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_309, 0, x_298); +lean_ctor_set(x_309, 1, x_299); +lean_ctor_set(x_309, 2, x_308); +lean_ctor_set(x_309, 3, x_300); +lean_ctor_set(x_309, 4, x_301); +lean_ctor_set(x_309, 5, x_302); +if (lean_is_scalar(x_249)) { + x_310 = lean_alloc_ctor(0, 2, 0); +} else { + x_310 = x_249; +} +lean_ctor_set(x_310, 0, x_286); +lean_ctor_set(x_310, 1, x_309); +return x_310; } } } } else { -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_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_325 = lean_ctor_get(x_244, 0); -x_326 = lean_ctor_get(x_244, 1); -x_327 = lean_ctor_get(x_244, 2); -x_328 = lean_ctor_get(x_244, 3); -lean_inc(x_328); -lean_inc(x_327); -lean_inc(x_326); -lean_inc(x_325); -lean_dec(x_244); -x_362 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_363 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_363, 0, x_325); -lean_ctor_set(x_363, 1, x_326); -lean_ctor_set(x_363, 2, x_362); -lean_ctor_set(x_363, 3, x_328); -lean_ctor_set(x_238, 2, x_363); -x_364 = lean_ctor_get(x_6, 0); -lean_inc(x_364); -x_365 = lean_ctor_get(x_6, 1); -lean_inc(x_365); -x_366 = lean_ctor_get(x_6, 2); -lean_inc(x_366); -x_367 = lean_ctor_get(x_6, 3); -lean_inc(x_367); -x_368 = lean_ctor_get(x_6, 4); -lean_inc(x_368); +lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; lean_object* x_345; 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_339 = lean_ctor_get(x_254, 0); +x_340 = lean_ctor_get(x_254, 1); +x_341 = lean_ctor_get(x_254, 2); +x_342 = lean_ctor_get(x_254, 3); +x_343 = lean_ctor_get(x_254, 4); +lean_inc(x_343); +lean_inc(x_342); +lean_inc(x_341); +lean_inc(x_340); +lean_inc(x_339); +lean_dec(x_254); +x_379 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_380 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_380, 0, x_339); +lean_ctor_set(x_380, 1, x_340); +lean_ctor_set(x_380, 2, x_379); +lean_ctor_set(x_380, 3, x_342); +lean_ctor_set(x_380, 4, x_343); +lean_ctor_set(x_248, 2, x_380); +x_381 = lean_ctor_get(x_6, 0); +lean_inc(x_381); +x_382 = lean_ctor_get(x_6, 1); +lean_inc(x_382); +x_383 = lean_ctor_get(x_6, 2); +lean_inc(x_383); +x_384 = lean_ctor_get(x_6, 3); +lean_inc(x_384); +x_385 = lean_ctor_get(x_6, 4); +lean_inc(x_385); if (lean_is_exclusive(x_6)) { lean_ctor_release(x_6, 0); lean_ctor_release(x_6, 1); lean_ctor_release(x_6, 2); lean_ctor_release(x_6, 3); lean_ctor_release(x_6, 4); - x_369 = x_6; + x_386 = x_6; } else { lean_dec_ref(x_6); - x_369 = lean_box(0); + x_386 = lean_box(0); } -x_370 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_370, 0, x_240); -lean_ctor_set(x_370, 1, x_15); -x_371 = lean_array_push(x_366, x_370); -if (lean_is_scalar(x_369)) { - x_372 = lean_alloc_ctor(0, 5, 0); +x_387 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_387, 0, x_250); +lean_ctor_set(x_387, 1, x_15); +x_388 = lean_array_push(x_383, x_387); +if (lean_is_scalar(x_386)) { + x_389 = lean_alloc_ctor(0, 5, 0); } else { - x_372 = x_369; + x_389 = x_386; } -lean_ctor_set(x_372, 0, x_364); -lean_ctor_set(x_372, 1, x_365); -lean_ctor_set(x_372, 2, x_371); -lean_ctor_set(x_372, 3, x_367); -lean_ctor_set(x_372, 4, x_368); -x_373 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_30__replaceIndFVarsWithConsts___spec__6(x_1, x_2, x_3, x_4, x_242, x_372, x_238); -if (lean_obj_tag(x_373) == 0) +lean_ctor_set(x_389, 0, x_381); +lean_ctor_set(x_389, 1, x_382); +lean_ctor_set(x_389, 2, x_388); +lean_ctor_set(x_389, 3, x_384); +lean_ctor_set(x_389, 4, x_385); +x_390 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_30__replaceIndFVarsWithConsts___spec__6(x_1, x_2, x_3, x_4, x_252, x_389, x_248); +if (lean_obj_tag(x_390) == 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); -x_376 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_376, 0, x_374); -x_329 = x_376; -x_330 = x_375; -goto block_361; +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); +x_393 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_393, 0, x_391); +x_344 = x_393; +x_345 = x_392; +goto block_378; } else { -lean_object* x_377; lean_object* x_378; lean_object* x_379; -x_377 = lean_ctor_get(x_373, 0); -lean_inc(x_377); -x_378 = lean_ctor_get(x_373, 1); -lean_inc(x_378); -lean_dec(x_373); -x_379 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_379, 0, x_377); -x_329 = x_379; -x_330 = x_378; -goto block_361; +lean_object* x_394; lean_object* x_395; lean_object* x_396; +x_394 = lean_ctor_get(x_390, 0); +lean_inc(x_394); +x_395 = lean_ctor_get(x_390, 1); +lean_inc(x_395); +lean_dec(x_390); +x_396 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_396, 0, x_394); +x_344 = x_396; +x_345 = x_395; +goto block_378; } -block_361: +block_378: { -if (lean_obj_tag(x_329) == 0) +if (lean_obj_tag(x_344) == 0) { -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; lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; lean_object* x_345; -x_331 = lean_ctor_get(x_330, 2); -lean_inc(x_331); -x_332 = lean_ctor_get(x_329, 0); -lean_inc(x_332); -lean_dec(x_329); -x_333 = lean_ctor_get(x_330, 0); -lean_inc(x_333); -x_334 = lean_ctor_get(x_330, 1); -lean_inc(x_334); -x_335 = lean_ctor_get(x_330, 3); -lean_inc(x_335); -x_336 = lean_ctor_get(x_330, 4); -lean_inc(x_336); -x_337 = lean_ctor_get(x_330, 5); -lean_inc(x_337); -if (lean_is_exclusive(x_330)) { - lean_ctor_release(x_330, 0); - lean_ctor_release(x_330, 1); - lean_ctor_release(x_330, 2); - lean_ctor_release(x_330, 3); - lean_ctor_release(x_330, 4); - lean_ctor_release(x_330, 5); - x_338 = x_330; -} else { - lean_dec_ref(x_330); - x_338 = lean_box(0); -} -x_339 = lean_ctor_get(x_331, 0); -lean_inc(x_339); -x_340 = lean_ctor_get(x_331, 1); -lean_inc(x_340); -x_341 = lean_ctor_get(x_331, 3); -lean_inc(x_341); -if (lean_is_exclusive(x_331)) { - lean_ctor_release(x_331, 0); - lean_ctor_release(x_331, 1); - lean_ctor_release(x_331, 2); - lean_ctor_release(x_331, 3); - x_342 = x_331; -} else { - lean_dec_ref(x_331); - x_342 = lean_box(0); -} -if (lean_is_scalar(x_342)) { - x_343 = lean_alloc_ctor(0, 4, 0); -} else { - x_343 = x_342; -} -lean_ctor_set(x_343, 0, x_339); -lean_ctor_set(x_343, 1, x_340); -lean_ctor_set(x_343, 2, x_327); -lean_ctor_set(x_343, 3, x_341); -if (lean_is_scalar(x_338)) { - x_344 = lean_alloc_ctor(0, 6, 0); -} else { - x_344 = x_338; -} -lean_ctor_set(x_344, 0, x_333); -lean_ctor_set(x_344, 1, x_334); -lean_ctor_set(x_344, 2, x_343); -lean_ctor_set(x_344, 3, x_335); -lean_ctor_set(x_344, 4, x_336); -lean_ctor_set(x_344, 5, x_337); -if (lean_is_scalar(x_239)) { - x_345 = lean_alloc_ctor(1, 2, 0); -} else { - x_345 = x_239; - lean_ctor_set_tag(x_345, 1); -} -lean_ctor_set(x_345, 0, x_332); -lean_ctor_set(x_345, 1, x_344); -return x_345; -} -else -{ -lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; lean_object* x_350; lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; lean_object* x_358; lean_object* x_359; lean_object* x_360; -x_346 = lean_ctor_get(x_330, 2); +lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; lean_object* x_350; lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; lean_object* x_358; lean_object* x_359; lean_object* x_360; lean_object* x_361; +x_346 = lean_ctor_get(x_345, 2); lean_inc(x_346); -x_347 = lean_ctor_get(x_329, 0); +x_347 = lean_ctor_get(x_344, 0); lean_inc(x_347); -lean_dec(x_329); -x_348 = lean_ctor_get(x_330, 0); +lean_dec(x_344); +x_348 = lean_ctor_get(x_345, 0); lean_inc(x_348); -x_349 = lean_ctor_get(x_330, 1); +x_349 = lean_ctor_get(x_345, 1); lean_inc(x_349); -x_350 = lean_ctor_get(x_330, 3); +x_350 = lean_ctor_get(x_345, 3); lean_inc(x_350); -x_351 = lean_ctor_get(x_330, 4); +x_351 = lean_ctor_get(x_345, 4); lean_inc(x_351); -x_352 = lean_ctor_get(x_330, 5); +x_352 = lean_ctor_get(x_345, 5); lean_inc(x_352); -if (lean_is_exclusive(x_330)) { - lean_ctor_release(x_330, 0); - lean_ctor_release(x_330, 1); - lean_ctor_release(x_330, 2); - lean_ctor_release(x_330, 3); - lean_ctor_release(x_330, 4); - lean_ctor_release(x_330, 5); - x_353 = x_330; +if (lean_is_exclusive(x_345)) { + lean_ctor_release(x_345, 0); + lean_ctor_release(x_345, 1); + lean_ctor_release(x_345, 2); + lean_ctor_release(x_345, 3); + lean_ctor_release(x_345, 4); + lean_ctor_release(x_345, 5); + x_353 = x_345; } else { - lean_dec_ref(x_330); + lean_dec_ref(x_345); x_353 = lean_box(0); } x_354 = lean_ctor_get(x_346, 0); @@ -15819,315 +15945,411 @@ x_355 = lean_ctor_get(x_346, 1); lean_inc(x_355); x_356 = lean_ctor_get(x_346, 3); lean_inc(x_356); +x_357 = lean_ctor_get(x_346, 4); +lean_inc(x_357); if (lean_is_exclusive(x_346)) { lean_ctor_release(x_346, 0); lean_ctor_release(x_346, 1); lean_ctor_release(x_346, 2); lean_ctor_release(x_346, 3); - x_357 = x_346; + lean_ctor_release(x_346, 4); + x_358 = x_346; } else { lean_dec_ref(x_346); - x_357 = lean_box(0); + x_358 = lean_box(0); } -if (lean_is_scalar(x_357)) { - x_358 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_358)) { + x_359 = lean_alloc_ctor(0, 5, 0); } else { - x_358 = x_357; + x_359 = x_358; } -lean_ctor_set(x_358, 0, x_354); -lean_ctor_set(x_358, 1, x_355); -lean_ctor_set(x_358, 2, x_327); -lean_ctor_set(x_358, 3, x_356); +lean_ctor_set(x_359, 0, x_354); +lean_ctor_set(x_359, 1, x_355); +lean_ctor_set(x_359, 2, x_341); +lean_ctor_set(x_359, 3, x_356); +lean_ctor_set(x_359, 4, x_357); if (lean_is_scalar(x_353)) { - x_359 = lean_alloc_ctor(0, 6, 0); + x_360 = lean_alloc_ctor(0, 6, 0); } else { - x_359 = x_353; + x_360 = x_353; } -lean_ctor_set(x_359, 0, x_348); -lean_ctor_set(x_359, 1, x_349); -lean_ctor_set(x_359, 2, x_358); -lean_ctor_set(x_359, 3, x_350); -lean_ctor_set(x_359, 4, x_351); -lean_ctor_set(x_359, 5, x_352); -if (lean_is_scalar(x_239)) { - x_360 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_360, 0, x_348); +lean_ctor_set(x_360, 1, x_349); +lean_ctor_set(x_360, 2, x_359); +lean_ctor_set(x_360, 3, x_350); +lean_ctor_set(x_360, 4, x_351); +lean_ctor_set(x_360, 5, x_352); +if (lean_is_scalar(x_249)) { + x_361 = lean_alloc_ctor(1, 2, 0); } else { - x_360 = x_239; + x_361 = x_249; + lean_ctor_set_tag(x_361, 1); } -lean_ctor_set(x_360, 0, x_347); -lean_ctor_set(x_360, 1, x_359); -return x_360; +lean_ctor_set(x_361, 0, x_347); +lean_ctor_set(x_361, 1, x_360); +return x_361; +} +else +{ +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; lean_object* x_374; lean_object* x_375; lean_object* x_376; lean_object* x_377; +x_362 = lean_ctor_get(x_345, 2); +lean_inc(x_362); +x_363 = lean_ctor_get(x_344, 0); +lean_inc(x_363); +lean_dec(x_344); +x_364 = lean_ctor_get(x_345, 0); +lean_inc(x_364); +x_365 = lean_ctor_get(x_345, 1); +lean_inc(x_365); +x_366 = lean_ctor_get(x_345, 3); +lean_inc(x_366); +x_367 = lean_ctor_get(x_345, 4); +lean_inc(x_367); +x_368 = lean_ctor_get(x_345, 5); +lean_inc(x_368); +if (lean_is_exclusive(x_345)) { + lean_ctor_release(x_345, 0); + lean_ctor_release(x_345, 1); + lean_ctor_release(x_345, 2); + lean_ctor_release(x_345, 3); + lean_ctor_release(x_345, 4); + lean_ctor_release(x_345, 5); + x_369 = x_345; +} else { + lean_dec_ref(x_345); + x_369 = lean_box(0); +} +x_370 = lean_ctor_get(x_362, 0); +lean_inc(x_370); +x_371 = lean_ctor_get(x_362, 1); +lean_inc(x_371); +x_372 = lean_ctor_get(x_362, 3); +lean_inc(x_372); +x_373 = lean_ctor_get(x_362, 4); +lean_inc(x_373); +if (lean_is_exclusive(x_362)) { + lean_ctor_release(x_362, 0); + lean_ctor_release(x_362, 1); + lean_ctor_release(x_362, 2); + lean_ctor_release(x_362, 3); + lean_ctor_release(x_362, 4); + x_374 = x_362; +} else { + lean_dec_ref(x_362); + x_374 = lean_box(0); +} +if (lean_is_scalar(x_374)) { + x_375 = lean_alloc_ctor(0, 5, 0); +} else { + x_375 = x_374; +} +lean_ctor_set(x_375, 0, x_370); +lean_ctor_set(x_375, 1, x_371); +lean_ctor_set(x_375, 2, x_341); +lean_ctor_set(x_375, 3, x_372); +lean_ctor_set(x_375, 4, x_373); +if (lean_is_scalar(x_369)) { + x_376 = lean_alloc_ctor(0, 6, 0); +} else { + x_376 = x_369; +} +lean_ctor_set(x_376, 0, x_364); +lean_ctor_set(x_376, 1, x_365); +lean_ctor_set(x_376, 2, x_375); +lean_ctor_set(x_376, 3, x_366); +lean_ctor_set(x_376, 4, x_367); +lean_ctor_set(x_376, 5, x_368); +if (lean_is_scalar(x_249)) { + x_377 = lean_alloc_ctor(0, 2, 0); +} else { + x_377 = x_249; +} +lean_ctor_set(x_377, 0, x_363); +lean_ctor_set(x_377, 1, x_376); +return x_377; } } } } else { -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; lean_object* x_391; lean_object* x_392; lean_object* x_424; lean_object* x_425; lean_object* x_426; lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; lean_object* x_432; lean_object* x_433; lean_object* x_434; lean_object* x_435; lean_object* x_436; -x_380 = lean_ctor_get(x_238, 2); -x_381 = lean_ctor_get(x_238, 0); -x_382 = lean_ctor_get(x_238, 1); -x_383 = lean_ctor_get(x_238, 3); -x_384 = lean_ctor_get(x_238, 4); -x_385 = lean_ctor_get(x_238, 5); -lean_inc(x_385); -lean_inc(x_384); -lean_inc(x_383); -lean_inc(x_380); -lean_inc(x_382); -lean_inc(x_381); -lean_dec(x_238); -x_386 = lean_ctor_get(x_380, 0); -lean_inc(x_386); -x_387 = lean_ctor_get(x_380, 1); -lean_inc(x_387); -x_388 = lean_ctor_get(x_380, 2); -lean_inc(x_388); -x_389 = lean_ctor_get(x_380, 3); -lean_inc(x_389); -if (lean_is_exclusive(x_380)) { - lean_ctor_release(x_380, 0); - lean_ctor_release(x_380, 1); - lean_ctor_release(x_380, 2); - lean_ctor_release(x_380, 3); - x_390 = x_380; +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; lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_444; lean_object* x_445; lean_object* x_446; lean_object* x_447; lean_object* x_448; lean_object* x_449; lean_object* x_450; lean_object* x_451; lean_object* x_452; lean_object* x_453; lean_object* x_454; lean_object* x_455; lean_object* x_456; +x_397 = lean_ctor_get(x_248, 2); +x_398 = lean_ctor_get(x_248, 0); +x_399 = lean_ctor_get(x_248, 1); +x_400 = lean_ctor_get(x_248, 3); +x_401 = lean_ctor_get(x_248, 4); +x_402 = lean_ctor_get(x_248, 5); +lean_inc(x_402); +lean_inc(x_401); +lean_inc(x_400); +lean_inc(x_397); +lean_inc(x_399); +lean_inc(x_398); +lean_dec(x_248); +x_403 = lean_ctor_get(x_397, 0); +lean_inc(x_403); +x_404 = lean_ctor_get(x_397, 1); +lean_inc(x_404); +x_405 = lean_ctor_get(x_397, 2); +lean_inc(x_405); +x_406 = lean_ctor_get(x_397, 3); +lean_inc(x_406); +x_407 = lean_ctor_get(x_397, 4); +lean_inc(x_407); +if (lean_is_exclusive(x_397)) { + lean_ctor_release(x_397, 0); + lean_ctor_release(x_397, 1); + lean_ctor_release(x_397, 2); + lean_ctor_release(x_397, 3); + lean_ctor_release(x_397, 4); + x_408 = x_397; } else { - lean_dec_ref(x_380); - x_390 = lean_box(0); + lean_dec_ref(x_397); + x_408 = lean_box(0); } -x_424 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_390)) { - x_425 = lean_alloc_ctor(0, 4, 0); +x_444 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_408)) { + x_445 = lean_alloc_ctor(0, 5, 0); } else { - x_425 = x_390; + x_445 = x_408; } -lean_ctor_set(x_425, 0, x_386); -lean_ctor_set(x_425, 1, x_387); -lean_ctor_set(x_425, 2, x_424); -lean_ctor_set(x_425, 3, x_389); -x_426 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_426, 0, x_381); -lean_ctor_set(x_426, 1, x_382); -lean_ctor_set(x_426, 2, x_425); -lean_ctor_set(x_426, 3, x_383); -lean_ctor_set(x_426, 4, x_384); -lean_ctor_set(x_426, 5, x_385); -x_427 = lean_ctor_get(x_6, 0); -lean_inc(x_427); -x_428 = lean_ctor_get(x_6, 1); -lean_inc(x_428); -x_429 = lean_ctor_get(x_6, 2); -lean_inc(x_429); -x_430 = lean_ctor_get(x_6, 3); -lean_inc(x_430); -x_431 = lean_ctor_get(x_6, 4); -lean_inc(x_431); +lean_ctor_set(x_445, 0, x_403); +lean_ctor_set(x_445, 1, x_404); +lean_ctor_set(x_445, 2, x_444); +lean_ctor_set(x_445, 3, x_406); +lean_ctor_set(x_445, 4, x_407); +x_446 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_446, 0, x_398); +lean_ctor_set(x_446, 1, x_399); +lean_ctor_set(x_446, 2, x_445); +lean_ctor_set(x_446, 3, x_400); +lean_ctor_set(x_446, 4, x_401); +lean_ctor_set(x_446, 5, x_402); +x_447 = lean_ctor_get(x_6, 0); +lean_inc(x_447); +x_448 = lean_ctor_get(x_6, 1); +lean_inc(x_448); +x_449 = lean_ctor_get(x_6, 2); +lean_inc(x_449); +x_450 = lean_ctor_get(x_6, 3); +lean_inc(x_450); +x_451 = lean_ctor_get(x_6, 4); +lean_inc(x_451); if (lean_is_exclusive(x_6)) { lean_ctor_release(x_6, 0); lean_ctor_release(x_6, 1); lean_ctor_release(x_6, 2); lean_ctor_release(x_6, 3); lean_ctor_release(x_6, 4); - x_432 = x_6; + x_452 = x_6; } else { lean_dec_ref(x_6); - x_432 = lean_box(0); + x_452 = lean_box(0); } -x_433 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_433, 0, x_240); -lean_ctor_set(x_433, 1, x_15); -x_434 = lean_array_push(x_429, x_433); -if (lean_is_scalar(x_432)) { - x_435 = lean_alloc_ctor(0, 5, 0); +x_453 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_453, 0, x_250); +lean_ctor_set(x_453, 1, x_15); +x_454 = lean_array_push(x_449, x_453); +if (lean_is_scalar(x_452)) { + x_455 = lean_alloc_ctor(0, 5, 0); } else { - x_435 = x_432; + x_455 = x_452; } -lean_ctor_set(x_435, 0, x_427); -lean_ctor_set(x_435, 1, x_428); -lean_ctor_set(x_435, 2, x_434); -lean_ctor_set(x_435, 3, x_430); -lean_ctor_set(x_435, 4, x_431); -x_436 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_30__replaceIndFVarsWithConsts___spec__6(x_1, x_2, x_3, x_4, x_242, x_435, x_426); -if (lean_obj_tag(x_436) == 0) +lean_ctor_set(x_455, 0, x_447); +lean_ctor_set(x_455, 1, x_448); +lean_ctor_set(x_455, 2, x_454); +lean_ctor_set(x_455, 3, x_450); +lean_ctor_set(x_455, 4, x_451); +x_456 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Elab_Inductive_30__replaceIndFVarsWithConsts___spec__6(x_1, x_2, x_3, x_4, x_252, x_455, x_446); +if (lean_obj_tag(x_456) == 0) { -lean_object* x_437; lean_object* x_438; lean_object* x_439; -x_437 = lean_ctor_get(x_436, 0); -lean_inc(x_437); -x_438 = lean_ctor_get(x_436, 1); -lean_inc(x_438); -lean_dec(x_436); -x_439 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_439, 0, x_437); -x_391 = x_439; -x_392 = x_438; -goto block_423; +lean_object* x_457; lean_object* x_458; lean_object* x_459; +x_457 = lean_ctor_get(x_456, 0); +lean_inc(x_457); +x_458 = lean_ctor_get(x_456, 1); +lean_inc(x_458); +lean_dec(x_456); +x_459 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_459, 0, x_457); +x_409 = x_459; +x_410 = x_458; +goto block_443; } else { -lean_object* x_440; lean_object* x_441; lean_object* x_442; -x_440 = lean_ctor_get(x_436, 0); -lean_inc(x_440); -x_441 = lean_ctor_get(x_436, 1); -lean_inc(x_441); -lean_dec(x_436); -x_442 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_442, 0, x_440); -x_391 = x_442; -x_392 = x_441; -goto block_423; +lean_object* x_460; lean_object* x_461; lean_object* x_462; +x_460 = lean_ctor_get(x_456, 0); +lean_inc(x_460); +x_461 = lean_ctor_get(x_456, 1); +lean_inc(x_461); +lean_dec(x_456); +x_462 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_462, 0, x_460); +x_409 = x_462; +x_410 = x_461; +goto block_443; } -block_423: +block_443: { -if (lean_obj_tag(x_391) == 0) +if (lean_obj_tag(x_409) == 0) { -lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; lean_object* x_400; lean_object* x_401; lean_object* x_402; lean_object* x_403; lean_object* x_404; lean_object* x_405; lean_object* x_406; lean_object* x_407; -x_393 = lean_ctor_get(x_392, 2); -lean_inc(x_393); -x_394 = lean_ctor_get(x_391, 0); -lean_inc(x_394); -lean_dec(x_391); -x_395 = lean_ctor_get(x_392, 0); -lean_inc(x_395); -x_396 = lean_ctor_get(x_392, 1); -lean_inc(x_396); -x_397 = lean_ctor_get(x_392, 3); -lean_inc(x_397); -x_398 = lean_ctor_get(x_392, 4); -lean_inc(x_398); -x_399 = lean_ctor_get(x_392, 5); -lean_inc(x_399); -if (lean_is_exclusive(x_392)) { - lean_ctor_release(x_392, 0); - lean_ctor_release(x_392, 1); - lean_ctor_release(x_392, 2); - lean_ctor_release(x_392, 3); - lean_ctor_release(x_392, 4); - lean_ctor_release(x_392, 5); - x_400 = x_392; -} else { - lean_dec_ref(x_392); - x_400 = lean_box(0); -} -x_401 = lean_ctor_get(x_393, 0); -lean_inc(x_401); -x_402 = lean_ctor_get(x_393, 1); -lean_inc(x_402); -x_403 = lean_ctor_get(x_393, 3); -lean_inc(x_403); -if (lean_is_exclusive(x_393)) { - lean_ctor_release(x_393, 0); - lean_ctor_release(x_393, 1); - lean_ctor_release(x_393, 2); - lean_ctor_release(x_393, 3); - x_404 = x_393; -} else { - lean_dec_ref(x_393); - x_404 = lean_box(0); -} -if (lean_is_scalar(x_404)) { - x_405 = lean_alloc_ctor(0, 4, 0); -} else { - x_405 = x_404; -} -lean_ctor_set(x_405, 0, x_401); -lean_ctor_set(x_405, 1, x_402); -lean_ctor_set(x_405, 2, x_388); -lean_ctor_set(x_405, 3, x_403); -if (lean_is_scalar(x_400)) { - x_406 = lean_alloc_ctor(0, 6, 0); -} else { - x_406 = x_400; -} -lean_ctor_set(x_406, 0, x_395); -lean_ctor_set(x_406, 1, x_396); -lean_ctor_set(x_406, 2, x_405); -lean_ctor_set(x_406, 3, x_397); -lean_ctor_set(x_406, 4, x_398); -lean_ctor_set(x_406, 5, x_399); -if (lean_is_scalar(x_239)) { - x_407 = lean_alloc_ctor(1, 2, 0); -} else { - x_407 = x_239; - lean_ctor_set_tag(x_407, 1); -} -lean_ctor_set(x_407, 0, x_394); -lean_ctor_set(x_407, 1, x_406); -return x_407; -} -else -{ -lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_object* x_412; lean_object* x_413; lean_object* x_414; lean_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; -x_408 = lean_ctor_get(x_392, 2); -lean_inc(x_408); -x_409 = lean_ctor_get(x_391, 0); -lean_inc(x_409); -lean_dec(x_391); -x_410 = lean_ctor_get(x_392, 0); -lean_inc(x_410); -x_411 = lean_ctor_get(x_392, 1); +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; lean_object* x_426; +x_411 = lean_ctor_get(x_410, 2); lean_inc(x_411); -x_412 = lean_ctor_get(x_392, 3); +x_412 = lean_ctor_get(x_409, 0); lean_inc(x_412); -x_413 = lean_ctor_get(x_392, 4); +lean_dec(x_409); +x_413 = lean_ctor_get(x_410, 0); lean_inc(x_413); -x_414 = lean_ctor_get(x_392, 5); +x_414 = lean_ctor_get(x_410, 1); lean_inc(x_414); -if (lean_is_exclusive(x_392)) { - lean_ctor_release(x_392, 0); - lean_ctor_release(x_392, 1); - lean_ctor_release(x_392, 2); - lean_ctor_release(x_392, 3); - lean_ctor_release(x_392, 4); - lean_ctor_release(x_392, 5); - x_415 = x_392; -} else { - lean_dec_ref(x_392); - x_415 = lean_box(0); -} -x_416 = lean_ctor_get(x_408, 0); +x_415 = lean_ctor_get(x_410, 3); +lean_inc(x_415); +x_416 = lean_ctor_get(x_410, 4); lean_inc(x_416); -x_417 = lean_ctor_get(x_408, 1); +x_417 = lean_ctor_get(x_410, 5); lean_inc(x_417); -x_418 = lean_ctor_get(x_408, 3); -lean_inc(x_418); -if (lean_is_exclusive(x_408)) { - lean_ctor_release(x_408, 0); - lean_ctor_release(x_408, 1); - lean_ctor_release(x_408, 2); - lean_ctor_release(x_408, 3); - x_419 = x_408; +if (lean_is_exclusive(x_410)) { + lean_ctor_release(x_410, 0); + lean_ctor_release(x_410, 1); + lean_ctor_release(x_410, 2); + lean_ctor_release(x_410, 3); + lean_ctor_release(x_410, 4); + lean_ctor_release(x_410, 5); + x_418 = x_410; } else { - lean_dec_ref(x_408); - x_419 = lean_box(0); + lean_dec_ref(x_410); + x_418 = lean_box(0); } -if (lean_is_scalar(x_419)) { - x_420 = lean_alloc_ctor(0, 4, 0); +x_419 = lean_ctor_get(x_411, 0); +lean_inc(x_419); +x_420 = lean_ctor_get(x_411, 1); +lean_inc(x_420); +x_421 = lean_ctor_get(x_411, 3); +lean_inc(x_421); +x_422 = lean_ctor_get(x_411, 4); +lean_inc(x_422); +if (lean_is_exclusive(x_411)) { + lean_ctor_release(x_411, 0); + lean_ctor_release(x_411, 1); + lean_ctor_release(x_411, 2); + lean_ctor_release(x_411, 3); + lean_ctor_release(x_411, 4); + x_423 = x_411; } else { - x_420 = x_419; + lean_dec_ref(x_411); + x_423 = lean_box(0); } -lean_ctor_set(x_420, 0, x_416); -lean_ctor_set(x_420, 1, x_417); -lean_ctor_set(x_420, 2, x_388); -lean_ctor_set(x_420, 3, x_418); -if (lean_is_scalar(x_415)) { - x_421 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_423)) { + x_424 = lean_alloc_ctor(0, 5, 0); } else { - x_421 = x_415; + x_424 = x_423; } -lean_ctor_set(x_421, 0, x_410); -lean_ctor_set(x_421, 1, x_411); -lean_ctor_set(x_421, 2, x_420); -lean_ctor_set(x_421, 3, x_412); -lean_ctor_set(x_421, 4, x_413); -lean_ctor_set(x_421, 5, x_414); -if (lean_is_scalar(x_239)) { - x_422 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_424, 0, x_419); +lean_ctor_set(x_424, 1, x_420); +lean_ctor_set(x_424, 2, x_405); +lean_ctor_set(x_424, 3, x_421); +lean_ctor_set(x_424, 4, x_422); +if (lean_is_scalar(x_418)) { + x_425 = lean_alloc_ctor(0, 6, 0); } else { - x_422 = x_239; + x_425 = x_418; } -lean_ctor_set(x_422, 0, x_409); -lean_ctor_set(x_422, 1, x_421); -return x_422; +lean_ctor_set(x_425, 0, x_413); +lean_ctor_set(x_425, 1, x_414); +lean_ctor_set(x_425, 2, x_424); +lean_ctor_set(x_425, 3, x_415); +lean_ctor_set(x_425, 4, x_416); +lean_ctor_set(x_425, 5, x_417); +if (lean_is_scalar(x_249)) { + x_426 = lean_alloc_ctor(1, 2, 0); +} else { + x_426 = x_249; + lean_ctor_set_tag(x_426, 1); +} +lean_ctor_set(x_426, 0, x_412); +lean_ctor_set(x_426, 1, x_425); +return x_426; +} +else +{ +lean_object* x_427; 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; +x_427 = lean_ctor_get(x_410, 2); +lean_inc(x_427); +x_428 = lean_ctor_get(x_409, 0); +lean_inc(x_428); +lean_dec(x_409); +x_429 = lean_ctor_get(x_410, 0); +lean_inc(x_429); +x_430 = lean_ctor_get(x_410, 1); +lean_inc(x_430); +x_431 = lean_ctor_get(x_410, 3); +lean_inc(x_431); +x_432 = lean_ctor_get(x_410, 4); +lean_inc(x_432); +x_433 = lean_ctor_get(x_410, 5); +lean_inc(x_433); +if (lean_is_exclusive(x_410)) { + lean_ctor_release(x_410, 0); + lean_ctor_release(x_410, 1); + lean_ctor_release(x_410, 2); + lean_ctor_release(x_410, 3); + lean_ctor_release(x_410, 4); + lean_ctor_release(x_410, 5); + x_434 = x_410; +} else { + lean_dec_ref(x_410); + x_434 = lean_box(0); +} +x_435 = lean_ctor_get(x_427, 0); +lean_inc(x_435); +x_436 = lean_ctor_get(x_427, 1); +lean_inc(x_436); +x_437 = lean_ctor_get(x_427, 3); +lean_inc(x_437); +x_438 = lean_ctor_get(x_427, 4); +lean_inc(x_438); +if (lean_is_exclusive(x_427)) { + lean_ctor_release(x_427, 0); + lean_ctor_release(x_427, 1); + lean_ctor_release(x_427, 2); + lean_ctor_release(x_427, 3); + lean_ctor_release(x_427, 4); + x_439 = x_427; +} else { + lean_dec_ref(x_427); + x_439 = lean_box(0); +} +if (lean_is_scalar(x_439)) { + x_440 = lean_alloc_ctor(0, 5, 0); +} else { + x_440 = x_439; +} +lean_ctor_set(x_440, 0, x_435); +lean_ctor_set(x_440, 1, x_436); +lean_ctor_set(x_440, 2, x_405); +lean_ctor_set(x_440, 3, x_437); +lean_ctor_set(x_440, 4, x_438); +if (lean_is_scalar(x_434)) { + x_441 = lean_alloc_ctor(0, 6, 0); +} else { + x_441 = x_434; +} +lean_ctor_set(x_441, 0, x_429); +lean_ctor_set(x_441, 1, x_430); +lean_ctor_set(x_441, 2, x_440); +lean_ctor_set(x_441, 3, x_431); +lean_ctor_set(x_441, 4, x_432); +lean_ctor_set(x_441, 5, x_433); +if (lean_is_scalar(x_249)) { + x_442 = lean_alloc_ctor(0, 2, 0); +} else { + x_442 = x_249; +} +lean_ctor_set(x_442, 0, x_428); +lean_ctor_set(x_442, 1, x_441); +return x_442; } } } @@ -16135,29 +16357,29 @@ return x_422; } else { -uint8_t x_443; +uint8_t x_463; lean_dec(x_15); lean_dec(x_6); lean_dec(x_5); lean_dec(x_3); lean_dec(x_2); -x_443 = !lean_is_exclusive(x_232); -if (x_443 == 0) +x_463 = !lean_is_exclusive(x_242); +if (x_463 == 0) { -return x_232; +return x_242; } else { -lean_object* x_444; lean_object* x_445; lean_object* x_446; -x_444 = lean_ctor_get(x_232, 0); -x_445 = lean_ctor_get(x_232, 1); -lean_inc(x_445); -lean_inc(x_444); -lean_dec(x_232); -x_446 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_446, 0, x_444); -lean_ctor_set(x_446, 1, x_445); -return x_446; +lean_object* x_464; lean_object* x_465; lean_object* x_466; +x_464 = lean_ctor_get(x_242, 0); +x_465 = lean_ctor_get(x_242, 1); +lean_inc(x_465); +lean_inc(x_464); +lean_dec(x_242); +x_466 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_466, 0, x_464); +lean_ctor_set(x_466, 1, x_465); +return x_466; } } } @@ -16165,58 +16387,58 @@ return x_446; } else { -uint8_t x_447; +uint8_t x_467; lean_dec(x_19); lean_dec(x_15); lean_dec(x_6); lean_dec(x_5); lean_dec(x_3); lean_dec(x_2); -x_447 = !lean_is_exclusive(x_20); -if (x_447 == 0) +x_467 = !lean_is_exclusive(x_20); +if (x_467 == 0) { return x_20; } else { -lean_object* x_448; lean_object* x_449; lean_object* x_450; -x_448 = lean_ctor_get(x_20, 0); -x_449 = lean_ctor_get(x_20, 1); -lean_inc(x_449); -lean_inc(x_448); +lean_object* x_468; lean_object* x_469; lean_object* x_470; +x_468 = lean_ctor_get(x_20, 0); +x_469 = lean_ctor_get(x_20, 1); +lean_inc(x_469); +lean_inc(x_468); lean_dec(x_20); -x_450 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_450, 0, x_448); -lean_ctor_set(x_450, 1, x_449); -return x_450; +x_470 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_470, 0, x_468); +lean_ctor_set(x_470, 1, x_469); +return x_470; } } } else { -uint8_t x_451; +uint8_t x_471; lean_dec(x_15); lean_dec(x_6); lean_dec(x_5); lean_dec(x_3); lean_dec(x_2); -x_451 = !lean_is_exclusive(x_16); -if (x_451 == 0) +x_471 = !lean_is_exclusive(x_16); +if (x_471 == 0) { return x_16; } else { -lean_object* x_452; lean_object* x_453; lean_object* x_454; -x_452 = lean_ctor_get(x_16, 0); -x_453 = lean_ctor_get(x_16, 1); -lean_inc(x_453); -lean_inc(x_452); +lean_object* x_472; lean_object* x_473; lean_object* x_474; +x_472 = lean_ctor_get(x_16, 0); +x_473 = lean_ctor_get(x_16, 1); +lean_inc(x_473); +lean_inc(x_472); lean_dec(x_16); -x_454 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_454, 0, x_452); -lean_ctor_set(x_454, 1, x_453); -return x_454; +x_474 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_474, 0, x_472); +lean_ctor_set(x_474, 1, x_473); +return x_474; } } } diff --git a/stage0/stdlib/Lean/Elab/Tactic/Basic.c b/stage0/stdlib/Lean/Elab/Tactic/Basic.c index 7c59aee292..e9fd9446dd 100644 --- a/stage0/stdlib/Lean/Elab/Tactic/Basic.c +++ b/stage0/stdlib/Lean/Elab/Tactic/Basic.c @@ -6545,7 +6545,7 @@ return x_4; lean_object* l_Lean_Elab_Tactic_resettingSynthInstanceCache___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { -lean_object* x_4; lean_object* x_5; lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_153; lean_object* x_154; +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_161; lean_object* x_162; x_4 = lean_ctor_get(x_3, 0); lean_inc(x_4); x_5 = lean_ctor_get(x_4, 0); @@ -6557,75 +6557,75 @@ lean_dec(x_5); x_7 = lean_ctor_get(x_6, 2); lean_inc(x_7); lean_dec(x_6); -x_153 = l_Lean_Elab_Tactic_resetSynthInstanceCache___closed__1; +x_161 = l_Lean_Elab_Tactic_resetSynthInstanceCache___closed__1; lean_inc(x_2); -x_154 = l_Lean_Elab_Tactic_liftTermElabM___rarg(x_153, x_2, x_3); -if (lean_obj_tag(x_154) == 0) +x_162 = l_Lean_Elab_Tactic_liftTermElabM___rarg(x_161, x_2, x_3); +if (lean_obj_tag(x_162) == 0) { -lean_object* x_155; lean_object* x_156; lean_object* x_157; -x_155 = lean_ctor_get(x_154, 1); -lean_inc(x_155); -lean_dec(x_154); -x_156 = l_Lean_Elab_Tactic_save(x_155); -x_157 = lean_apply_2(x_1, x_2, x_155); -if (lean_obj_tag(x_157) == 0) +lean_object* x_163; lean_object* x_164; lean_object* x_165; +x_163 = lean_ctor_get(x_162, 1); +lean_inc(x_163); +lean_dec(x_162); +x_164 = l_Lean_Elab_Tactic_save(x_163); +x_165 = lean_apply_2(x_1, x_2, x_163); +if (lean_obj_tag(x_165) == 0) { -lean_object* x_158; lean_object* x_159; lean_object* x_160; -lean_dec(x_156); -x_158 = lean_ctor_get(x_157, 0); -lean_inc(x_158); -x_159 = lean_ctor_get(x_157, 1); -lean_inc(x_159); -lean_dec(x_157); -x_160 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_160, 0, x_158); -x_8 = x_160; -x_9 = x_159; -goto block_152; +lean_object* x_166; lean_object* x_167; lean_object* x_168; +lean_dec(x_164); +x_166 = lean_ctor_get(x_165, 0); +lean_inc(x_166); +x_167 = lean_ctor_get(x_165, 1); +lean_inc(x_167); +lean_dec(x_165); +x_168 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_168, 0, x_166); +x_8 = x_168; +x_9 = x_167; +goto block_160; } else { -lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; -x_161 = lean_ctor_get(x_157, 0); -lean_inc(x_161); -x_162 = lean_ctor_get(x_157, 1); -lean_inc(x_162); -lean_dec(x_157); -x_163 = l_Lean_Elab_Tactic_restore(x_162, x_156); -lean_dec(x_156); -x_164 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_164, 0, x_161); -x_8 = x_164; -x_9 = x_163; -goto block_152; +lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; +x_169 = lean_ctor_get(x_165, 0); +lean_inc(x_169); +x_170 = lean_ctor_get(x_165, 1); +lean_inc(x_170); +lean_dec(x_165); +x_171 = l_Lean_Elab_Tactic_restore(x_170, x_164); +lean_dec(x_164); +x_172 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_172, 0, x_169); +x_8 = x_172; +x_9 = x_171; +goto block_160; } } else { -uint8_t x_165; +uint8_t x_173; lean_dec(x_7); lean_dec(x_2); lean_dec(x_1); -x_165 = !lean_is_exclusive(x_154); -if (x_165 == 0) +x_173 = !lean_is_exclusive(x_162); +if (x_173 == 0) { -return x_154; +return x_162; } else { -lean_object* x_166; lean_object* x_167; lean_object* x_168; -x_166 = lean_ctor_get(x_154, 0); -x_167 = lean_ctor_get(x_154, 1); -lean_inc(x_167); -lean_inc(x_166); -lean_dec(x_154); -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* x_174; lean_object* x_175; lean_object* x_176; +x_174 = lean_ctor_get(x_162, 0); +x_175 = lean_ctor_get(x_162, 1); +lean_inc(x_175); +lean_inc(x_174); +lean_dec(x_162); +x_176 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_176, 0, x_174); +lean_ctor_set(x_176, 1, x_175); +return x_176; } } -block_152: +block_160: { if (lean_obj_tag(x_8) == 0) { @@ -6671,103 +6671,110 @@ return x_22; } else { -lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; +lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; x_23 = lean_ctor_get(x_12, 0); x_24 = lean_ctor_get(x_12, 1); x_25 = lean_ctor_get(x_12, 3); +x_26 = lean_ctor_get(x_12, 4); +lean_inc(x_26); lean_inc(x_25); lean_inc(x_24); lean_inc(x_23); lean_dec(x_12); -x_26 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_26, 0, x_23); -lean_ctor_set(x_26, 1, x_24); -lean_ctor_set(x_26, 2, x_7); -lean_ctor_set(x_26, 3, x_25); -lean_ctor_set(x_11, 2, x_26); -x_27 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_27, 0, x_13); -lean_ctor_set(x_27, 1, x_9); -return x_27; +x_27 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_27, 0, x_23); +lean_ctor_set(x_27, 1, x_24); +lean_ctor_set(x_27, 2, x_7); +lean_ctor_set(x_27, 3, x_25); +lean_ctor_set(x_27, 4, x_26); +lean_ctor_set(x_11, 2, x_27); +x_28 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_28, 0, x_13); +lean_ctor_set(x_28, 1, x_9); +return x_28; } } else { -lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; -x_28 = lean_ctor_get(x_11, 0); -x_29 = lean_ctor_get(x_11, 1); -x_30 = lean_ctor_get(x_11, 3); -x_31 = lean_ctor_get(x_11, 4); -x_32 = lean_ctor_get(x_11, 5); +lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; +x_29 = lean_ctor_get(x_11, 0); +x_30 = lean_ctor_get(x_11, 1); +x_31 = lean_ctor_get(x_11, 3); +x_32 = lean_ctor_get(x_11, 4); +x_33 = lean_ctor_get(x_11, 5); +lean_inc(x_33); lean_inc(x_32); lean_inc(x_31); lean_inc(x_30); lean_inc(x_29); -lean_inc(x_28); lean_dec(x_11); -x_33 = lean_ctor_get(x_12, 0); -lean_inc(x_33); -x_34 = lean_ctor_get(x_12, 1); +x_34 = lean_ctor_get(x_12, 0); lean_inc(x_34); -x_35 = lean_ctor_get(x_12, 3); +x_35 = lean_ctor_get(x_12, 1); lean_inc(x_35); +x_36 = lean_ctor_get(x_12, 3); +lean_inc(x_36); +x_37 = lean_ctor_get(x_12, 4); +lean_inc(x_37); if (lean_is_exclusive(x_12)) { lean_ctor_release(x_12, 0); lean_ctor_release(x_12, 1); lean_ctor_release(x_12, 2); lean_ctor_release(x_12, 3); - x_36 = x_12; + lean_ctor_release(x_12, 4); + x_38 = x_12; } else { lean_dec_ref(x_12); - x_36 = lean_box(0); + x_38 = lean_box(0); } -if (lean_is_scalar(x_36)) { - x_37 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_38)) { + x_39 = lean_alloc_ctor(0, 5, 0); } else { - x_37 = x_36; + x_39 = x_38; } -lean_ctor_set(x_37, 0, x_33); -lean_ctor_set(x_37, 1, x_34); -lean_ctor_set(x_37, 2, x_7); -lean_ctor_set(x_37, 3, x_35); -x_38 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_38, 0, x_28); -lean_ctor_set(x_38, 1, x_29); -lean_ctor_set(x_38, 2, x_37); -lean_ctor_set(x_38, 3, x_30); -lean_ctor_set(x_38, 4, x_31); -lean_ctor_set(x_38, 5, x_32); -lean_ctor_set(x_10, 0, x_38); -x_39 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_39, 0, x_13); -lean_ctor_set(x_39, 1, x_9); -return x_39; +lean_ctor_set(x_39, 0, x_34); +lean_ctor_set(x_39, 1, x_35); +lean_ctor_set(x_39, 2, x_7); +lean_ctor_set(x_39, 3, x_36); +lean_ctor_set(x_39, 4, x_37); +x_40 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_40, 0, x_29); +lean_ctor_set(x_40, 1, x_30); +lean_ctor_set(x_40, 2, x_39); +lean_ctor_set(x_40, 3, x_31); +lean_ctor_set(x_40, 4, x_32); +lean_ctor_set(x_40, 5, x_33); +lean_ctor_set(x_10, 0, x_40); +x_41 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_41, 0, x_13); +lean_ctor_set(x_41, 1, x_9); +return x_41; } } else { -lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; -x_40 = lean_ctor_get(x_10, 1); -x_41 = lean_ctor_get(x_10, 2); -x_42 = lean_ctor_get(x_10, 3); -x_43 = lean_ctor_get(x_10, 4); -x_44 = lean_ctor_get(x_10, 5); +lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; 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; +x_42 = lean_ctor_get(x_10, 1); +x_43 = lean_ctor_get(x_10, 2); +x_44 = lean_ctor_get(x_10, 3); +x_45 = lean_ctor_get(x_10, 4); +x_46 = lean_ctor_get(x_10, 5); +lean_inc(x_46); +lean_inc(x_45); lean_inc(x_44); lean_inc(x_43); lean_inc(x_42); -lean_inc(x_41); -lean_inc(x_40); lean_dec(x_10); -x_45 = lean_ctor_get(x_11, 0); -lean_inc(x_45); -x_46 = lean_ctor_get(x_11, 1); -lean_inc(x_46); -x_47 = lean_ctor_get(x_11, 3); +x_47 = lean_ctor_get(x_11, 0); lean_inc(x_47); -x_48 = lean_ctor_get(x_11, 4); +x_48 = lean_ctor_get(x_11, 1); lean_inc(x_48); -x_49 = lean_ctor_get(x_11, 5); +x_49 = lean_ctor_get(x_11, 3); lean_inc(x_49); +x_50 = lean_ctor_get(x_11, 4); +lean_inc(x_50); +x_51 = lean_ctor_get(x_11, 5); +lean_inc(x_51); if (lean_is_exclusive(x_11)) { lean_ctor_release(x_11, 0); lean_ctor_release(x_11, 1); @@ -6775,77 +6782,81 @@ if (lean_is_exclusive(x_11)) { lean_ctor_release(x_11, 3); lean_ctor_release(x_11, 4); lean_ctor_release(x_11, 5); - x_50 = x_11; + x_52 = x_11; } else { lean_dec_ref(x_11); - x_50 = lean_box(0); + x_52 = lean_box(0); } -x_51 = lean_ctor_get(x_12, 0); -lean_inc(x_51); -x_52 = lean_ctor_get(x_12, 1); -lean_inc(x_52); -x_53 = lean_ctor_get(x_12, 3); +x_53 = lean_ctor_get(x_12, 0); lean_inc(x_53); +x_54 = lean_ctor_get(x_12, 1); +lean_inc(x_54); +x_55 = lean_ctor_get(x_12, 3); +lean_inc(x_55); +x_56 = lean_ctor_get(x_12, 4); +lean_inc(x_56); if (lean_is_exclusive(x_12)) { lean_ctor_release(x_12, 0); lean_ctor_release(x_12, 1); lean_ctor_release(x_12, 2); lean_ctor_release(x_12, 3); - x_54 = x_12; + lean_ctor_release(x_12, 4); + x_57 = x_12; } else { lean_dec_ref(x_12); - x_54 = lean_box(0); + x_57 = lean_box(0); } -if (lean_is_scalar(x_54)) { - x_55 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_57)) { + x_58 = lean_alloc_ctor(0, 5, 0); } else { - x_55 = x_54; + x_58 = x_57; } -lean_ctor_set(x_55, 0, x_51); -lean_ctor_set(x_55, 1, x_52); -lean_ctor_set(x_55, 2, x_7); -lean_ctor_set(x_55, 3, x_53); -if (lean_is_scalar(x_50)) { - x_56 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_58, 0, x_53); +lean_ctor_set(x_58, 1, x_54); +lean_ctor_set(x_58, 2, x_7); +lean_ctor_set(x_58, 3, x_55); +lean_ctor_set(x_58, 4, x_56); +if (lean_is_scalar(x_52)) { + x_59 = lean_alloc_ctor(0, 6, 0); } else { - x_56 = x_50; + x_59 = x_52; } -lean_ctor_set(x_56, 0, x_45); -lean_ctor_set(x_56, 1, x_46); -lean_ctor_set(x_56, 2, x_55); -lean_ctor_set(x_56, 3, x_47); -lean_ctor_set(x_56, 4, x_48); -lean_ctor_set(x_56, 5, x_49); -x_57 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_57, 0, x_56); -lean_ctor_set(x_57, 1, x_40); -lean_ctor_set(x_57, 2, x_41); -lean_ctor_set(x_57, 3, x_42); -lean_ctor_set(x_57, 4, x_43); -lean_ctor_set(x_57, 5, x_44); -lean_ctor_set(x_9, 0, x_57); -x_58 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_58, 0, x_13); -lean_ctor_set(x_58, 1, x_9); -return x_58; +lean_ctor_set(x_59, 0, x_47); +lean_ctor_set(x_59, 1, x_48); +lean_ctor_set(x_59, 2, x_58); +lean_ctor_set(x_59, 3, x_49); +lean_ctor_set(x_59, 4, x_50); +lean_ctor_set(x_59, 5, x_51); +x_60 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_60, 0, x_59); +lean_ctor_set(x_60, 1, x_42); +lean_ctor_set(x_60, 2, x_43); +lean_ctor_set(x_60, 3, x_44); +lean_ctor_set(x_60, 4, x_45); +lean_ctor_set(x_60, 5, x_46); +lean_ctor_set(x_9, 0, x_60); +x_61 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_61, 0, x_13); +lean_ctor_set(x_61, 1, x_9); +return x_61; } } else { -lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; -x_59 = lean_ctor_get(x_9, 1); -lean_inc(x_59); -lean_dec(x_9); -x_60 = lean_ctor_get(x_10, 1); -lean_inc(x_60); -x_61 = lean_ctor_get(x_10, 2); -lean_inc(x_61); -x_62 = lean_ctor_get(x_10, 3); +lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; +x_62 = lean_ctor_get(x_9, 1); lean_inc(x_62); -x_63 = lean_ctor_get(x_10, 4); +lean_dec(x_9); +x_63 = lean_ctor_get(x_10, 1); lean_inc(x_63); -x_64 = lean_ctor_get(x_10, 5); +x_64 = lean_ctor_get(x_10, 2); lean_inc(x_64); +x_65 = lean_ctor_get(x_10, 3); +lean_inc(x_65); +x_66 = lean_ctor_get(x_10, 4); +lean_inc(x_66); +x_67 = lean_ctor_get(x_10, 5); +lean_inc(x_67); if (lean_is_exclusive(x_10)) { lean_ctor_release(x_10, 0); lean_ctor_release(x_10, 1); @@ -6853,21 +6864,21 @@ if (lean_is_exclusive(x_10)) { lean_ctor_release(x_10, 3); lean_ctor_release(x_10, 4); lean_ctor_release(x_10, 5); - x_65 = x_10; + x_68 = x_10; } else { lean_dec_ref(x_10); - x_65 = lean_box(0); + x_68 = lean_box(0); } -x_66 = lean_ctor_get(x_11, 0); -lean_inc(x_66); -x_67 = lean_ctor_get(x_11, 1); -lean_inc(x_67); -x_68 = lean_ctor_get(x_11, 3); -lean_inc(x_68); -x_69 = lean_ctor_get(x_11, 4); +x_69 = lean_ctor_get(x_11, 0); lean_inc(x_69); -x_70 = lean_ctor_get(x_11, 5); +x_70 = lean_ctor_get(x_11, 1); lean_inc(x_70); +x_71 = lean_ctor_get(x_11, 3); +lean_inc(x_71); +x_72 = lean_ctor_get(x_11, 4); +lean_inc(x_72); +x_73 = lean_ctor_get(x_11, 5); +lean_inc(x_73); if (lean_is_exclusive(x_11)) { lean_ctor_release(x_11, 0); lean_ctor_release(x_11, 1); @@ -6875,374 +6886,393 @@ if (lean_is_exclusive(x_11)) { lean_ctor_release(x_11, 3); lean_ctor_release(x_11, 4); lean_ctor_release(x_11, 5); - x_71 = x_11; + x_74 = x_11; } else { lean_dec_ref(x_11); - x_71 = lean_box(0); + x_74 = lean_box(0); } -x_72 = lean_ctor_get(x_12, 0); -lean_inc(x_72); -x_73 = lean_ctor_get(x_12, 1); -lean_inc(x_73); -x_74 = lean_ctor_get(x_12, 3); -lean_inc(x_74); +x_75 = lean_ctor_get(x_12, 0); +lean_inc(x_75); +x_76 = lean_ctor_get(x_12, 1); +lean_inc(x_76); +x_77 = lean_ctor_get(x_12, 3); +lean_inc(x_77); +x_78 = lean_ctor_get(x_12, 4); +lean_inc(x_78); if (lean_is_exclusive(x_12)) { lean_ctor_release(x_12, 0); lean_ctor_release(x_12, 1); lean_ctor_release(x_12, 2); lean_ctor_release(x_12, 3); - x_75 = x_12; + lean_ctor_release(x_12, 4); + x_79 = x_12; } else { lean_dec_ref(x_12); - x_75 = lean_box(0); + x_79 = lean_box(0); } -if (lean_is_scalar(x_75)) { - x_76 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_79)) { + x_80 = lean_alloc_ctor(0, 5, 0); } else { - x_76 = x_75; + x_80 = x_79; } -lean_ctor_set(x_76, 0, x_72); -lean_ctor_set(x_76, 1, x_73); -lean_ctor_set(x_76, 2, x_7); -lean_ctor_set(x_76, 3, x_74); -if (lean_is_scalar(x_71)) { - x_77 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_80, 0, x_75); +lean_ctor_set(x_80, 1, x_76); +lean_ctor_set(x_80, 2, x_7); +lean_ctor_set(x_80, 3, x_77); +lean_ctor_set(x_80, 4, x_78); +if (lean_is_scalar(x_74)) { + x_81 = lean_alloc_ctor(0, 6, 0); } else { - x_77 = x_71; + x_81 = x_74; } -lean_ctor_set(x_77, 0, x_66); -lean_ctor_set(x_77, 1, x_67); -lean_ctor_set(x_77, 2, x_76); -lean_ctor_set(x_77, 3, x_68); -lean_ctor_set(x_77, 4, x_69); -lean_ctor_set(x_77, 5, x_70); -if (lean_is_scalar(x_65)) { - x_78 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_81, 0, x_69); +lean_ctor_set(x_81, 1, x_70); +lean_ctor_set(x_81, 2, x_80); +lean_ctor_set(x_81, 3, x_71); +lean_ctor_set(x_81, 4, x_72); +lean_ctor_set(x_81, 5, x_73); +if (lean_is_scalar(x_68)) { + x_82 = lean_alloc_ctor(0, 6, 0); } else { - x_78 = x_65; + x_82 = x_68; } -lean_ctor_set(x_78, 0, x_77); -lean_ctor_set(x_78, 1, x_60); -lean_ctor_set(x_78, 2, x_61); -lean_ctor_set(x_78, 3, x_62); -lean_ctor_set(x_78, 4, x_63); -lean_ctor_set(x_78, 5, x_64); -x_79 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_79, 0, x_78); -lean_ctor_set(x_79, 1, x_59); -x_80 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_80, 0, x_13); -lean_ctor_set(x_80, 1, x_79); -return x_80; +lean_ctor_set(x_82, 0, x_81); +lean_ctor_set(x_82, 1, x_63); +lean_ctor_set(x_82, 2, x_64); +lean_ctor_set(x_82, 3, x_65); +lean_ctor_set(x_82, 4, x_66); +lean_ctor_set(x_82, 5, x_67); +x_83 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_83, 0, x_82); +lean_ctor_set(x_83, 1, x_62); +x_84 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_84, 0, x_13); +lean_ctor_set(x_84, 1, x_83); +return x_84; } } else { -lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; uint8_t x_85; -x_81 = lean_ctor_get(x_9, 0); -lean_inc(x_81); -x_82 = lean_ctor_get(x_81, 0); -lean_inc(x_82); -x_83 = lean_ctor_get(x_82, 2); -lean_inc(x_83); -x_84 = lean_ctor_get(x_8, 0); -lean_inc(x_84); +lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; uint8_t x_89; +x_85 = lean_ctor_get(x_9, 0); +lean_inc(x_85); +x_86 = lean_ctor_get(x_85, 0); +lean_inc(x_86); +x_87 = lean_ctor_get(x_86, 2); +lean_inc(x_87); +x_88 = lean_ctor_get(x_8, 0); +lean_inc(x_88); lean_dec(x_8); -x_85 = !lean_is_exclusive(x_9); -if (x_85 == 0) -{ -lean_object* x_86; uint8_t x_87; -x_86 = lean_ctor_get(x_9, 0); -lean_dec(x_86); -x_87 = !lean_is_exclusive(x_81); -if (x_87 == 0) -{ -lean_object* x_88; uint8_t x_89; -x_88 = lean_ctor_get(x_81, 0); -lean_dec(x_88); -x_89 = !lean_is_exclusive(x_82); +x_89 = !lean_is_exclusive(x_9); if (x_89 == 0) { lean_object* x_90; uint8_t x_91; -x_90 = lean_ctor_get(x_82, 2); +x_90 = lean_ctor_get(x_9, 0); lean_dec(x_90); -x_91 = !lean_is_exclusive(x_83); +x_91 = !lean_is_exclusive(x_85); if (x_91 == 0) { -lean_object* x_92; lean_object* x_93; -x_92 = lean_ctor_get(x_83, 2); +lean_object* x_92; uint8_t x_93; +x_92 = lean_ctor_get(x_85, 0); lean_dec(x_92); -lean_ctor_set(x_83, 2, x_7); -x_93 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_93, 0, x_84); -lean_ctor_set(x_93, 1, x_9); -return x_93; +x_93 = !lean_is_exclusive(x_86); +if (x_93 == 0) +{ +lean_object* x_94; uint8_t x_95; +x_94 = lean_ctor_get(x_86, 2); +lean_dec(x_94); +x_95 = !lean_is_exclusive(x_87); +if (x_95 == 0) +{ +lean_object* x_96; lean_object* x_97; +x_96 = lean_ctor_get(x_87, 2); +lean_dec(x_96); +lean_ctor_set(x_87, 2, x_7); +x_97 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_97, 0, x_88); +lean_ctor_set(x_97, 1, x_9); +return x_97; } else { -lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; -x_94 = lean_ctor_get(x_83, 0); -x_95 = lean_ctor_get(x_83, 1); -x_96 = lean_ctor_get(x_83, 3); -lean_inc(x_96); -lean_inc(x_95); -lean_inc(x_94); -lean_dec(x_83); -x_97 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_97, 0, x_94); -lean_ctor_set(x_97, 1, x_95); -lean_ctor_set(x_97, 2, x_7); -lean_ctor_set(x_97, 3, x_96); -lean_ctor_set(x_82, 2, x_97); -x_98 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_98, 0, x_84); -lean_ctor_set(x_98, 1, x_9); -return x_98; -} -} -else -{ -lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; -x_99 = lean_ctor_get(x_82, 0); -x_100 = lean_ctor_get(x_82, 1); -x_101 = lean_ctor_get(x_82, 3); -x_102 = lean_ctor_get(x_82, 4); -x_103 = lean_ctor_get(x_82, 5); -lean_inc(x_103); -lean_inc(x_102); +lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; +x_98 = lean_ctor_get(x_87, 0); +x_99 = lean_ctor_get(x_87, 1); +x_100 = lean_ctor_get(x_87, 3); +x_101 = lean_ctor_get(x_87, 4); lean_inc(x_101); lean_inc(x_100); lean_inc(x_99); -lean_dec(x_82); -x_104 = lean_ctor_get(x_83, 0); -lean_inc(x_104); -x_105 = lean_ctor_get(x_83, 1); -lean_inc(x_105); -x_106 = lean_ctor_get(x_83, 3); +lean_inc(x_98); +lean_dec(x_87); +x_102 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_102, 0, x_98); +lean_ctor_set(x_102, 1, x_99); +lean_ctor_set(x_102, 2, x_7); +lean_ctor_set(x_102, 3, x_100); +lean_ctor_set(x_102, 4, x_101); +lean_ctor_set(x_86, 2, x_102); +x_103 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_103, 0, x_88); +lean_ctor_set(x_103, 1, x_9); +return x_103; +} +} +else +{ +lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; +x_104 = lean_ctor_get(x_86, 0); +x_105 = lean_ctor_get(x_86, 1); +x_106 = lean_ctor_get(x_86, 3); +x_107 = lean_ctor_get(x_86, 4); +x_108 = lean_ctor_get(x_86, 5); +lean_inc(x_108); +lean_inc(x_107); lean_inc(x_106); -if (lean_is_exclusive(x_83)) { - lean_ctor_release(x_83, 0); - lean_ctor_release(x_83, 1); - lean_ctor_release(x_83, 2); - lean_ctor_release(x_83, 3); - x_107 = x_83; -} else { - lean_dec_ref(x_83); - x_107 = lean_box(0); -} -if (lean_is_scalar(x_107)) { - x_108 = lean_alloc_ctor(0, 4, 0); -} else { - x_108 = x_107; -} -lean_ctor_set(x_108, 0, x_104); -lean_ctor_set(x_108, 1, x_105); -lean_ctor_set(x_108, 2, x_7); -lean_ctor_set(x_108, 3, x_106); -x_109 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_109, 0, x_99); -lean_ctor_set(x_109, 1, x_100); -lean_ctor_set(x_109, 2, x_108); -lean_ctor_set(x_109, 3, x_101); -lean_ctor_set(x_109, 4, x_102); -lean_ctor_set(x_109, 5, x_103); -lean_ctor_set(x_81, 0, x_109); -x_110 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_110, 0, x_84); -lean_ctor_set(x_110, 1, x_9); -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; -x_111 = lean_ctor_get(x_81, 1); -x_112 = lean_ctor_get(x_81, 2); -x_113 = lean_ctor_get(x_81, 3); -x_114 = lean_ctor_get(x_81, 4); -x_115 = lean_ctor_get(x_81, 5); -lean_inc(x_115); -lean_inc(x_114); -lean_inc(x_113); -lean_inc(x_112); +lean_inc(x_105); +lean_inc(x_104); +lean_dec(x_86); +x_109 = lean_ctor_get(x_87, 0); +lean_inc(x_109); +x_110 = lean_ctor_get(x_87, 1); +lean_inc(x_110); +x_111 = lean_ctor_get(x_87, 3); lean_inc(x_111); -lean_dec(x_81); -x_116 = lean_ctor_get(x_82, 0); -lean_inc(x_116); -x_117 = lean_ctor_get(x_82, 1); -lean_inc(x_117); -x_118 = lean_ctor_get(x_82, 3); -lean_inc(x_118); -x_119 = lean_ctor_get(x_82, 4); -lean_inc(x_119); -x_120 = lean_ctor_get(x_82, 5); -lean_inc(x_120); -if (lean_is_exclusive(x_82)) { - lean_ctor_release(x_82, 0); - lean_ctor_release(x_82, 1); - lean_ctor_release(x_82, 2); - lean_ctor_release(x_82, 3); - lean_ctor_release(x_82, 4); - lean_ctor_release(x_82, 5); - x_121 = x_82; +x_112 = lean_ctor_get(x_87, 4); +lean_inc(x_112); +if (lean_is_exclusive(x_87)) { + lean_ctor_release(x_87, 0); + lean_ctor_release(x_87, 1); + lean_ctor_release(x_87, 2); + lean_ctor_release(x_87, 3); + lean_ctor_release(x_87, 4); + x_113 = x_87; } else { - lean_dec_ref(x_82); - x_121 = lean_box(0); + lean_dec_ref(x_87); + x_113 = lean_box(0); } -x_122 = lean_ctor_get(x_83, 0); -lean_inc(x_122); -x_123 = lean_ctor_get(x_83, 1); -lean_inc(x_123); -x_124 = lean_ctor_get(x_83, 3); -lean_inc(x_124); -if (lean_is_exclusive(x_83)) { - lean_ctor_release(x_83, 0); - lean_ctor_release(x_83, 1); - lean_ctor_release(x_83, 2); - lean_ctor_release(x_83, 3); - x_125 = x_83; +if (lean_is_scalar(x_113)) { + x_114 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_83); - x_125 = lean_box(0); + x_114 = x_113; } -if (lean_is_scalar(x_125)) { - x_126 = lean_alloc_ctor(0, 4, 0); -} else { - x_126 = x_125; -} -lean_ctor_set(x_126, 0, x_122); -lean_ctor_set(x_126, 1, x_123); -lean_ctor_set(x_126, 2, x_7); -lean_ctor_set(x_126, 3, x_124); -if (lean_is_scalar(x_121)) { - x_127 = lean_alloc_ctor(0, 6, 0); -} else { - x_127 = x_121; -} -lean_ctor_set(x_127, 0, x_116); -lean_ctor_set(x_127, 1, x_117); -lean_ctor_set(x_127, 2, x_126); -lean_ctor_set(x_127, 3, x_118); -lean_ctor_set(x_127, 4, x_119); -lean_ctor_set(x_127, 5, x_120); -x_128 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_128, 0, x_127); -lean_ctor_set(x_128, 1, x_111); -lean_ctor_set(x_128, 2, x_112); -lean_ctor_set(x_128, 3, x_113); -lean_ctor_set(x_128, 4, x_114); -lean_ctor_set(x_128, 5, x_115); -lean_ctor_set(x_9, 0, x_128); -x_129 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_129, 0, x_84); -lean_ctor_set(x_129, 1, x_9); -return x_129; +lean_ctor_set(x_114, 0, x_109); +lean_ctor_set(x_114, 1, x_110); +lean_ctor_set(x_114, 2, x_7); +lean_ctor_set(x_114, 3, x_111); +lean_ctor_set(x_114, 4, x_112); +x_115 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_115, 0, x_104); +lean_ctor_set(x_115, 1, x_105); +lean_ctor_set(x_115, 2, x_114); +lean_ctor_set(x_115, 3, x_106); +lean_ctor_set(x_115, 4, x_107); +lean_ctor_set(x_115, 5, x_108); +lean_ctor_set(x_85, 0, x_115); +x_116 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_116, 0, x_88); +lean_ctor_set(x_116, 1, x_9); +return x_116; } } else { -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; -x_130 = lean_ctor_get(x_9, 1); +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; +x_117 = lean_ctor_get(x_85, 1); +x_118 = lean_ctor_get(x_85, 2); +x_119 = lean_ctor_get(x_85, 3); +x_120 = lean_ctor_get(x_85, 4); +x_121 = lean_ctor_get(x_85, 5); +lean_inc(x_121); +lean_inc(x_120); +lean_inc(x_119); +lean_inc(x_118); +lean_inc(x_117); +lean_dec(x_85); +x_122 = lean_ctor_get(x_86, 0); +lean_inc(x_122); +x_123 = lean_ctor_get(x_86, 1); +lean_inc(x_123); +x_124 = lean_ctor_get(x_86, 3); +lean_inc(x_124); +x_125 = lean_ctor_get(x_86, 4); +lean_inc(x_125); +x_126 = lean_ctor_get(x_86, 5); +lean_inc(x_126); +if (lean_is_exclusive(x_86)) { + lean_ctor_release(x_86, 0); + lean_ctor_release(x_86, 1); + lean_ctor_release(x_86, 2); + lean_ctor_release(x_86, 3); + lean_ctor_release(x_86, 4); + lean_ctor_release(x_86, 5); + x_127 = x_86; +} else { + lean_dec_ref(x_86); + x_127 = lean_box(0); +} +x_128 = lean_ctor_get(x_87, 0); +lean_inc(x_128); +x_129 = lean_ctor_get(x_87, 1); +lean_inc(x_129); +x_130 = lean_ctor_get(x_87, 3); lean_inc(x_130); -lean_dec(x_9); -x_131 = lean_ctor_get(x_81, 1); +x_131 = lean_ctor_get(x_87, 4); lean_inc(x_131); -x_132 = lean_ctor_get(x_81, 2); -lean_inc(x_132); -x_133 = lean_ctor_get(x_81, 3); -lean_inc(x_133); -x_134 = lean_ctor_get(x_81, 4); -lean_inc(x_134); -x_135 = lean_ctor_get(x_81, 5); -lean_inc(x_135); -if (lean_is_exclusive(x_81)) { - lean_ctor_release(x_81, 0); - lean_ctor_release(x_81, 1); - lean_ctor_release(x_81, 2); - lean_ctor_release(x_81, 3); - lean_ctor_release(x_81, 4); - lean_ctor_release(x_81, 5); - x_136 = x_81; +if (lean_is_exclusive(x_87)) { + lean_ctor_release(x_87, 0); + lean_ctor_release(x_87, 1); + lean_ctor_release(x_87, 2); + lean_ctor_release(x_87, 3); + lean_ctor_release(x_87, 4); + x_132 = x_87; } else { - lean_dec_ref(x_81); - x_136 = lean_box(0); + lean_dec_ref(x_87); + x_132 = lean_box(0); } -x_137 = lean_ctor_get(x_82, 0); +if (lean_is_scalar(x_132)) { + x_133 = lean_alloc_ctor(0, 5, 0); +} else { + x_133 = x_132; +} +lean_ctor_set(x_133, 0, x_128); +lean_ctor_set(x_133, 1, x_129); +lean_ctor_set(x_133, 2, x_7); +lean_ctor_set(x_133, 3, x_130); +lean_ctor_set(x_133, 4, x_131); +if (lean_is_scalar(x_127)) { + x_134 = lean_alloc_ctor(0, 6, 0); +} else { + x_134 = x_127; +} +lean_ctor_set(x_134, 0, x_122); +lean_ctor_set(x_134, 1, x_123); +lean_ctor_set(x_134, 2, x_133); +lean_ctor_set(x_134, 3, x_124); +lean_ctor_set(x_134, 4, x_125); +lean_ctor_set(x_134, 5, x_126); +x_135 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_135, 0, x_134); +lean_ctor_set(x_135, 1, x_117); +lean_ctor_set(x_135, 2, x_118); +lean_ctor_set(x_135, 3, x_119); +lean_ctor_set(x_135, 4, x_120); +lean_ctor_set(x_135, 5, x_121); +lean_ctor_set(x_9, 0, x_135); +x_136 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_136, 0, x_88); +lean_ctor_set(x_136, 1, x_9); +return x_136; +} +} +else +{ +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; +x_137 = lean_ctor_get(x_9, 1); lean_inc(x_137); -x_138 = lean_ctor_get(x_82, 1); +lean_dec(x_9); +x_138 = lean_ctor_get(x_85, 1); lean_inc(x_138); -x_139 = lean_ctor_get(x_82, 3); +x_139 = lean_ctor_get(x_85, 2); lean_inc(x_139); -x_140 = lean_ctor_get(x_82, 4); +x_140 = lean_ctor_get(x_85, 3); lean_inc(x_140); -x_141 = lean_ctor_get(x_82, 5); +x_141 = lean_ctor_get(x_85, 4); lean_inc(x_141); -if (lean_is_exclusive(x_82)) { - lean_ctor_release(x_82, 0); - lean_ctor_release(x_82, 1); - lean_ctor_release(x_82, 2); - lean_ctor_release(x_82, 3); - lean_ctor_release(x_82, 4); - lean_ctor_release(x_82, 5); - x_142 = x_82; +x_142 = lean_ctor_get(x_85, 5); +lean_inc(x_142); +if (lean_is_exclusive(x_85)) { + lean_ctor_release(x_85, 0); + lean_ctor_release(x_85, 1); + lean_ctor_release(x_85, 2); + lean_ctor_release(x_85, 3); + lean_ctor_release(x_85, 4); + lean_ctor_release(x_85, 5); + x_143 = x_85; } else { - lean_dec_ref(x_82); - x_142 = lean_box(0); + lean_dec_ref(x_85); + x_143 = lean_box(0); } -x_143 = lean_ctor_get(x_83, 0); -lean_inc(x_143); -x_144 = lean_ctor_get(x_83, 1); +x_144 = lean_ctor_get(x_86, 0); lean_inc(x_144); -x_145 = lean_ctor_get(x_83, 3); +x_145 = lean_ctor_get(x_86, 1); lean_inc(x_145); -if (lean_is_exclusive(x_83)) { - lean_ctor_release(x_83, 0); - lean_ctor_release(x_83, 1); - lean_ctor_release(x_83, 2); - lean_ctor_release(x_83, 3); - x_146 = x_83; +x_146 = lean_ctor_get(x_86, 3); +lean_inc(x_146); +x_147 = lean_ctor_get(x_86, 4); +lean_inc(x_147); +x_148 = lean_ctor_get(x_86, 5); +lean_inc(x_148); +if (lean_is_exclusive(x_86)) { + lean_ctor_release(x_86, 0); + lean_ctor_release(x_86, 1); + lean_ctor_release(x_86, 2); + lean_ctor_release(x_86, 3); + lean_ctor_release(x_86, 4); + lean_ctor_release(x_86, 5); + x_149 = x_86; } else { - lean_dec_ref(x_83); - x_146 = lean_box(0); + lean_dec_ref(x_86); + x_149 = lean_box(0); } -if (lean_is_scalar(x_146)) { - x_147 = lean_alloc_ctor(0, 4, 0); +x_150 = lean_ctor_get(x_87, 0); +lean_inc(x_150); +x_151 = lean_ctor_get(x_87, 1); +lean_inc(x_151); +x_152 = lean_ctor_get(x_87, 3); +lean_inc(x_152); +x_153 = lean_ctor_get(x_87, 4); +lean_inc(x_153); +if (lean_is_exclusive(x_87)) { + lean_ctor_release(x_87, 0); + lean_ctor_release(x_87, 1); + lean_ctor_release(x_87, 2); + lean_ctor_release(x_87, 3); + lean_ctor_release(x_87, 4); + x_154 = x_87; } else { - x_147 = x_146; + lean_dec_ref(x_87); + x_154 = lean_box(0); } -lean_ctor_set(x_147, 0, x_143); -lean_ctor_set(x_147, 1, x_144); -lean_ctor_set(x_147, 2, x_7); -lean_ctor_set(x_147, 3, x_145); -if (lean_is_scalar(x_142)) { - x_148 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_154)) { + x_155 = lean_alloc_ctor(0, 5, 0); } else { - x_148 = x_142; + x_155 = x_154; } -lean_ctor_set(x_148, 0, x_137); -lean_ctor_set(x_148, 1, x_138); -lean_ctor_set(x_148, 2, x_147); -lean_ctor_set(x_148, 3, x_139); -lean_ctor_set(x_148, 4, x_140); -lean_ctor_set(x_148, 5, x_141); -if (lean_is_scalar(x_136)) { - x_149 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_155, 0, x_150); +lean_ctor_set(x_155, 1, x_151); +lean_ctor_set(x_155, 2, x_7); +lean_ctor_set(x_155, 3, x_152); +lean_ctor_set(x_155, 4, x_153); +if (lean_is_scalar(x_149)) { + x_156 = lean_alloc_ctor(0, 6, 0); } else { - x_149 = x_136; + x_156 = x_149; } -lean_ctor_set(x_149, 0, x_148); -lean_ctor_set(x_149, 1, x_131); -lean_ctor_set(x_149, 2, x_132); -lean_ctor_set(x_149, 3, x_133); -lean_ctor_set(x_149, 4, x_134); -lean_ctor_set(x_149, 5, x_135); -x_150 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_150, 0, x_149); -lean_ctor_set(x_150, 1, x_130); -x_151 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_151, 0, x_84); -lean_ctor_set(x_151, 1, x_150); -return x_151; +lean_ctor_set(x_156, 0, x_144); +lean_ctor_set(x_156, 1, x_145); +lean_ctor_set(x_156, 2, x_155); +lean_ctor_set(x_156, 3, x_146); +lean_ctor_set(x_156, 4, x_147); +lean_ctor_set(x_156, 5, x_148); +if (lean_is_scalar(x_143)) { + x_157 = lean_alloc_ctor(0, 6, 0); +} else { + x_157 = x_143; +} +lean_ctor_set(x_157, 0, x_156); +lean_ctor_set(x_157, 1, x_138); +lean_ctor_set(x_157, 2, x_139); +lean_ctor_set(x_157, 3, x_140); +lean_ctor_set(x_157, 4, x_141); +lean_ctor_set(x_157, 5, x_142); +x_158 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_158, 0, x_157); +lean_ctor_set(x_158, 1, x_137); +x_159 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_159, 0, x_88); +lean_ctor_set(x_159, 1, x_158); +return x_159; } } } @@ -7267,7 +7297,7 @@ return x_5; } else { -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_155; lean_object* x_156; +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_163; lean_object* x_164; x_6 = lean_ctor_get(x_4, 0); lean_inc(x_6); x_7 = lean_ctor_get(x_6, 0); @@ -7279,75 +7309,75 @@ lean_dec(x_7); x_9 = lean_ctor_get(x_8, 2); lean_inc(x_9); lean_dec(x_8); -x_155 = l_Lean_Elab_Tactic_resetSynthInstanceCache___closed__1; +x_163 = l_Lean_Elab_Tactic_resetSynthInstanceCache___closed__1; lean_inc(x_3); -x_156 = l_Lean_Elab_Tactic_liftTermElabM___rarg(x_155, x_3, x_4); -if (lean_obj_tag(x_156) == 0) +x_164 = l_Lean_Elab_Tactic_liftTermElabM___rarg(x_163, x_3, x_4); +if (lean_obj_tag(x_164) == 0) { -lean_object* x_157; lean_object* x_158; lean_object* x_159; -x_157 = lean_ctor_get(x_156, 1); -lean_inc(x_157); -lean_dec(x_156); -x_158 = l_Lean_Elab_Tactic_save(x_157); -x_159 = lean_apply_2(x_2, x_3, x_157); -if (lean_obj_tag(x_159) == 0) +lean_object* x_165; lean_object* x_166; lean_object* x_167; +x_165 = lean_ctor_get(x_164, 1); +lean_inc(x_165); +lean_dec(x_164); +x_166 = l_Lean_Elab_Tactic_save(x_165); +x_167 = lean_apply_2(x_2, x_3, x_165); +if (lean_obj_tag(x_167) == 0) { -lean_object* x_160; lean_object* x_161; lean_object* x_162; -lean_dec(x_158); -x_160 = lean_ctor_get(x_159, 0); -lean_inc(x_160); -x_161 = lean_ctor_get(x_159, 1); -lean_inc(x_161); -lean_dec(x_159); -x_162 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_162, 0, x_160); -x_10 = x_162; -x_11 = x_161; -goto block_154; +lean_object* x_168; lean_object* x_169; lean_object* x_170; +lean_dec(x_166); +x_168 = lean_ctor_get(x_167, 0); +lean_inc(x_168); +x_169 = lean_ctor_get(x_167, 1); +lean_inc(x_169); +lean_dec(x_167); +x_170 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_170, 0, x_168); +x_10 = x_170; +x_11 = x_169; +goto block_162; } else { -lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; -x_163 = lean_ctor_get(x_159, 0); -lean_inc(x_163); -x_164 = lean_ctor_get(x_159, 1); -lean_inc(x_164); -lean_dec(x_159); -x_165 = l_Lean_Elab_Tactic_restore(x_164, x_158); -lean_dec(x_158); -x_166 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_166, 0, x_163); -x_10 = x_166; -x_11 = x_165; -goto block_154; +lean_object* x_171; lean_object* x_172; lean_object* x_173; lean_object* x_174; +x_171 = lean_ctor_get(x_167, 0); +lean_inc(x_171); +x_172 = lean_ctor_get(x_167, 1); +lean_inc(x_172); +lean_dec(x_167); +x_173 = l_Lean_Elab_Tactic_restore(x_172, x_166); +lean_dec(x_166); +x_174 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_174, 0, x_171); +x_10 = x_174; +x_11 = x_173; +goto block_162; } } else { -uint8_t x_167; +uint8_t x_175; lean_dec(x_9); lean_dec(x_3); lean_dec(x_2); -x_167 = !lean_is_exclusive(x_156); -if (x_167 == 0) +x_175 = !lean_is_exclusive(x_164); +if (x_175 == 0) { -return x_156; +return x_164; } else { -lean_object* x_168; lean_object* x_169; lean_object* x_170; -x_168 = lean_ctor_get(x_156, 0); -x_169 = lean_ctor_get(x_156, 1); -lean_inc(x_169); -lean_inc(x_168); -lean_dec(x_156); -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; +lean_object* x_176; lean_object* x_177; lean_object* x_178; +x_176 = lean_ctor_get(x_164, 0); +x_177 = lean_ctor_get(x_164, 1); +lean_inc(x_177); +lean_inc(x_176); +lean_dec(x_164); +x_178 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_178, 0, x_176); +lean_ctor_set(x_178, 1, x_177); +return x_178; } } -block_154: +block_162: { if (lean_obj_tag(x_10) == 0) { @@ -7393,103 +7423,110 @@ return x_24; } else { -lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; +lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; x_25 = lean_ctor_get(x_14, 0); x_26 = lean_ctor_get(x_14, 1); x_27 = lean_ctor_get(x_14, 3); +x_28 = lean_ctor_get(x_14, 4); +lean_inc(x_28); lean_inc(x_27); lean_inc(x_26); lean_inc(x_25); lean_dec(x_14); -x_28 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_28, 0, x_25); -lean_ctor_set(x_28, 1, x_26); -lean_ctor_set(x_28, 2, x_9); -lean_ctor_set(x_28, 3, x_27); -lean_ctor_set(x_13, 2, x_28); -x_29 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_29, 0, x_15); -lean_ctor_set(x_29, 1, x_11); -return x_29; +x_29 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_29, 0, x_25); +lean_ctor_set(x_29, 1, x_26); +lean_ctor_set(x_29, 2, x_9); +lean_ctor_set(x_29, 3, x_27); +lean_ctor_set(x_29, 4, x_28); +lean_ctor_set(x_13, 2, x_29); +x_30 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_30, 0, x_15); +lean_ctor_set(x_30, 1, x_11); +return x_30; } } else { -lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; -x_30 = lean_ctor_get(x_13, 0); -x_31 = lean_ctor_get(x_13, 1); -x_32 = lean_ctor_get(x_13, 3); -x_33 = lean_ctor_get(x_13, 4); -x_34 = lean_ctor_get(x_13, 5); +lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; +x_31 = lean_ctor_get(x_13, 0); +x_32 = lean_ctor_get(x_13, 1); +x_33 = lean_ctor_get(x_13, 3); +x_34 = lean_ctor_get(x_13, 4); +x_35 = lean_ctor_get(x_13, 5); +lean_inc(x_35); lean_inc(x_34); lean_inc(x_33); lean_inc(x_32); lean_inc(x_31); -lean_inc(x_30); lean_dec(x_13); -x_35 = lean_ctor_get(x_14, 0); -lean_inc(x_35); -x_36 = lean_ctor_get(x_14, 1); +x_36 = lean_ctor_get(x_14, 0); lean_inc(x_36); -x_37 = lean_ctor_get(x_14, 3); +x_37 = lean_ctor_get(x_14, 1); lean_inc(x_37); +x_38 = lean_ctor_get(x_14, 3); +lean_inc(x_38); +x_39 = lean_ctor_get(x_14, 4); +lean_inc(x_39); if (lean_is_exclusive(x_14)) { lean_ctor_release(x_14, 0); lean_ctor_release(x_14, 1); lean_ctor_release(x_14, 2); lean_ctor_release(x_14, 3); - x_38 = x_14; + lean_ctor_release(x_14, 4); + x_40 = x_14; } else { lean_dec_ref(x_14); - x_38 = lean_box(0); + x_40 = lean_box(0); } -if (lean_is_scalar(x_38)) { - x_39 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_40)) { + x_41 = lean_alloc_ctor(0, 5, 0); } else { - x_39 = x_38; + x_41 = x_40; } -lean_ctor_set(x_39, 0, x_35); -lean_ctor_set(x_39, 1, x_36); -lean_ctor_set(x_39, 2, x_9); -lean_ctor_set(x_39, 3, x_37); -x_40 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_40, 0, x_30); -lean_ctor_set(x_40, 1, x_31); -lean_ctor_set(x_40, 2, x_39); -lean_ctor_set(x_40, 3, x_32); -lean_ctor_set(x_40, 4, x_33); -lean_ctor_set(x_40, 5, x_34); -lean_ctor_set(x_12, 0, x_40); -x_41 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_41, 0, x_15); -lean_ctor_set(x_41, 1, x_11); -return x_41; +lean_ctor_set(x_41, 0, x_36); +lean_ctor_set(x_41, 1, x_37); +lean_ctor_set(x_41, 2, x_9); +lean_ctor_set(x_41, 3, x_38); +lean_ctor_set(x_41, 4, x_39); +x_42 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_42, 0, x_31); +lean_ctor_set(x_42, 1, x_32); +lean_ctor_set(x_42, 2, x_41); +lean_ctor_set(x_42, 3, x_33); +lean_ctor_set(x_42, 4, x_34); +lean_ctor_set(x_42, 5, x_35); +lean_ctor_set(x_12, 0, x_42); +x_43 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_43, 0, x_15); +lean_ctor_set(x_43, 1, x_11); +return x_43; } } else { -lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; 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; -x_42 = lean_ctor_get(x_12, 1); -x_43 = lean_ctor_get(x_12, 2); -x_44 = lean_ctor_get(x_12, 3); -x_45 = lean_ctor_get(x_12, 4); -x_46 = lean_ctor_get(x_12, 5); +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; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; +x_44 = lean_ctor_get(x_12, 1); +x_45 = lean_ctor_get(x_12, 2); +x_46 = lean_ctor_get(x_12, 3); +x_47 = lean_ctor_get(x_12, 4); +x_48 = lean_ctor_get(x_12, 5); +lean_inc(x_48); +lean_inc(x_47); lean_inc(x_46); lean_inc(x_45); lean_inc(x_44); -lean_inc(x_43); -lean_inc(x_42); lean_dec(x_12); -x_47 = lean_ctor_get(x_13, 0); -lean_inc(x_47); -x_48 = lean_ctor_get(x_13, 1); -lean_inc(x_48); -x_49 = lean_ctor_get(x_13, 3); +x_49 = lean_ctor_get(x_13, 0); lean_inc(x_49); -x_50 = lean_ctor_get(x_13, 4); +x_50 = lean_ctor_get(x_13, 1); lean_inc(x_50); -x_51 = lean_ctor_get(x_13, 5); +x_51 = lean_ctor_get(x_13, 3); lean_inc(x_51); +x_52 = lean_ctor_get(x_13, 4); +lean_inc(x_52); +x_53 = lean_ctor_get(x_13, 5); +lean_inc(x_53); if (lean_is_exclusive(x_13)) { lean_ctor_release(x_13, 0); lean_ctor_release(x_13, 1); @@ -7497,77 +7534,81 @@ if (lean_is_exclusive(x_13)) { lean_ctor_release(x_13, 3); lean_ctor_release(x_13, 4); lean_ctor_release(x_13, 5); - x_52 = x_13; + x_54 = x_13; } else { lean_dec_ref(x_13); - x_52 = lean_box(0); + x_54 = lean_box(0); } -x_53 = lean_ctor_get(x_14, 0); -lean_inc(x_53); -x_54 = lean_ctor_get(x_14, 1); -lean_inc(x_54); -x_55 = lean_ctor_get(x_14, 3); +x_55 = lean_ctor_get(x_14, 0); lean_inc(x_55); +x_56 = lean_ctor_get(x_14, 1); +lean_inc(x_56); +x_57 = lean_ctor_get(x_14, 3); +lean_inc(x_57); +x_58 = lean_ctor_get(x_14, 4); +lean_inc(x_58); if (lean_is_exclusive(x_14)) { lean_ctor_release(x_14, 0); lean_ctor_release(x_14, 1); lean_ctor_release(x_14, 2); lean_ctor_release(x_14, 3); - x_56 = x_14; + lean_ctor_release(x_14, 4); + x_59 = x_14; } else { lean_dec_ref(x_14); - x_56 = lean_box(0); + x_59 = lean_box(0); } -if (lean_is_scalar(x_56)) { - x_57 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_59)) { + x_60 = lean_alloc_ctor(0, 5, 0); } else { - x_57 = x_56; + x_60 = x_59; } -lean_ctor_set(x_57, 0, x_53); -lean_ctor_set(x_57, 1, x_54); -lean_ctor_set(x_57, 2, x_9); -lean_ctor_set(x_57, 3, x_55); -if (lean_is_scalar(x_52)) { - x_58 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_60, 0, x_55); +lean_ctor_set(x_60, 1, x_56); +lean_ctor_set(x_60, 2, x_9); +lean_ctor_set(x_60, 3, x_57); +lean_ctor_set(x_60, 4, x_58); +if (lean_is_scalar(x_54)) { + x_61 = lean_alloc_ctor(0, 6, 0); } else { - x_58 = x_52; + x_61 = x_54; } -lean_ctor_set(x_58, 0, x_47); -lean_ctor_set(x_58, 1, x_48); -lean_ctor_set(x_58, 2, x_57); -lean_ctor_set(x_58, 3, x_49); -lean_ctor_set(x_58, 4, x_50); -lean_ctor_set(x_58, 5, x_51); -x_59 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_59, 0, x_58); -lean_ctor_set(x_59, 1, x_42); -lean_ctor_set(x_59, 2, x_43); -lean_ctor_set(x_59, 3, x_44); -lean_ctor_set(x_59, 4, x_45); -lean_ctor_set(x_59, 5, x_46); -lean_ctor_set(x_11, 0, x_59); -x_60 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_60, 0, x_15); -lean_ctor_set(x_60, 1, x_11); -return x_60; +lean_ctor_set(x_61, 0, x_49); +lean_ctor_set(x_61, 1, x_50); +lean_ctor_set(x_61, 2, x_60); +lean_ctor_set(x_61, 3, x_51); +lean_ctor_set(x_61, 4, x_52); +lean_ctor_set(x_61, 5, x_53); +x_62 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_62, 0, x_61); +lean_ctor_set(x_62, 1, x_44); +lean_ctor_set(x_62, 2, x_45); +lean_ctor_set(x_62, 3, x_46); +lean_ctor_set(x_62, 4, x_47); +lean_ctor_set(x_62, 5, x_48); +lean_ctor_set(x_11, 0, x_62); +x_63 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_63, 0, x_15); +lean_ctor_set(x_63, 1, x_11); +return x_63; } } else { -lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; -x_61 = lean_ctor_get(x_11, 1); -lean_inc(x_61); -lean_dec(x_11); -x_62 = lean_ctor_get(x_12, 1); -lean_inc(x_62); -x_63 = lean_ctor_get(x_12, 2); -lean_inc(x_63); -x_64 = lean_ctor_get(x_12, 3); +lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; +x_64 = lean_ctor_get(x_11, 1); lean_inc(x_64); -x_65 = lean_ctor_get(x_12, 4); +lean_dec(x_11); +x_65 = lean_ctor_get(x_12, 1); lean_inc(x_65); -x_66 = lean_ctor_get(x_12, 5); +x_66 = lean_ctor_get(x_12, 2); lean_inc(x_66); +x_67 = lean_ctor_get(x_12, 3); +lean_inc(x_67); +x_68 = lean_ctor_get(x_12, 4); +lean_inc(x_68); +x_69 = lean_ctor_get(x_12, 5); +lean_inc(x_69); if (lean_is_exclusive(x_12)) { lean_ctor_release(x_12, 0); lean_ctor_release(x_12, 1); @@ -7575,21 +7616,21 @@ if (lean_is_exclusive(x_12)) { lean_ctor_release(x_12, 3); lean_ctor_release(x_12, 4); lean_ctor_release(x_12, 5); - x_67 = x_12; + x_70 = x_12; } else { lean_dec_ref(x_12); - x_67 = lean_box(0); + x_70 = lean_box(0); } -x_68 = lean_ctor_get(x_13, 0); -lean_inc(x_68); -x_69 = lean_ctor_get(x_13, 1); -lean_inc(x_69); -x_70 = lean_ctor_get(x_13, 3); -lean_inc(x_70); -x_71 = lean_ctor_get(x_13, 4); +x_71 = lean_ctor_get(x_13, 0); lean_inc(x_71); -x_72 = lean_ctor_get(x_13, 5); +x_72 = lean_ctor_get(x_13, 1); lean_inc(x_72); +x_73 = lean_ctor_get(x_13, 3); +lean_inc(x_73); +x_74 = lean_ctor_get(x_13, 4); +lean_inc(x_74); +x_75 = lean_ctor_get(x_13, 5); +lean_inc(x_75); if (lean_is_exclusive(x_13)) { lean_ctor_release(x_13, 0); lean_ctor_release(x_13, 1); @@ -7597,374 +7638,393 @@ if (lean_is_exclusive(x_13)) { lean_ctor_release(x_13, 3); lean_ctor_release(x_13, 4); lean_ctor_release(x_13, 5); - x_73 = x_13; + x_76 = x_13; } else { lean_dec_ref(x_13); - x_73 = lean_box(0); + x_76 = lean_box(0); } -x_74 = lean_ctor_get(x_14, 0); -lean_inc(x_74); -x_75 = lean_ctor_get(x_14, 1); -lean_inc(x_75); -x_76 = lean_ctor_get(x_14, 3); -lean_inc(x_76); +x_77 = lean_ctor_get(x_14, 0); +lean_inc(x_77); +x_78 = lean_ctor_get(x_14, 1); +lean_inc(x_78); +x_79 = lean_ctor_get(x_14, 3); +lean_inc(x_79); +x_80 = lean_ctor_get(x_14, 4); +lean_inc(x_80); if (lean_is_exclusive(x_14)) { lean_ctor_release(x_14, 0); lean_ctor_release(x_14, 1); lean_ctor_release(x_14, 2); lean_ctor_release(x_14, 3); - x_77 = x_14; + lean_ctor_release(x_14, 4); + x_81 = x_14; } else { lean_dec_ref(x_14); - x_77 = lean_box(0); + x_81 = lean_box(0); } -if (lean_is_scalar(x_77)) { - x_78 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_81)) { + x_82 = lean_alloc_ctor(0, 5, 0); } else { - x_78 = x_77; + x_82 = x_81; } -lean_ctor_set(x_78, 0, x_74); -lean_ctor_set(x_78, 1, x_75); -lean_ctor_set(x_78, 2, x_9); -lean_ctor_set(x_78, 3, x_76); -if (lean_is_scalar(x_73)) { - x_79 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_82, 0, x_77); +lean_ctor_set(x_82, 1, x_78); +lean_ctor_set(x_82, 2, x_9); +lean_ctor_set(x_82, 3, x_79); +lean_ctor_set(x_82, 4, x_80); +if (lean_is_scalar(x_76)) { + x_83 = lean_alloc_ctor(0, 6, 0); } else { - x_79 = x_73; + x_83 = x_76; } -lean_ctor_set(x_79, 0, x_68); -lean_ctor_set(x_79, 1, x_69); -lean_ctor_set(x_79, 2, x_78); -lean_ctor_set(x_79, 3, x_70); -lean_ctor_set(x_79, 4, x_71); -lean_ctor_set(x_79, 5, x_72); -if (lean_is_scalar(x_67)) { - x_80 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_83, 0, x_71); +lean_ctor_set(x_83, 1, x_72); +lean_ctor_set(x_83, 2, x_82); +lean_ctor_set(x_83, 3, x_73); +lean_ctor_set(x_83, 4, x_74); +lean_ctor_set(x_83, 5, x_75); +if (lean_is_scalar(x_70)) { + x_84 = lean_alloc_ctor(0, 6, 0); } else { - x_80 = x_67; + x_84 = x_70; } -lean_ctor_set(x_80, 0, x_79); -lean_ctor_set(x_80, 1, x_62); -lean_ctor_set(x_80, 2, x_63); -lean_ctor_set(x_80, 3, x_64); -lean_ctor_set(x_80, 4, x_65); -lean_ctor_set(x_80, 5, x_66); -x_81 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_81, 0, x_80); -lean_ctor_set(x_81, 1, x_61); -x_82 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_82, 0, x_15); -lean_ctor_set(x_82, 1, x_81); -return x_82; +lean_ctor_set(x_84, 0, x_83); +lean_ctor_set(x_84, 1, x_65); +lean_ctor_set(x_84, 2, x_66); +lean_ctor_set(x_84, 3, x_67); +lean_ctor_set(x_84, 4, x_68); +lean_ctor_set(x_84, 5, x_69); +x_85 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_85, 0, x_84); +lean_ctor_set(x_85, 1, x_64); +x_86 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_86, 0, x_15); +lean_ctor_set(x_86, 1, x_85); +return x_86; } } else { -lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; uint8_t x_87; -x_83 = lean_ctor_get(x_11, 0); -lean_inc(x_83); -x_84 = lean_ctor_get(x_83, 0); -lean_inc(x_84); -x_85 = lean_ctor_get(x_84, 2); -lean_inc(x_85); -x_86 = lean_ctor_get(x_10, 0); -lean_inc(x_86); +lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; uint8_t x_91; +x_87 = lean_ctor_get(x_11, 0); +lean_inc(x_87); +x_88 = lean_ctor_get(x_87, 0); +lean_inc(x_88); +x_89 = lean_ctor_get(x_88, 2); +lean_inc(x_89); +x_90 = lean_ctor_get(x_10, 0); +lean_inc(x_90); lean_dec(x_10); -x_87 = !lean_is_exclusive(x_11); -if (x_87 == 0) -{ -lean_object* x_88; uint8_t x_89; -x_88 = lean_ctor_get(x_11, 0); -lean_dec(x_88); -x_89 = !lean_is_exclusive(x_83); -if (x_89 == 0) -{ -lean_object* x_90; uint8_t x_91; -x_90 = lean_ctor_get(x_83, 0); -lean_dec(x_90); -x_91 = !lean_is_exclusive(x_84); +x_91 = !lean_is_exclusive(x_11); if (x_91 == 0) { lean_object* x_92; uint8_t x_93; -x_92 = lean_ctor_get(x_84, 2); +x_92 = lean_ctor_get(x_11, 0); lean_dec(x_92); -x_93 = !lean_is_exclusive(x_85); +x_93 = !lean_is_exclusive(x_87); if (x_93 == 0) { -lean_object* x_94; lean_object* x_95; -x_94 = lean_ctor_get(x_85, 2); +lean_object* x_94; uint8_t x_95; +x_94 = lean_ctor_get(x_87, 0); lean_dec(x_94); -lean_ctor_set(x_85, 2, x_9); -x_95 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_95, 0, x_86); -lean_ctor_set(x_95, 1, x_11); -return x_95; +x_95 = !lean_is_exclusive(x_88); +if (x_95 == 0) +{ +lean_object* x_96; uint8_t x_97; +x_96 = lean_ctor_get(x_88, 2); +lean_dec(x_96); +x_97 = !lean_is_exclusive(x_89); +if (x_97 == 0) +{ +lean_object* x_98; lean_object* x_99; +x_98 = lean_ctor_get(x_89, 2); +lean_dec(x_98); +lean_ctor_set(x_89, 2, x_9); +x_99 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_99, 0, x_90); +lean_ctor_set(x_99, 1, x_11); +return x_99; } else { -lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; -x_96 = lean_ctor_get(x_85, 0); -x_97 = lean_ctor_get(x_85, 1); -x_98 = lean_ctor_get(x_85, 3); -lean_inc(x_98); -lean_inc(x_97); -lean_inc(x_96); -lean_dec(x_85); -x_99 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_99, 0, x_96); -lean_ctor_set(x_99, 1, x_97); -lean_ctor_set(x_99, 2, x_9); -lean_ctor_set(x_99, 3, x_98); -lean_ctor_set(x_84, 2, x_99); -x_100 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_100, 0, x_86); -lean_ctor_set(x_100, 1, x_11); -return x_100; -} -} -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; -x_101 = lean_ctor_get(x_84, 0); -x_102 = lean_ctor_get(x_84, 1); -x_103 = lean_ctor_get(x_84, 3); -x_104 = lean_ctor_get(x_84, 4); -x_105 = lean_ctor_get(x_84, 5); -lean_inc(x_105); -lean_inc(x_104); +lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; +x_100 = lean_ctor_get(x_89, 0); +x_101 = lean_ctor_get(x_89, 1); +x_102 = lean_ctor_get(x_89, 3); +x_103 = lean_ctor_get(x_89, 4); lean_inc(x_103); lean_inc(x_102); lean_inc(x_101); -lean_dec(x_84); -x_106 = lean_ctor_get(x_85, 0); -lean_inc(x_106); -x_107 = lean_ctor_get(x_85, 1); -lean_inc(x_107); -x_108 = lean_ctor_get(x_85, 3); +lean_inc(x_100); +lean_dec(x_89); +x_104 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_104, 0, x_100); +lean_ctor_set(x_104, 1, x_101); +lean_ctor_set(x_104, 2, x_9); +lean_ctor_set(x_104, 3, x_102); +lean_ctor_set(x_104, 4, x_103); +lean_ctor_set(x_88, 2, x_104); +x_105 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_105, 0, x_90); +lean_ctor_set(x_105, 1, x_11); +return x_105; +} +} +else +{ +lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; +x_106 = lean_ctor_get(x_88, 0); +x_107 = lean_ctor_get(x_88, 1); +x_108 = lean_ctor_get(x_88, 3); +x_109 = lean_ctor_get(x_88, 4); +x_110 = lean_ctor_get(x_88, 5); +lean_inc(x_110); +lean_inc(x_109); lean_inc(x_108); -if (lean_is_exclusive(x_85)) { - lean_ctor_release(x_85, 0); - lean_ctor_release(x_85, 1); - lean_ctor_release(x_85, 2); - lean_ctor_release(x_85, 3); - x_109 = x_85; -} else { - lean_dec_ref(x_85); - x_109 = lean_box(0); -} -if (lean_is_scalar(x_109)) { - x_110 = lean_alloc_ctor(0, 4, 0); -} else { - x_110 = x_109; -} -lean_ctor_set(x_110, 0, x_106); -lean_ctor_set(x_110, 1, x_107); -lean_ctor_set(x_110, 2, x_9); -lean_ctor_set(x_110, 3, x_108); -x_111 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_111, 0, x_101); -lean_ctor_set(x_111, 1, x_102); -lean_ctor_set(x_111, 2, x_110); -lean_ctor_set(x_111, 3, x_103); -lean_ctor_set(x_111, 4, x_104); -lean_ctor_set(x_111, 5, x_105); -lean_ctor_set(x_83, 0, x_111); -x_112 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_112, 0, x_86); -lean_ctor_set(x_112, 1, x_11); -return x_112; -} -} -else -{ -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; -x_113 = lean_ctor_get(x_83, 1); -x_114 = lean_ctor_get(x_83, 2); -x_115 = lean_ctor_get(x_83, 3); -x_116 = lean_ctor_get(x_83, 4); -x_117 = lean_ctor_get(x_83, 5); -lean_inc(x_117); -lean_inc(x_116); -lean_inc(x_115); -lean_inc(x_114); +lean_inc(x_107); +lean_inc(x_106); +lean_dec(x_88); +x_111 = lean_ctor_get(x_89, 0); +lean_inc(x_111); +x_112 = lean_ctor_get(x_89, 1); +lean_inc(x_112); +x_113 = lean_ctor_get(x_89, 3); lean_inc(x_113); -lean_dec(x_83); -x_118 = lean_ctor_get(x_84, 0); -lean_inc(x_118); -x_119 = lean_ctor_get(x_84, 1); -lean_inc(x_119); -x_120 = lean_ctor_get(x_84, 3); -lean_inc(x_120); -x_121 = lean_ctor_get(x_84, 4); -lean_inc(x_121); -x_122 = lean_ctor_get(x_84, 5); -lean_inc(x_122); -if (lean_is_exclusive(x_84)) { - lean_ctor_release(x_84, 0); - lean_ctor_release(x_84, 1); - lean_ctor_release(x_84, 2); - lean_ctor_release(x_84, 3); - lean_ctor_release(x_84, 4); - lean_ctor_release(x_84, 5); - x_123 = x_84; +x_114 = lean_ctor_get(x_89, 4); +lean_inc(x_114); +if (lean_is_exclusive(x_89)) { + lean_ctor_release(x_89, 0); + lean_ctor_release(x_89, 1); + lean_ctor_release(x_89, 2); + lean_ctor_release(x_89, 3); + lean_ctor_release(x_89, 4); + x_115 = x_89; } else { - lean_dec_ref(x_84); - x_123 = lean_box(0); + lean_dec_ref(x_89); + x_115 = lean_box(0); } -x_124 = lean_ctor_get(x_85, 0); -lean_inc(x_124); -x_125 = lean_ctor_get(x_85, 1); -lean_inc(x_125); -x_126 = lean_ctor_get(x_85, 3); -lean_inc(x_126); -if (lean_is_exclusive(x_85)) { - lean_ctor_release(x_85, 0); - lean_ctor_release(x_85, 1); - lean_ctor_release(x_85, 2); - lean_ctor_release(x_85, 3); - x_127 = x_85; +if (lean_is_scalar(x_115)) { + x_116 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_85); - x_127 = lean_box(0); + x_116 = x_115; } -if (lean_is_scalar(x_127)) { - x_128 = lean_alloc_ctor(0, 4, 0); -} else { - x_128 = x_127; -} -lean_ctor_set(x_128, 0, x_124); -lean_ctor_set(x_128, 1, x_125); -lean_ctor_set(x_128, 2, x_9); -lean_ctor_set(x_128, 3, x_126); -if (lean_is_scalar(x_123)) { - x_129 = lean_alloc_ctor(0, 6, 0); -} else { - x_129 = x_123; -} -lean_ctor_set(x_129, 0, x_118); -lean_ctor_set(x_129, 1, x_119); -lean_ctor_set(x_129, 2, x_128); -lean_ctor_set(x_129, 3, x_120); -lean_ctor_set(x_129, 4, x_121); -lean_ctor_set(x_129, 5, x_122); -x_130 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_130, 0, x_129); -lean_ctor_set(x_130, 1, x_113); -lean_ctor_set(x_130, 2, x_114); -lean_ctor_set(x_130, 3, x_115); -lean_ctor_set(x_130, 4, x_116); -lean_ctor_set(x_130, 5, x_117); -lean_ctor_set(x_11, 0, x_130); -x_131 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_131, 0, x_86); -lean_ctor_set(x_131, 1, x_11); -return x_131; +lean_ctor_set(x_116, 0, x_111); +lean_ctor_set(x_116, 1, x_112); +lean_ctor_set(x_116, 2, x_9); +lean_ctor_set(x_116, 3, x_113); +lean_ctor_set(x_116, 4, x_114); +x_117 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_117, 0, x_106); +lean_ctor_set(x_117, 1, x_107); +lean_ctor_set(x_117, 2, x_116); +lean_ctor_set(x_117, 3, x_108); +lean_ctor_set(x_117, 4, x_109); +lean_ctor_set(x_117, 5, x_110); +lean_ctor_set(x_87, 0, x_117); +x_118 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_118, 0, x_90); +lean_ctor_set(x_118, 1, x_11); +return x_118; } } else { -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; -x_132 = lean_ctor_get(x_11, 1); +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; +x_119 = lean_ctor_get(x_87, 1); +x_120 = lean_ctor_get(x_87, 2); +x_121 = lean_ctor_get(x_87, 3); +x_122 = lean_ctor_get(x_87, 4); +x_123 = lean_ctor_get(x_87, 5); +lean_inc(x_123); +lean_inc(x_122); +lean_inc(x_121); +lean_inc(x_120); +lean_inc(x_119); +lean_dec(x_87); +x_124 = lean_ctor_get(x_88, 0); +lean_inc(x_124); +x_125 = lean_ctor_get(x_88, 1); +lean_inc(x_125); +x_126 = lean_ctor_get(x_88, 3); +lean_inc(x_126); +x_127 = lean_ctor_get(x_88, 4); +lean_inc(x_127); +x_128 = lean_ctor_get(x_88, 5); +lean_inc(x_128); +if (lean_is_exclusive(x_88)) { + lean_ctor_release(x_88, 0); + lean_ctor_release(x_88, 1); + lean_ctor_release(x_88, 2); + lean_ctor_release(x_88, 3); + lean_ctor_release(x_88, 4); + lean_ctor_release(x_88, 5); + x_129 = x_88; +} else { + lean_dec_ref(x_88); + x_129 = lean_box(0); +} +x_130 = lean_ctor_get(x_89, 0); +lean_inc(x_130); +x_131 = lean_ctor_get(x_89, 1); +lean_inc(x_131); +x_132 = lean_ctor_get(x_89, 3); lean_inc(x_132); -lean_dec(x_11); -x_133 = lean_ctor_get(x_83, 1); +x_133 = lean_ctor_get(x_89, 4); lean_inc(x_133); -x_134 = lean_ctor_get(x_83, 2); -lean_inc(x_134); -x_135 = lean_ctor_get(x_83, 3); -lean_inc(x_135); -x_136 = lean_ctor_get(x_83, 4); -lean_inc(x_136); -x_137 = lean_ctor_get(x_83, 5); -lean_inc(x_137); -if (lean_is_exclusive(x_83)) { - lean_ctor_release(x_83, 0); - lean_ctor_release(x_83, 1); - lean_ctor_release(x_83, 2); - lean_ctor_release(x_83, 3); - lean_ctor_release(x_83, 4); - lean_ctor_release(x_83, 5); - x_138 = x_83; +if (lean_is_exclusive(x_89)) { + lean_ctor_release(x_89, 0); + lean_ctor_release(x_89, 1); + lean_ctor_release(x_89, 2); + lean_ctor_release(x_89, 3); + lean_ctor_release(x_89, 4); + x_134 = x_89; } else { - lean_dec_ref(x_83); - x_138 = lean_box(0); + lean_dec_ref(x_89); + x_134 = lean_box(0); } -x_139 = lean_ctor_get(x_84, 0); +if (lean_is_scalar(x_134)) { + x_135 = lean_alloc_ctor(0, 5, 0); +} else { + x_135 = x_134; +} +lean_ctor_set(x_135, 0, x_130); +lean_ctor_set(x_135, 1, x_131); +lean_ctor_set(x_135, 2, x_9); +lean_ctor_set(x_135, 3, x_132); +lean_ctor_set(x_135, 4, x_133); +if (lean_is_scalar(x_129)) { + x_136 = lean_alloc_ctor(0, 6, 0); +} else { + x_136 = x_129; +} +lean_ctor_set(x_136, 0, x_124); +lean_ctor_set(x_136, 1, x_125); +lean_ctor_set(x_136, 2, x_135); +lean_ctor_set(x_136, 3, x_126); +lean_ctor_set(x_136, 4, x_127); +lean_ctor_set(x_136, 5, x_128); +x_137 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_137, 0, x_136); +lean_ctor_set(x_137, 1, x_119); +lean_ctor_set(x_137, 2, x_120); +lean_ctor_set(x_137, 3, x_121); +lean_ctor_set(x_137, 4, x_122); +lean_ctor_set(x_137, 5, x_123); +lean_ctor_set(x_11, 0, x_137); +x_138 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_138, 0, x_90); +lean_ctor_set(x_138, 1, x_11); +return x_138; +} +} +else +{ +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; +x_139 = lean_ctor_get(x_11, 1); lean_inc(x_139); -x_140 = lean_ctor_get(x_84, 1); +lean_dec(x_11); +x_140 = lean_ctor_get(x_87, 1); lean_inc(x_140); -x_141 = lean_ctor_get(x_84, 3); +x_141 = lean_ctor_get(x_87, 2); lean_inc(x_141); -x_142 = lean_ctor_get(x_84, 4); +x_142 = lean_ctor_get(x_87, 3); lean_inc(x_142); -x_143 = lean_ctor_get(x_84, 5); +x_143 = lean_ctor_get(x_87, 4); lean_inc(x_143); -if (lean_is_exclusive(x_84)) { - lean_ctor_release(x_84, 0); - lean_ctor_release(x_84, 1); - lean_ctor_release(x_84, 2); - lean_ctor_release(x_84, 3); - lean_ctor_release(x_84, 4); - lean_ctor_release(x_84, 5); - x_144 = x_84; +x_144 = lean_ctor_get(x_87, 5); +lean_inc(x_144); +if (lean_is_exclusive(x_87)) { + lean_ctor_release(x_87, 0); + lean_ctor_release(x_87, 1); + lean_ctor_release(x_87, 2); + lean_ctor_release(x_87, 3); + lean_ctor_release(x_87, 4); + lean_ctor_release(x_87, 5); + x_145 = x_87; } else { - lean_dec_ref(x_84); - x_144 = lean_box(0); + lean_dec_ref(x_87); + x_145 = lean_box(0); } -x_145 = lean_ctor_get(x_85, 0); -lean_inc(x_145); -x_146 = lean_ctor_get(x_85, 1); +x_146 = lean_ctor_get(x_88, 0); lean_inc(x_146); -x_147 = lean_ctor_get(x_85, 3); +x_147 = lean_ctor_get(x_88, 1); lean_inc(x_147); -if (lean_is_exclusive(x_85)) { - lean_ctor_release(x_85, 0); - lean_ctor_release(x_85, 1); - lean_ctor_release(x_85, 2); - lean_ctor_release(x_85, 3); - x_148 = x_85; +x_148 = lean_ctor_get(x_88, 3); +lean_inc(x_148); +x_149 = lean_ctor_get(x_88, 4); +lean_inc(x_149); +x_150 = lean_ctor_get(x_88, 5); +lean_inc(x_150); +if (lean_is_exclusive(x_88)) { + lean_ctor_release(x_88, 0); + lean_ctor_release(x_88, 1); + lean_ctor_release(x_88, 2); + lean_ctor_release(x_88, 3); + lean_ctor_release(x_88, 4); + lean_ctor_release(x_88, 5); + x_151 = x_88; } else { - lean_dec_ref(x_85); - x_148 = lean_box(0); + lean_dec_ref(x_88); + x_151 = lean_box(0); } -if (lean_is_scalar(x_148)) { - x_149 = lean_alloc_ctor(0, 4, 0); +x_152 = lean_ctor_get(x_89, 0); +lean_inc(x_152); +x_153 = lean_ctor_get(x_89, 1); +lean_inc(x_153); +x_154 = lean_ctor_get(x_89, 3); +lean_inc(x_154); +x_155 = lean_ctor_get(x_89, 4); +lean_inc(x_155); +if (lean_is_exclusive(x_89)) { + lean_ctor_release(x_89, 0); + lean_ctor_release(x_89, 1); + lean_ctor_release(x_89, 2); + lean_ctor_release(x_89, 3); + lean_ctor_release(x_89, 4); + x_156 = x_89; } else { - x_149 = x_148; + lean_dec_ref(x_89); + x_156 = lean_box(0); } -lean_ctor_set(x_149, 0, x_145); -lean_ctor_set(x_149, 1, x_146); -lean_ctor_set(x_149, 2, x_9); -lean_ctor_set(x_149, 3, x_147); -if (lean_is_scalar(x_144)) { - x_150 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_156)) { + x_157 = lean_alloc_ctor(0, 5, 0); } else { - x_150 = x_144; + x_157 = x_156; } -lean_ctor_set(x_150, 0, x_139); -lean_ctor_set(x_150, 1, x_140); -lean_ctor_set(x_150, 2, x_149); -lean_ctor_set(x_150, 3, x_141); -lean_ctor_set(x_150, 4, x_142); -lean_ctor_set(x_150, 5, x_143); -if (lean_is_scalar(x_138)) { - x_151 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_157, 0, x_152); +lean_ctor_set(x_157, 1, x_153); +lean_ctor_set(x_157, 2, x_9); +lean_ctor_set(x_157, 3, x_154); +lean_ctor_set(x_157, 4, x_155); +if (lean_is_scalar(x_151)) { + x_158 = lean_alloc_ctor(0, 6, 0); } else { - x_151 = x_138; + x_158 = x_151; } -lean_ctor_set(x_151, 0, x_150); -lean_ctor_set(x_151, 1, x_133); -lean_ctor_set(x_151, 2, x_134); -lean_ctor_set(x_151, 3, x_135); -lean_ctor_set(x_151, 4, x_136); -lean_ctor_set(x_151, 5, x_137); -x_152 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_152, 0, x_151); -lean_ctor_set(x_152, 1, x_132); -x_153 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_153, 0, x_86); -lean_ctor_set(x_153, 1, x_152); -return x_153; +lean_ctor_set(x_158, 0, x_146); +lean_ctor_set(x_158, 1, x_147); +lean_ctor_set(x_158, 2, x_157); +lean_ctor_set(x_158, 3, x_148); +lean_ctor_set(x_158, 4, x_149); +lean_ctor_set(x_158, 5, x_150); +if (lean_is_scalar(x_145)) { + x_159 = lean_alloc_ctor(0, 6, 0); +} else { + x_159 = x_145; +} +lean_ctor_set(x_159, 0, x_158); +lean_ctor_set(x_159, 1, x_140); +lean_ctor_set(x_159, 2, x_141); +lean_ctor_set(x_159, 3, x_142); +lean_ctor_set(x_159, 4, x_143); +lean_ctor_set(x_159, 5, x_144); +x_160 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_160, 0, x_159); +lean_ctor_set(x_160, 1, x_139); +x_161 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_161, 0, x_90); +lean_ctor_set(x_161, 1, x_160); +return x_161; } } } @@ -8114,7 +8174,7 @@ return x_27; } else { -lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_177; lean_object* x_178; +lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_185; lean_object* x_186; x_28 = lean_ctor_get(x_9, 0); lean_inc(x_28); x_29 = lean_ctor_get(x_28, 0); @@ -8126,76 +8186,76 @@ lean_dec(x_29); x_31 = lean_ctor_get(x_30, 2); lean_inc(x_31); lean_dec(x_30); -x_177 = l_Lean_Elab_Tactic_resetSynthInstanceCache___closed__1; +x_185 = l_Lean_Elab_Tactic_resetSynthInstanceCache___closed__1; lean_inc(x_23); -x_178 = l_Lean_Elab_Tactic_liftTermElabM___rarg(x_177, x_23, x_9); -if (lean_obj_tag(x_178) == 0) +x_186 = l_Lean_Elab_Tactic_liftTermElabM___rarg(x_185, x_23, x_9); +if (lean_obj_tag(x_186) == 0) { -lean_object* x_179; lean_object* x_180; lean_object* x_181; -x_179 = lean_ctor_get(x_178, 1); -lean_inc(x_179); -lean_dec(x_178); -x_180 = l_Lean_Elab_Tactic_save(x_179); -x_181 = lean_apply_2(x_2, x_23, x_179); -if (lean_obj_tag(x_181) == 0) +lean_object* x_187; lean_object* x_188; lean_object* x_189; +x_187 = lean_ctor_get(x_186, 1); +lean_inc(x_187); +lean_dec(x_186); +x_188 = l_Lean_Elab_Tactic_save(x_187); +x_189 = lean_apply_2(x_2, x_23, x_187); +if (lean_obj_tag(x_189) == 0) { -lean_object* x_182; lean_object* x_183; lean_object* x_184; -lean_dec(x_180); -x_182 = lean_ctor_get(x_181, 0); -lean_inc(x_182); -x_183 = lean_ctor_get(x_181, 1); -lean_inc(x_183); -lean_dec(x_181); -x_184 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_184, 0, x_182); -x_32 = x_184; -x_33 = x_183; -goto block_176; +lean_object* x_190; lean_object* x_191; lean_object* x_192; +lean_dec(x_188); +x_190 = lean_ctor_get(x_189, 0); +lean_inc(x_190); +x_191 = lean_ctor_get(x_189, 1); +lean_inc(x_191); +lean_dec(x_189); +x_192 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_192, 0, x_190); +x_32 = x_192; +x_33 = x_191; +goto block_184; } else { -lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; -x_185 = lean_ctor_get(x_181, 0); -lean_inc(x_185); -x_186 = lean_ctor_get(x_181, 1); -lean_inc(x_186); -lean_dec(x_181); -x_187 = l_Lean_Elab_Tactic_restore(x_186, x_180); -lean_dec(x_180); -x_188 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_188, 0, x_185); -x_32 = x_188; -x_33 = x_187; -goto block_176; +lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; +x_193 = lean_ctor_get(x_189, 0); +lean_inc(x_193); +x_194 = lean_ctor_get(x_189, 1); +lean_inc(x_194); +lean_dec(x_189); +x_195 = l_Lean_Elab_Tactic_restore(x_194, x_188); +lean_dec(x_188); +x_196 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_196, 0, x_193); +x_32 = x_196; +x_33 = x_195; +goto block_184; } } else { -uint8_t x_189; +uint8_t x_197; lean_dec(x_31); lean_dec(x_23); lean_dec(x_10); lean_dec(x_2); -x_189 = !lean_is_exclusive(x_178); -if (x_189 == 0) +x_197 = !lean_is_exclusive(x_186); +if (x_197 == 0) { -return x_178; +return x_186; } else { -lean_object* x_190; lean_object* x_191; lean_object* x_192; -x_190 = lean_ctor_get(x_178, 0); -x_191 = lean_ctor_get(x_178, 1); -lean_inc(x_191); -lean_inc(x_190); -lean_dec(x_178); -x_192 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_192, 0, x_190); -lean_ctor_set(x_192, 1, x_191); -return x_192; +lean_object* x_198; lean_object* x_199; lean_object* x_200; +x_198 = lean_ctor_get(x_186, 0); +x_199 = lean_ctor_get(x_186, 1); +lean_inc(x_199); +lean_inc(x_198); +lean_dec(x_186); +x_200 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_200, 0, x_198); +lean_ctor_set(x_200, 1, x_199); +return x_200; } } -block_176: +block_184: { if (lean_obj_tag(x_32) == 0) { @@ -8246,113 +8306,120 @@ return x_46; } else { -lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; +lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; x_47 = lean_ctor_get(x_36, 0); x_48 = lean_ctor_get(x_36, 1); x_49 = lean_ctor_get(x_36, 3); +x_50 = lean_ctor_get(x_36, 4); +lean_inc(x_50); lean_inc(x_49); lean_inc(x_48); lean_inc(x_47); lean_dec(x_36); -x_50 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_50, 0, x_47); -lean_ctor_set(x_50, 1, x_48); -lean_ctor_set(x_50, 2, x_31); -lean_ctor_set(x_50, 3, x_49); -lean_ctor_set(x_35, 2, x_50); +x_51 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_51, 0, x_47); +lean_ctor_set(x_51, 1, x_48); +lean_ctor_set(x_51, 2, x_31); +lean_ctor_set(x_51, 3, x_49); +lean_ctor_set(x_51, 4, x_50); +lean_ctor_set(x_35, 2, x_51); if (lean_is_scalar(x_10)) { - x_51 = lean_alloc_ctor(1, 2, 0); + x_52 = lean_alloc_ctor(1, 2, 0); } else { - x_51 = x_10; - lean_ctor_set_tag(x_51, 1); + x_52 = x_10; + lean_ctor_set_tag(x_52, 1); } -lean_ctor_set(x_51, 0, x_37); -lean_ctor_set(x_51, 1, x_33); -return x_51; +lean_ctor_set(x_52, 0, x_37); +lean_ctor_set(x_52, 1, x_33); +return x_52; } } else { -lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; -x_52 = lean_ctor_get(x_35, 0); -x_53 = lean_ctor_get(x_35, 1); -x_54 = lean_ctor_get(x_35, 3); -x_55 = lean_ctor_get(x_35, 4); -x_56 = lean_ctor_get(x_35, 5); +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_object* x_63; lean_object* x_64; lean_object* x_65; +x_53 = lean_ctor_get(x_35, 0); +x_54 = lean_ctor_get(x_35, 1); +x_55 = lean_ctor_get(x_35, 3); +x_56 = lean_ctor_get(x_35, 4); +x_57 = lean_ctor_get(x_35, 5); +lean_inc(x_57); lean_inc(x_56); lean_inc(x_55); lean_inc(x_54); lean_inc(x_53); -lean_inc(x_52); lean_dec(x_35); -x_57 = lean_ctor_get(x_36, 0); -lean_inc(x_57); -x_58 = lean_ctor_get(x_36, 1); +x_58 = lean_ctor_get(x_36, 0); lean_inc(x_58); -x_59 = lean_ctor_get(x_36, 3); +x_59 = lean_ctor_get(x_36, 1); lean_inc(x_59); +x_60 = lean_ctor_get(x_36, 3); +lean_inc(x_60); +x_61 = lean_ctor_get(x_36, 4); +lean_inc(x_61); if (lean_is_exclusive(x_36)) { lean_ctor_release(x_36, 0); lean_ctor_release(x_36, 1); lean_ctor_release(x_36, 2); lean_ctor_release(x_36, 3); - x_60 = x_36; + lean_ctor_release(x_36, 4); + x_62 = x_36; } else { lean_dec_ref(x_36); - x_60 = lean_box(0); + x_62 = lean_box(0); } -if (lean_is_scalar(x_60)) { - x_61 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_62)) { + x_63 = lean_alloc_ctor(0, 5, 0); } else { - x_61 = x_60; + x_63 = x_62; } -lean_ctor_set(x_61, 0, x_57); -lean_ctor_set(x_61, 1, x_58); -lean_ctor_set(x_61, 2, x_31); -lean_ctor_set(x_61, 3, x_59); -x_62 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_62, 0, x_52); -lean_ctor_set(x_62, 1, x_53); -lean_ctor_set(x_62, 2, x_61); -lean_ctor_set(x_62, 3, x_54); -lean_ctor_set(x_62, 4, x_55); -lean_ctor_set(x_62, 5, x_56); -lean_ctor_set(x_34, 0, x_62); +lean_ctor_set(x_63, 0, x_58); +lean_ctor_set(x_63, 1, x_59); +lean_ctor_set(x_63, 2, x_31); +lean_ctor_set(x_63, 3, x_60); +lean_ctor_set(x_63, 4, x_61); +x_64 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_64, 0, x_53); +lean_ctor_set(x_64, 1, x_54); +lean_ctor_set(x_64, 2, x_63); +lean_ctor_set(x_64, 3, x_55); +lean_ctor_set(x_64, 4, x_56); +lean_ctor_set(x_64, 5, x_57); +lean_ctor_set(x_34, 0, x_64); if (lean_is_scalar(x_10)) { - x_63 = lean_alloc_ctor(1, 2, 0); + x_65 = lean_alloc_ctor(1, 2, 0); } else { - x_63 = x_10; - lean_ctor_set_tag(x_63, 1); + x_65 = x_10; + lean_ctor_set_tag(x_65, 1); } -lean_ctor_set(x_63, 0, x_37); -lean_ctor_set(x_63, 1, x_33); -return x_63; +lean_ctor_set(x_65, 0, x_37); +lean_ctor_set(x_65, 1, x_33); +return x_65; } } else { -lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; -x_64 = lean_ctor_get(x_34, 1); -x_65 = lean_ctor_get(x_34, 2); -x_66 = lean_ctor_get(x_34, 3); -x_67 = lean_ctor_get(x_34, 4); -x_68 = lean_ctor_get(x_34, 5); +lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; 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; +x_66 = lean_ctor_get(x_34, 1); +x_67 = lean_ctor_get(x_34, 2); +x_68 = lean_ctor_get(x_34, 3); +x_69 = lean_ctor_get(x_34, 4); +x_70 = lean_ctor_get(x_34, 5); +lean_inc(x_70); +lean_inc(x_69); lean_inc(x_68); lean_inc(x_67); lean_inc(x_66); -lean_inc(x_65); -lean_inc(x_64); lean_dec(x_34); -x_69 = lean_ctor_get(x_35, 0); -lean_inc(x_69); -x_70 = lean_ctor_get(x_35, 1); -lean_inc(x_70); -x_71 = lean_ctor_get(x_35, 3); +x_71 = lean_ctor_get(x_35, 0); lean_inc(x_71); -x_72 = lean_ctor_get(x_35, 4); +x_72 = lean_ctor_get(x_35, 1); lean_inc(x_72); -x_73 = lean_ctor_get(x_35, 5); +x_73 = lean_ctor_get(x_35, 3); lean_inc(x_73); +x_74 = lean_ctor_get(x_35, 4); +lean_inc(x_74); +x_75 = lean_ctor_get(x_35, 5); +lean_inc(x_75); if (lean_is_exclusive(x_35)) { lean_ctor_release(x_35, 0); lean_ctor_release(x_35, 1); @@ -8360,82 +8427,86 @@ if (lean_is_exclusive(x_35)) { lean_ctor_release(x_35, 3); lean_ctor_release(x_35, 4); lean_ctor_release(x_35, 5); - x_74 = x_35; + x_76 = x_35; } else { lean_dec_ref(x_35); - x_74 = lean_box(0); + x_76 = lean_box(0); } -x_75 = lean_ctor_get(x_36, 0); -lean_inc(x_75); -x_76 = lean_ctor_get(x_36, 1); -lean_inc(x_76); -x_77 = lean_ctor_get(x_36, 3); +x_77 = lean_ctor_get(x_36, 0); lean_inc(x_77); +x_78 = lean_ctor_get(x_36, 1); +lean_inc(x_78); +x_79 = lean_ctor_get(x_36, 3); +lean_inc(x_79); +x_80 = lean_ctor_get(x_36, 4); +lean_inc(x_80); if (lean_is_exclusive(x_36)) { lean_ctor_release(x_36, 0); lean_ctor_release(x_36, 1); lean_ctor_release(x_36, 2); lean_ctor_release(x_36, 3); - x_78 = x_36; + lean_ctor_release(x_36, 4); + x_81 = x_36; } else { lean_dec_ref(x_36); - x_78 = lean_box(0); + x_81 = lean_box(0); } -if (lean_is_scalar(x_78)) { - x_79 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_81)) { + x_82 = lean_alloc_ctor(0, 5, 0); } else { - x_79 = x_78; + x_82 = x_81; } -lean_ctor_set(x_79, 0, x_75); -lean_ctor_set(x_79, 1, x_76); -lean_ctor_set(x_79, 2, x_31); -lean_ctor_set(x_79, 3, x_77); -if (lean_is_scalar(x_74)) { - x_80 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_82, 0, x_77); +lean_ctor_set(x_82, 1, x_78); +lean_ctor_set(x_82, 2, x_31); +lean_ctor_set(x_82, 3, x_79); +lean_ctor_set(x_82, 4, x_80); +if (lean_is_scalar(x_76)) { + x_83 = lean_alloc_ctor(0, 6, 0); } else { - x_80 = x_74; + x_83 = x_76; } -lean_ctor_set(x_80, 0, x_69); -lean_ctor_set(x_80, 1, x_70); -lean_ctor_set(x_80, 2, x_79); -lean_ctor_set(x_80, 3, x_71); -lean_ctor_set(x_80, 4, x_72); -lean_ctor_set(x_80, 5, x_73); -x_81 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_81, 0, x_80); -lean_ctor_set(x_81, 1, x_64); -lean_ctor_set(x_81, 2, x_65); -lean_ctor_set(x_81, 3, x_66); -lean_ctor_set(x_81, 4, x_67); -lean_ctor_set(x_81, 5, x_68); -lean_ctor_set(x_33, 0, x_81); +lean_ctor_set(x_83, 0, x_71); +lean_ctor_set(x_83, 1, x_72); +lean_ctor_set(x_83, 2, x_82); +lean_ctor_set(x_83, 3, x_73); +lean_ctor_set(x_83, 4, x_74); +lean_ctor_set(x_83, 5, x_75); +x_84 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_84, 0, x_83); +lean_ctor_set(x_84, 1, x_66); +lean_ctor_set(x_84, 2, x_67); +lean_ctor_set(x_84, 3, x_68); +lean_ctor_set(x_84, 4, x_69); +lean_ctor_set(x_84, 5, x_70); +lean_ctor_set(x_33, 0, x_84); if (lean_is_scalar(x_10)) { - x_82 = lean_alloc_ctor(1, 2, 0); + x_85 = lean_alloc_ctor(1, 2, 0); } else { - x_82 = x_10; - lean_ctor_set_tag(x_82, 1); + x_85 = x_10; + lean_ctor_set_tag(x_85, 1); } -lean_ctor_set(x_82, 0, x_37); -lean_ctor_set(x_82, 1, x_33); -return x_82; +lean_ctor_set(x_85, 0, x_37); +lean_ctor_set(x_85, 1, x_33); +return x_85; } } else { -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; -x_83 = lean_ctor_get(x_33, 1); -lean_inc(x_83); -lean_dec(x_33); -x_84 = lean_ctor_get(x_34, 1); -lean_inc(x_84); -x_85 = lean_ctor_get(x_34, 2); -lean_inc(x_85); -x_86 = lean_ctor_get(x_34, 3); +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; +x_86 = lean_ctor_get(x_33, 1); lean_inc(x_86); -x_87 = lean_ctor_get(x_34, 4); +lean_dec(x_33); +x_87 = lean_ctor_get(x_34, 1); lean_inc(x_87); -x_88 = lean_ctor_get(x_34, 5); +x_88 = lean_ctor_get(x_34, 2); lean_inc(x_88); +x_89 = lean_ctor_get(x_34, 3); +lean_inc(x_89); +x_90 = lean_ctor_get(x_34, 4); +lean_inc(x_90); +x_91 = lean_ctor_get(x_34, 5); +lean_inc(x_91); if (lean_is_exclusive(x_34)) { lean_ctor_release(x_34, 0); lean_ctor_release(x_34, 1); @@ -8443,21 +8514,21 @@ if (lean_is_exclusive(x_34)) { lean_ctor_release(x_34, 3); lean_ctor_release(x_34, 4); lean_ctor_release(x_34, 5); - x_89 = x_34; + x_92 = x_34; } else { lean_dec_ref(x_34); - x_89 = lean_box(0); + x_92 = lean_box(0); } -x_90 = lean_ctor_get(x_35, 0); -lean_inc(x_90); -x_91 = lean_ctor_get(x_35, 1); -lean_inc(x_91); -x_92 = lean_ctor_get(x_35, 3); -lean_inc(x_92); -x_93 = lean_ctor_get(x_35, 4); +x_93 = lean_ctor_get(x_35, 0); lean_inc(x_93); -x_94 = lean_ctor_get(x_35, 5); +x_94 = lean_ctor_get(x_35, 1); lean_inc(x_94); +x_95 = lean_ctor_get(x_35, 3); +lean_inc(x_95); +x_96 = lean_ctor_get(x_35, 4); +lean_inc(x_96); +x_97 = lean_ctor_get(x_35, 5); +lean_inc(x_97); if (lean_is_exclusive(x_35)) { lean_ctor_release(x_35, 0); lean_ctor_release(x_35, 1); @@ -8465,399 +8536,418 @@ if (lean_is_exclusive(x_35)) { lean_ctor_release(x_35, 3); lean_ctor_release(x_35, 4); lean_ctor_release(x_35, 5); - x_95 = x_35; + x_98 = x_35; } else { lean_dec_ref(x_35); - x_95 = lean_box(0); + x_98 = lean_box(0); } -x_96 = lean_ctor_get(x_36, 0); -lean_inc(x_96); -x_97 = lean_ctor_get(x_36, 1); -lean_inc(x_97); -x_98 = lean_ctor_get(x_36, 3); -lean_inc(x_98); +x_99 = lean_ctor_get(x_36, 0); +lean_inc(x_99); +x_100 = lean_ctor_get(x_36, 1); +lean_inc(x_100); +x_101 = lean_ctor_get(x_36, 3); +lean_inc(x_101); +x_102 = lean_ctor_get(x_36, 4); +lean_inc(x_102); if (lean_is_exclusive(x_36)) { lean_ctor_release(x_36, 0); lean_ctor_release(x_36, 1); lean_ctor_release(x_36, 2); lean_ctor_release(x_36, 3); - x_99 = x_36; + lean_ctor_release(x_36, 4); + x_103 = x_36; } else { lean_dec_ref(x_36); - x_99 = lean_box(0); + x_103 = lean_box(0); } -if (lean_is_scalar(x_99)) { - x_100 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_103)) { + x_104 = lean_alloc_ctor(0, 5, 0); } else { - x_100 = x_99; + x_104 = x_103; } -lean_ctor_set(x_100, 0, x_96); -lean_ctor_set(x_100, 1, x_97); -lean_ctor_set(x_100, 2, x_31); -lean_ctor_set(x_100, 3, x_98); -if (lean_is_scalar(x_95)) { - x_101 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_104, 0, x_99); +lean_ctor_set(x_104, 1, x_100); +lean_ctor_set(x_104, 2, x_31); +lean_ctor_set(x_104, 3, x_101); +lean_ctor_set(x_104, 4, x_102); +if (lean_is_scalar(x_98)) { + x_105 = lean_alloc_ctor(0, 6, 0); } else { - x_101 = x_95; + x_105 = x_98; } -lean_ctor_set(x_101, 0, x_90); -lean_ctor_set(x_101, 1, x_91); -lean_ctor_set(x_101, 2, x_100); -lean_ctor_set(x_101, 3, x_92); -lean_ctor_set(x_101, 4, x_93); -lean_ctor_set(x_101, 5, x_94); -if (lean_is_scalar(x_89)) { - x_102 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_105, 0, x_93); +lean_ctor_set(x_105, 1, x_94); +lean_ctor_set(x_105, 2, x_104); +lean_ctor_set(x_105, 3, x_95); +lean_ctor_set(x_105, 4, x_96); +lean_ctor_set(x_105, 5, x_97); +if (lean_is_scalar(x_92)) { + x_106 = lean_alloc_ctor(0, 6, 0); } else { - x_102 = x_89; + x_106 = x_92; } -lean_ctor_set(x_102, 0, x_101); -lean_ctor_set(x_102, 1, x_84); -lean_ctor_set(x_102, 2, x_85); -lean_ctor_set(x_102, 3, x_86); -lean_ctor_set(x_102, 4, x_87); -lean_ctor_set(x_102, 5, x_88); -x_103 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_103, 0, x_102); -lean_ctor_set(x_103, 1, x_83); +lean_ctor_set(x_106, 0, x_105); +lean_ctor_set(x_106, 1, x_87); +lean_ctor_set(x_106, 2, x_88); +lean_ctor_set(x_106, 3, x_89); +lean_ctor_set(x_106, 4, x_90); +lean_ctor_set(x_106, 5, x_91); +x_107 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_107, 0, x_106); +lean_ctor_set(x_107, 1, x_86); if (lean_is_scalar(x_10)) { - x_104 = lean_alloc_ctor(1, 2, 0); + x_108 = lean_alloc_ctor(1, 2, 0); } else { - x_104 = x_10; - lean_ctor_set_tag(x_104, 1); + x_108 = x_10; + lean_ctor_set_tag(x_108, 1); } -lean_ctor_set(x_104, 0, x_37); -lean_ctor_set(x_104, 1, x_103); -return x_104; +lean_ctor_set(x_108, 0, x_37); +lean_ctor_set(x_108, 1, x_107); +return x_108; } } else { -lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; uint8_t x_109; -x_105 = lean_ctor_get(x_33, 0); -lean_inc(x_105); -x_106 = lean_ctor_get(x_105, 0); -lean_inc(x_106); -x_107 = lean_ctor_get(x_106, 2); -lean_inc(x_107); -x_108 = lean_ctor_get(x_32, 0); -lean_inc(x_108); +lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; uint8_t x_113; +x_109 = lean_ctor_get(x_33, 0); +lean_inc(x_109); +x_110 = lean_ctor_get(x_109, 0); +lean_inc(x_110); +x_111 = lean_ctor_get(x_110, 2); +lean_inc(x_111); +x_112 = lean_ctor_get(x_32, 0); +lean_inc(x_112); lean_dec(x_32); -x_109 = !lean_is_exclusive(x_33); -if (x_109 == 0) -{ -lean_object* x_110; uint8_t x_111; -x_110 = lean_ctor_get(x_33, 0); -lean_dec(x_110); -x_111 = !lean_is_exclusive(x_105); -if (x_111 == 0) -{ -lean_object* x_112; uint8_t x_113; -x_112 = lean_ctor_get(x_105, 0); -lean_dec(x_112); -x_113 = !lean_is_exclusive(x_106); +x_113 = !lean_is_exclusive(x_33); if (x_113 == 0) { lean_object* x_114; uint8_t x_115; -x_114 = lean_ctor_get(x_106, 2); +x_114 = lean_ctor_get(x_33, 0); lean_dec(x_114); -x_115 = !lean_is_exclusive(x_107); +x_115 = !lean_is_exclusive(x_109); if (x_115 == 0) { -lean_object* x_116; lean_object* x_117; -x_116 = lean_ctor_get(x_107, 2); +lean_object* x_116; uint8_t x_117; +x_116 = lean_ctor_get(x_109, 0); lean_dec(x_116); -lean_ctor_set(x_107, 2, x_31); +x_117 = !lean_is_exclusive(x_110); +if (x_117 == 0) +{ +lean_object* x_118; uint8_t x_119; +x_118 = lean_ctor_get(x_110, 2); +lean_dec(x_118); +x_119 = !lean_is_exclusive(x_111); +if (x_119 == 0) +{ +lean_object* x_120; lean_object* x_121; +x_120 = lean_ctor_get(x_111, 2); +lean_dec(x_120); +lean_ctor_set(x_111, 2, x_31); if (lean_is_scalar(x_10)) { - x_117 = lean_alloc_ctor(0, 2, 0); + x_121 = lean_alloc_ctor(0, 2, 0); } else { - x_117 = x_10; + x_121 = x_10; } -lean_ctor_set(x_117, 0, x_108); -lean_ctor_set(x_117, 1, x_33); -return x_117; +lean_ctor_set(x_121, 0, x_112); +lean_ctor_set(x_121, 1, x_33); +return x_121; } else { -lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; -x_118 = lean_ctor_get(x_107, 0); -x_119 = lean_ctor_get(x_107, 1); -x_120 = lean_ctor_get(x_107, 3); -lean_inc(x_120); -lean_inc(x_119); -lean_inc(x_118); -lean_dec(x_107); -x_121 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_121, 0, x_118); -lean_ctor_set(x_121, 1, x_119); -lean_ctor_set(x_121, 2, x_31); -lean_ctor_set(x_121, 3, x_120); -lean_ctor_set(x_106, 2, x_121); -if (lean_is_scalar(x_10)) { - x_122 = lean_alloc_ctor(0, 2, 0); -} else { - x_122 = x_10; -} -lean_ctor_set(x_122, 0, x_108); -lean_ctor_set(x_122, 1, x_33); -return x_122; -} -} -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; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; -x_123 = lean_ctor_get(x_106, 0); -x_124 = lean_ctor_get(x_106, 1); -x_125 = lean_ctor_get(x_106, 3); -x_126 = lean_ctor_get(x_106, 4); -x_127 = lean_ctor_get(x_106, 5); -lean_inc(x_127); -lean_inc(x_126); +lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; +x_122 = lean_ctor_get(x_111, 0); +x_123 = lean_ctor_get(x_111, 1); +x_124 = lean_ctor_get(x_111, 3); +x_125 = lean_ctor_get(x_111, 4); lean_inc(x_125); lean_inc(x_124); lean_inc(x_123); -lean_dec(x_106); -x_128 = lean_ctor_get(x_107, 0); -lean_inc(x_128); -x_129 = lean_ctor_get(x_107, 1); -lean_inc(x_129); -x_130 = lean_ctor_get(x_107, 3); +lean_inc(x_122); +lean_dec(x_111); +x_126 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_126, 0, x_122); +lean_ctor_set(x_126, 1, x_123); +lean_ctor_set(x_126, 2, x_31); +lean_ctor_set(x_126, 3, x_124); +lean_ctor_set(x_126, 4, x_125); +lean_ctor_set(x_110, 2, x_126); +if (lean_is_scalar(x_10)) { + x_127 = lean_alloc_ctor(0, 2, 0); +} else { + x_127 = x_10; +} +lean_ctor_set(x_127, 0, x_112); +lean_ctor_set(x_127, 1, x_33); +return x_127; +} +} +else +{ +lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; +x_128 = lean_ctor_get(x_110, 0); +x_129 = lean_ctor_get(x_110, 1); +x_130 = lean_ctor_get(x_110, 3); +x_131 = lean_ctor_get(x_110, 4); +x_132 = lean_ctor_get(x_110, 5); +lean_inc(x_132); +lean_inc(x_131); lean_inc(x_130); -if (lean_is_exclusive(x_107)) { - lean_ctor_release(x_107, 0); - lean_ctor_release(x_107, 1); - lean_ctor_release(x_107, 2); - lean_ctor_release(x_107, 3); - x_131 = x_107; -} else { - lean_dec_ref(x_107); - x_131 = lean_box(0); -} -if (lean_is_scalar(x_131)) { - x_132 = lean_alloc_ctor(0, 4, 0); -} else { - x_132 = x_131; -} -lean_ctor_set(x_132, 0, x_128); -lean_ctor_set(x_132, 1, x_129); -lean_ctor_set(x_132, 2, x_31); -lean_ctor_set(x_132, 3, x_130); -x_133 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_133, 0, x_123); -lean_ctor_set(x_133, 1, x_124); -lean_ctor_set(x_133, 2, x_132); -lean_ctor_set(x_133, 3, x_125); -lean_ctor_set(x_133, 4, x_126); -lean_ctor_set(x_133, 5, x_127); -lean_ctor_set(x_105, 0, x_133); -if (lean_is_scalar(x_10)) { - x_134 = lean_alloc_ctor(0, 2, 0); -} else { - x_134 = x_10; -} -lean_ctor_set(x_134, 0, x_108); -lean_ctor_set(x_134, 1, x_33); -return x_134; -} -} -else -{ -lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; 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; -x_135 = lean_ctor_get(x_105, 1); -x_136 = lean_ctor_get(x_105, 2); -x_137 = lean_ctor_get(x_105, 3); -x_138 = lean_ctor_get(x_105, 4); -x_139 = lean_ctor_get(x_105, 5); -lean_inc(x_139); -lean_inc(x_138); -lean_inc(x_137); -lean_inc(x_136); +lean_inc(x_129); +lean_inc(x_128); +lean_dec(x_110); +x_133 = lean_ctor_get(x_111, 0); +lean_inc(x_133); +x_134 = lean_ctor_get(x_111, 1); +lean_inc(x_134); +x_135 = lean_ctor_get(x_111, 3); lean_inc(x_135); -lean_dec(x_105); -x_140 = lean_ctor_get(x_106, 0); -lean_inc(x_140); -x_141 = lean_ctor_get(x_106, 1); -lean_inc(x_141); -x_142 = lean_ctor_get(x_106, 3); -lean_inc(x_142); -x_143 = lean_ctor_get(x_106, 4); -lean_inc(x_143); -x_144 = lean_ctor_get(x_106, 5); +x_136 = lean_ctor_get(x_111, 4); +lean_inc(x_136); +if (lean_is_exclusive(x_111)) { + lean_ctor_release(x_111, 0); + lean_ctor_release(x_111, 1); + lean_ctor_release(x_111, 2); + lean_ctor_release(x_111, 3); + lean_ctor_release(x_111, 4); + x_137 = x_111; +} else { + lean_dec_ref(x_111); + x_137 = lean_box(0); +} +if (lean_is_scalar(x_137)) { + x_138 = lean_alloc_ctor(0, 5, 0); +} else { + x_138 = x_137; +} +lean_ctor_set(x_138, 0, x_133); +lean_ctor_set(x_138, 1, x_134); +lean_ctor_set(x_138, 2, x_31); +lean_ctor_set(x_138, 3, x_135); +lean_ctor_set(x_138, 4, x_136); +x_139 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_139, 0, x_128); +lean_ctor_set(x_139, 1, x_129); +lean_ctor_set(x_139, 2, x_138); +lean_ctor_set(x_139, 3, x_130); +lean_ctor_set(x_139, 4, x_131); +lean_ctor_set(x_139, 5, x_132); +lean_ctor_set(x_109, 0, x_139); +if (lean_is_scalar(x_10)) { + x_140 = lean_alloc_ctor(0, 2, 0); +} else { + x_140 = x_10; +} +lean_ctor_set(x_140, 0, x_112); +lean_ctor_set(x_140, 1, x_33); +return x_140; +} +} +else +{ +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; +x_141 = lean_ctor_get(x_109, 1); +x_142 = lean_ctor_get(x_109, 2); +x_143 = lean_ctor_get(x_109, 3); +x_144 = lean_ctor_get(x_109, 4); +x_145 = lean_ctor_get(x_109, 5); +lean_inc(x_145); lean_inc(x_144); -if (lean_is_exclusive(x_106)) { - lean_ctor_release(x_106, 0); - lean_ctor_release(x_106, 1); - lean_ctor_release(x_106, 2); - lean_ctor_release(x_106, 3); - lean_ctor_release(x_106, 4); - lean_ctor_release(x_106, 5); - x_145 = x_106; -} else { - lean_dec_ref(x_106); - x_145 = lean_box(0); -} -x_146 = lean_ctor_get(x_107, 0); +lean_inc(x_143); +lean_inc(x_142); +lean_inc(x_141); +lean_dec(x_109); +x_146 = lean_ctor_get(x_110, 0); lean_inc(x_146); -x_147 = lean_ctor_get(x_107, 1); +x_147 = lean_ctor_get(x_110, 1); lean_inc(x_147); -x_148 = lean_ctor_get(x_107, 3); +x_148 = lean_ctor_get(x_110, 3); lean_inc(x_148); -if (lean_is_exclusive(x_107)) { - lean_ctor_release(x_107, 0); - lean_ctor_release(x_107, 1); - lean_ctor_release(x_107, 2); - lean_ctor_release(x_107, 3); - x_149 = x_107; +x_149 = lean_ctor_get(x_110, 4); +lean_inc(x_149); +x_150 = lean_ctor_get(x_110, 5); +lean_inc(x_150); +if (lean_is_exclusive(x_110)) { + lean_ctor_release(x_110, 0); + lean_ctor_release(x_110, 1); + lean_ctor_release(x_110, 2); + lean_ctor_release(x_110, 3); + lean_ctor_release(x_110, 4); + lean_ctor_release(x_110, 5); + x_151 = x_110; } else { - lean_dec_ref(x_107); - x_149 = lean_box(0); + lean_dec_ref(x_110); + x_151 = lean_box(0); } -if (lean_is_scalar(x_149)) { - x_150 = lean_alloc_ctor(0, 4, 0); -} else { - x_150 = x_149; -} -lean_ctor_set(x_150, 0, x_146); -lean_ctor_set(x_150, 1, x_147); -lean_ctor_set(x_150, 2, x_31); -lean_ctor_set(x_150, 3, x_148); -if (lean_is_scalar(x_145)) { - x_151 = lean_alloc_ctor(0, 6, 0); -} else { - x_151 = x_145; -} -lean_ctor_set(x_151, 0, x_140); -lean_ctor_set(x_151, 1, x_141); -lean_ctor_set(x_151, 2, x_150); -lean_ctor_set(x_151, 3, x_142); -lean_ctor_set(x_151, 4, x_143); -lean_ctor_set(x_151, 5, x_144); -x_152 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_152, 0, x_151); -lean_ctor_set(x_152, 1, x_135); -lean_ctor_set(x_152, 2, x_136); -lean_ctor_set(x_152, 3, x_137); -lean_ctor_set(x_152, 4, x_138); -lean_ctor_set(x_152, 5, x_139); -lean_ctor_set(x_33, 0, x_152); -if (lean_is_scalar(x_10)) { - x_153 = lean_alloc_ctor(0, 2, 0); -} else { - x_153 = x_10; -} -lean_ctor_set(x_153, 0, x_108); -lean_ctor_set(x_153, 1, x_33); -return x_153; -} -} -else -{ -lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; lean_object* x_173; lean_object* x_174; lean_object* x_175; -x_154 = lean_ctor_get(x_33, 1); +x_152 = lean_ctor_get(x_111, 0); +lean_inc(x_152); +x_153 = lean_ctor_get(x_111, 1); +lean_inc(x_153); +x_154 = lean_ctor_get(x_111, 3); lean_inc(x_154); -lean_dec(x_33); -x_155 = lean_ctor_get(x_105, 1); +x_155 = lean_ctor_get(x_111, 4); lean_inc(x_155); -x_156 = lean_ctor_get(x_105, 2); -lean_inc(x_156); -x_157 = lean_ctor_get(x_105, 3); -lean_inc(x_157); -x_158 = lean_ctor_get(x_105, 4); -lean_inc(x_158); -x_159 = lean_ctor_get(x_105, 5); -lean_inc(x_159); -if (lean_is_exclusive(x_105)) { - lean_ctor_release(x_105, 0); - lean_ctor_release(x_105, 1); - lean_ctor_release(x_105, 2); - lean_ctor_release(x_105, 3); - lean_ctor_release(x_105, 4); - lean_ctor_release(x_105, 5); - x_160 = x_105; +if (lean_is_exclusive(x_111)) { + lean_ctor_release(x_111, 0); + lean_ctor_release(x_111, 1); + lean_ctor_release(x_111, 2); + lean_ctor_release(x_111, 3); + lean_ctor_release(x_111, 4); + x_156 = x_111; } else { - lean_dec_ref(x_105); - x_160 = lean_box(0); + lean_dec_ref(x_111); + x_156 = lean_box(0); } -x_161 = lean_ctor_get(x_106, 0); -lean_inc(x_161); -x_162 = lean_ctor_get(x_106, 1); -lean_inc(x_162); -x_163 = lean_ctor_get(x_106, 3); -lean_inc(x_163); -x_164 = lean_ctor_get(x_106, 4); -lean_inc(x_164); -x_165 = lean_ctor_get(x_106, 5); -lean_inc(x_165); -if (lean_is_exclusive(x_106)) { - lean_ctor_release(x_106, 0); - lean_ctor_release(x_106, 1); - lean_ctor_release(x_106, 2); - lean_ctor_release(x_106, 3); - lean_ctor_release(x_106, 4); - lean_ctor_release(x_106, 5); - x_166 = x_106; +if (lean_is_scalar(x_156)) { + x_157 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_106); - x_166 = lean_box(0); + x_157 = x_156; } -x_167 = lean_ctor_get(x_107, 0); -lean_inc(x_167); -x_168 = lean_ctor_get(x_107, 1); -lean_inc(x_168); -x_169 = lean_ctor_get(x_107, 3); -lean_inc(x_169); -if (lean_is_exclusive(x_107)) { - lean_ctor_release(x_107, 0); - lean_ctor_release(x_107, 1); - lean_ctor_release(x_107, 2); - lean_ctor_release(x_107, 3); - x_170 = x_107; +lean_ctor_set(x_157, 0, x_152); +lean_ctor_set(x_157, 1, x_153); +lean_ctor_set(x_157, 2, x_31); +lean_ctor_set(x_157, 3, x_154); +lean_ctor_set(x_157, 4, x_155); +if (lean_is_scalar(x_151)) { + x_158 = lean_alloc_ctor(0, 6, 0); } else { - lean_dec_ref(x_107); - x_170 = lean_box(0); + x_158 = x_151; } -if (lean_is_scalar(x_170)) { - x_171 = lean_alloc_ctor(0, 4, 0); -} else { - x_171 = x_170; -} -lean_ctor_set(x_171, 0, x_167); -lean_ctor_set(x_171, 1, x_168); -lean_ctor_set(x_171, 2, x_31); -lean_ctor_set(x_171, 3, x_169); -if (lean_is_scalar(x_166)) { - x_172 = lean_alloc_ctor(0, 6, 0); -} else { - x_172 = x_166; -} -lean_ctor_set(x_172, 0, x_161); -lean_ctor_set(x_172, 1, x_162); -lean_ctor_set(x_172, 2, x_171); -lean_ctor_set(x_172, 3, x_163); -lean_ctor_set(x_172, 4, x_164); -lean_ctor_set(x_172, 5, x_165); -if (lean_is_scalar(x_160)) { - x_173 = lean_alloc_ctor(0, 6, 0); -} else { - x_173 = x_160; -} -lean_ctor_set(x_173, 0, x_172); -lean_ctor_set(x_173, 1, x_155); -lean_ctor_set(x_173, 2, x_156); -lean_ctor_set(x_173, 3, x_157); -lean_ctor_set(x_173, 4, x_158); -lean_ctor_set(x_173, 5, x_159); -x_174 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_174, 0, x_173); -lean_ctor_set(x_174, 1, x_154); +lean_ctor_set(x_158, 0, x_146); +lean_ctor_set(x_158, 1, x_147); +lean_ctor_set(x_158, 2, x_157); +lean_ctor_set(x_158, 3, x_148); +lean_ctor_set(x_158, 4, x_149); +lean_ctor_set(x_158, 5, x_150); +x_159 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_159, 0, x_158); +lean_ctor_set(x_159, 1, x_141); +lean_ctor_set(x_159, 2, x_142); +lean_ctor_set(x_159, 3, x_143); +lean_ctor_set(x_159, 4, x_144); +lean_ctor_set(x_159, 5, x_145); +lean_ctor_set(x_33, 0, x_159); if (lean_is_scalar(x_10)) { - x_175 = lean_alloc_ctor(0, 2, 0); + x_160 = lean_alloc_ctor(0, 2, 0); } else { - x_175 = x_10; + x_160 = x_10; } -lean_ctor_set(x_175, 0, x_108); -lean_ctor_set(x_175, 1, x_174); -return x_175; +lean_ctor_set(x_160, 0, x_112); +lean_ctor_set(x_160, 1, x_33); +return x_160; +} +} +else +{ +lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; 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; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; +x_161 = lean_ctor_get(x_33, 1); +lean_inc(x_161); +lean_dec(x_33); +x_162 = lean_ctor_get(x_109, 1); +lean_inc(x_162); +x_163 = lean_ctor_get(x_109, 2); +lean_inc(x_163); +x_164 = lean_ctor_get(x_109, 3); +lean_inc(x_164); +x_165 = lean_ctor_get(x_109, 4); +lean_inc(x_165); +x_166 = lean_ctor_get(x_109, 5); +lean_inc(x_166); +if (lean_is_exclusive(x_109)) { + lean_ctor_release(x_109, 0); + lean_ctor_release(x_109, 1); + lean_ctor_release(x_109, 2); + lean_ctor_release(x_109, 3); + lean_ctor_release(x_109, 4); + lean_ctor_release(x_109, 5); + x_167 = x_109; +} else { + lean_dec_ref(x_109); + x_167 = lean_box(0); +} +x_168 = lean_ctor_get(x_110, 0); +lean_inc(x_168); +x_169 = lean_ctor_get(x_110, 1); +lean_inc(x_169); +x_170 = lean_ctor_get(x_110, 3); +lean_inc(x_170); +x_171 = lean_ctor_get(x_110, 4); +lean_inc(x_171); +x_172 = lean_ctor_get(x_110, 5); +lean_inc(x_172); +if (lean_is_exclusive(x_110)) { + lean_ctor_release(x_110, 0); + lean_ctor_release(x_110, 1); + lean_ctor_release(x_110, 2); + lean_ctor_release(x_110, 3); + lean_ctor_release(x_110, 4); + lean_ctor_release(x_110, 5); + x_173 = x_110; +} else { + lean_dec_ref(x_110); + x_173 = lean_box(0); +} +x_174 = lean_ctor_get(x_111, 0); +lean_inc(x_174); +x_175 = lean_ctor_get(x_111, 1); +lean_inc(x_175); +x_176 = lean_ctor_get(x_111, 3); +lean_inc(x_176); +x_177 = lean_ctor_get(x_111, 4); +lean_inc(x_177); +if (lean_is_exclusive(x_111)) { + lean_ctor_release(x_111, 0); + lean_ctor_release(x_111, 1); + lean_ctor_release(x_111, 2); + lean_ctor_release(x_111, 3); + lean_ctor_release(x_111, 4); + x_178 = x_111; +} else { + lean_dec_ref(x_111); + x_178 = lean_box(0); +} +if (lean_is_scalar(x_178)) { + x_179 = lean_alloc_ctor(0, 5, 0); +} else { + x_179 = x_178; +} +lean_ctor_set(x_179, 0, x_174); +lean_ctor_set(x_179, 1, x_175); +lean_ctor_set(x_179, 2, x_31); +lean_ctor_set(x_179, 3, x_176); +lean_ctor_set(x_179, 4, x_177); +if (lean_is_scalar(x_173)) { + x_180 = lean_alloc_ctor(0, 6, 0); +} else { + x_180 = x_173; +} +lean_ctor_set(x_180, 0, x_168); +lean_ctor_set(x_180, 1, x_169); +lean_ctor_set(x_180, 2, x_179); +lean_ctor_set(x_180, 3, x_170); +lean_ctor_set(x_180, 4, x_171); +lean_ctor_set(x_180, 5, x_172); +if (lean_is_scalar(x_167)) { + x_181 = lean_alloc_ctor(0, 6, 0); +} else { + x_181 = x_167; +} +lean_ctor_set(x_181, 0, x_180); +lean_ctor_set(x_181, 1, x_162); +lean_ctor_set(x_181, 2, x_163); +lean_ctor_set(x_181, 3, x_164); +lean_ctor_set(x_181, 4, x_165); +lean_ctor_set(x_181, 5, x_166); +x_182 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_182, 0, x_181); +lean_ctor_set(x_182, 1, x_161); +if (lean_is_scalar(x_10)) { + x_183 = lean_alloc_ctor(0, 2, 0); +} else { + x_183 = x_10; +} +lean_ctor_set(x_183, 0, x_112); +lean_ctor_set(x_183, 1, x_182); +return x_183; } } } @@ -8866,869 +8956,885 @@ return x_175; } else { -lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; uint8_t x_201; lean_object* x_202; lean_object* x_203; -x_193 = lean_ctor_get(x_7, 0); -x_194 = lean_ctor_get(x_7, 2); -x_195 = lean_ctor_get(x_7, 3); -x_196 = lean_ctor_get(x_7, 4); -lean_inc(x_196); -lean_inc(x_195); -lean_inc(x_194); -lean_inc(x_193); -lean_dec(x_7); -x_197 = lean_ctor_get(x_8, 1); -lean_inc(x_197); -x_198 = lean_ctor_get(x_8, 4); -lean_inc(x_198); -x_199 = lean_array_get_size(x_194); -x_200 = lean_array_get_size(x_198); -x_201 = lean_nat_dec_eq(x_199, x_200); -lean_dec(x_200); -lean_dec(x_199); -lean_inc(x_198); -x_202 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_202, 0, x_193); -lean_ctor_set(x_202, 1, x_197); -lean_ctor_set(x_202, 2, x_198); -lean_ctor_set(x_202, 3, x_195); -lean_ctor_set(x_202, 4, x_196); -lean_ctor_set(x_6, 0, x_202); -x_203 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_203, 0, x_6); -lean_ctor_set(x_203, 1, x_11); -lean_ctor_set(x_203, 2, x_12); -if (x_201 == 0) -{ -lean_object* x_204; -lean_dec(x_198); -lean_dec(x_194); -lean_dec(x_10); -lean_dec(x_8); -lean_dec(x_3); -x_204 = lean_apply_2(x_2, x_203, x_9); -return x_204; -} -else -{ -lean_object* x_205; uint8_t x_206; -x_205 = lean_unsigned_to_nat(0u); -x_206 = l_Array_isEqvAux___main___at_Lean_Elab_Tactic_withMVarContext___spec__1(x_3, x_8, lean_box(0), x_194, x_198, x_205); -lean_dec(x_198); -lean_dec(x_194); -lean_dec(x_8); -lean_dec(x_3); -if (x_206 == 0) -{ -lean_object* x_207; -lean_dec(x_10); -x_207 = lean_apply_2(x_2, x_203, x_9); -return x_207; -} -else -{ -lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_269; lean_object* x_270; -x_208 = lean_ctor_get(x_9, 0); -lean_inc(x_208); -x_209 = lean_ctor_get(x_208, 0); -lean_inc(x_209); -lean_dec(x_208); -x_210 = lean_ctor_get(x_209, 2); -lean_inc(x_210); -lean_dec(x_209); -x_211 = lean_ctor_get(x_210, 2); -lean_inc(x_211); -lean_dec(x_210); -x_269 = l_Lean_Elab_Tactic_resetSynthInstanceCache___closed__1; +lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; uint8_t x_209; lean_object* x_210; lean_object* x_211; +x_201 = lean_ctor_get(x_7, 0); +x_202 = lean_ctor_get(x_7, 2); +x_203 = lean_ctor_get(x_7, 3); +x_204 = lean_ctor_get(x_7, 4); +lean_inc(x_204); lean_inc(x_203); -x_270 = l_Lean_Elab_Tactic_liftTermElabM___rarg(x_269, x_203, x_9); -if (lean_obj_tag(x_270) == 0) +lean_inc(x_202); +lean_inc(x_201); +lean_dec(x_7); +x_205 = lean_ctor_get(x_8, 1); +lean_inc(x_205); +x_206 = lean_ctor_get(x_8, 4); +lean_inc(x_206); +x_207 = lean_array_get_size(x_202); +x_208 = lean_array_get_size(x_206); +x_209 = lean_nat_dec_eq(x_207, x_208); +lean_dec(x_208); +lean_dec(x_207); +lean_inc(x_206); +x_210 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_210, 0, x_201); +lean_ctor_set(x_210, 1, x_205); +lean_ctor_set(x_210, 2, x_206); +lean_ctor_set(x_210, 3, x_203); +lean_ctor_set(x_210, 4, x_204); +lean_ctor_set(x_6, 0, x_210); +x_211 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_211, 0, x_6); +lean_ctor_set(x_211, 1, x_11); +lean_ctor_set(x_211, 2, x_12); +if (x_209 == 0) { -lean_object* x_271; lean_object* x_272; lean_object* x_273; -x_271 = lean_ctor_get(x_270, 1); -lean_inc(x_271); -lean_dec(x_270); -x_272 = l_Lean_Elab_Tactic_save(x_271); -x_273 = lean_apply_2(x_2, x_203, x_271); -if (lean_obj_tag(x_273) == 0) -{ -lean_object* x_274; lean_object* x_275; lean_object* x_276; -lean_dec(x_272); -x_274 = lean_ctor_get(x_273, 0); -lean_inc(x_274); -x_275 = lean_ctor_get(x_273, 1); -lean_inc(x_275); -lean_dec(x_273); -x_276 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_276, 0, x_274); -x_212 = x_276; -x_213 = x_275; -goto block_268; +lean_object* x_212; +lean_dec(x_206); +lean_dec(x_202); +lean_dec(x_10); +lean_dec(x_8); +lean_dec(x_3); +x_212 = lean_apply_2(x_2, x_211, x_9); +return x_212; } else { -lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; -x_277 = lean_ctor_get(x_273, 0); -lean_inc(x_277); -x_278 = lean_ctor_get(x_273, 1); -lean_inc(x_278); -lean_dec(x_273); -x_279 = l_Lean_Elab_Tactic_restore(x_278, x_272); -lean_dec(x_272); -x_280 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_280, 0, x_277); -x_212 = x_280; -x_213 = x_279; -goto block_268; +lean_object* x_213; uint8_t x_214; +x_213 = lean_unsigned_to_nat(0u); +x_214 = l_Array_isEqvAux___main___at_Lean_Elab_Tactic_withMVarContext___spec__1(x_3, x_8, lean_box(0), x_202, x_206, x_213); +lean_dec(x_206); +lean_dec(x_202); +lean_dec(x_8); +lean_dec(x_3); +if (x_214 == 0) +{ +lean_object* x_215; +lean_dec(x_10); +x_215 = lean_apply_2(x_2, x_211, x_9); +return x_215; +} +else +{ +lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_279; lean_object* x_280; +x_216 = lean_ctor_get(x_9, 0); +lean_inc(x_216); +x_217 = lean_ctor_get(x_216, 0); +lean_inc(x_217); +lean_dec(x_216); +x_218 = lean_ctor_get(x_217, 2); +lean_inc(x_218); +lean_dec(x_217); +x_219 = lean_ctor_get(x_218, 2); +lean_inc(x_219); +lean_dec(x_218); +x_279 = l_Lean_Elab_Tactic_resetSynthInstanceCache___closed__1; +lean_inc(x_211); +x_280 = l_Lean_Elab_Tactic_liftTermElabM___rarg(x_279, x_211, x_9); +if (lean_obj_tag(x_280) == 0) +{ +lean_object* x_281; lean_object* x_282; lean_object* x_283; +x_281 = lean_ctor_get(x_280, 1); +lean_inc(x_281); +lean_dec(x_280); +x_282 = l_Lean_Elab_Tactic_save(x_281); +x_283 = lean_apply_2(x_2, x_211, x_281); +if (lean_obj_tag(x_283) == 0) +{ +lean_object* x_284; lean_object* x_285; lean_object* x_286; +lean_dec(x_282); +x_284 = lean_ctor_get(x_283, 0); +lean_inc(x_284); +x_285 = lean_ctor_get(x_283, 1); +lean_inc(x_285); +lean_dec(x_283); +x_286 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_286, 0, x_284); +x_220 = x_286; +x_221 = x_285; +goto block_278; +} +else +{ +lean_object* x_287; lean_object* x_288; lean_object* x_289; lean_object* x_290; +x_287 = lean_ctor_get(x_283, 0); +lean_inc(x_287); +x_288 = lean_ctor_get(x_283, 1); +lean_inc(x_288); +lean_dec(x_283); +x_289 = l_Lean_Elab_Tactic_restore(x_288, x_282); +lean_dec(x_282); +x_290 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_290, 0, x_287); +x_220 = x_290; +x_221 = x_289; +goto block_278; } } else { -lean_object* x_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; +lean_object* x_291; lean_object* x_292; lean_object* x_293; lean_object* x_294; +lean_dec(x_219); lean_dec(x_211); -lean_dec(x_203); lean_dec(x_10); lean_dec(x_2); -x_281 = lean_ctor_get(x_270, 0); -lean_inc(x_281); -x_282 = lean_ctor_get(x_270, 1); -lean_inc(x_282); -if (lean_is_exclusive(x_270)) { - lean_ctor_release(x_270, 0); - lean_ctor_release(x_270, 1); - x_283 = x_270; -} else { - lean_dec_ref(x_270); - x_283 = lean_box(0); -} -if (lean_is_scalar(x_283)) { - x_284 = lean_alloc_ctor(1, 2, 0); -} else { - x_284 = x_283; -} -lean_ctor_set(x_284, 0, x_281); -lean_ctor_set(x_284, 1, x_282); -return x_284; -} -block_268: -{ -if (lean_obj_tag(x_212) == 0) -{ -lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; lean_object* x_224; lean_object* x_225; lean_object* x_226; lean_object* x_227; lean_object* x_228; lean_object* x_229; lean_object* x_230; lean_object* x_231; lean_object* x_232; lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_object* x_236; lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_object* x_240; -x_214 = lean_ctor_get(x_213, 0); -lean_inc(x_214); -x_215 = lean_ctor_get(x_214, 0); -lean_inc(x_215); -x_216 = lean_ctor_get(x_215, 2); -lean_inc(x_216); -x_217 = lean_ctor_get(x_212, 0); -lean_inc(x_217); -lean_dec(x_212); -x_218 = lean_ctor_get(x_213, 1); -lean_inc(x_218); -if (lean_is_exclusive(x_213)) { - lean_ctor_release(x_213, 0); - lean_ctor_release(x_213, 1); - x_219 = x_213; -} else { - lean_dec_ref(x_213); - x_219 = lean_box(0); -} -x_220 = lean_ctor_get(x_214, 1); -lean_inc(x_220); -x_221 = lean_ctor_get(x_214, 2); -lean_inc(x_221); -x_222 = lean_ctor_get(x_214, 3); -lean_inc(x_222); -x_223 = lean_ctor_get(x_214, 4); -lean_inc(x_223); -x_224 = lean_ctor_get(x_214, 5); -lean_inc(x_224); -if (lean_is_exclusive(x_214)) { - lean_ctor_release(x_214, 0); - lean_ctor_release(x_214, 1); - lean_ctor_release(x_214, 2); - lean_ctor_release(x_214, 3); - lean_ctor_release(x_214, 4); - lean_ctor_release(x_214, 5); - x_225 = x_214; -} else { - lean_dec_ref(x_214); - x_225 = lean_box(0); -} -x_226 = lean_ctor_get(x_215, 0); -lean_inc(x_226); -x_227 = lean_ctor_get(x_215, 1); -lean_inc(x_227); -x_228 = lean_ctor_get(x_215, 3); -lean_inc(x_228); -x_229 = lean_ctor_get(x_215, 4); -lean_inc(x_229); -x_230 = lean_ctor_get(x_215, 5); -lean_inc(x_230); -if (lean_is_exclusive(x_215)) { - lean_ctor_release(x_215, 0); - lean_ctor_release(x_215, 1); - lean_ctor_release(x_215, 2); - lean_ctor_release(x_215, 3); - lean_ctor_release(x_215, 4); - lean_ctor_release(x_215, 5); - x_231 = x_215; -} else { - lean_dec_ref(x_215); - x_231 = lean_box(0); -} -x_232 = lean_ctor_get(x_216, 0); -lean_inc(x_232); -x_233 = lean_ctor_get(x_216, 1); -lean_inc(x_233); -x_234 = lean_ctor_get(x_216, 3); -lean_inc(x_234); -if (lean_is_exclusive(x_216)) { - lean_ctor_release(x_216, 0); - lean_ctor_release(x_216, 1); - lean_ctor_release(x_216, 2); - lean_ctor_release(x_216, 3); - x_235 = x_216; -} else { - lean_dec_ref(x_216); - x_235 = lean_box(0); -} -if (lean_is_scalar(x_235)) { - x_236 = lean_alloc_ctor(0, 4, 0); -} else { - x_236 = x_235; -} -lean_ctor_set(x_236, 0, x_232); -lean_ctor_set(x_236, 1, x_233); -lean_ctor_set(x_236, 2, x_211); -lean_ctor_set(x_236, 3, x_234); -if (lean_is_scalar(x_231)) { - x_237 = lean_alloc_ctor(0, 6, 0); -} else { - x_237 = x_231; -} -lean_ctor_set(x_237, 0, x_226); -lean_ctor_set(x_237, 1, x_227); -lean_ctor_set(x_237, 2, x_236); -lean_ctor_set(x_237, 3, x_228); -lean_ctor_set(x_237, 4, x_229); -lean_ctor_set(x_237, 5, x_230); -if (lean_is_scalar(x_225)) { - x_238 = lean_alloc_ctor(0, 6, 0); -} else { - x_238 = x_225; -} -lean_ctor_set(x_238, 0, x_237); -lean_ctor_set(x_238, 1, x_220); -lean_ctor_set(x_238, 2, x_221); -lean_ctor_set(x_238, 3, x_222); -lean_ctor_set(x_238, 4, x_223); -lean_ctor_set(x_238, 5, x_224); -if (lean_is_scalar(x_219)) { - x_239 = lean_alloc_ctor(0, 2, 0); -} else { - x_239 = x_219; -} -lean_ctor_set(x_239, 0, x_238); -lean_ctor_set(x_239, 1, x_218); -if (lean_is_scalar(x_10)) { - x_240 = lean_alloc_ctor(1, 2, 0); -} else { - x_240 = x_10; - lean_ctor_set_tag(x_240, 1); -} -lean_ctor_set(x_240, 0, x_217); -lean_ctor_set(x_240, 1, x_239); -return x_240; -} -else -{ -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; lean_object* x_252; lean_object* x_253; lean_object* x_254; lean_object* x_255; lean_object* x_256; lean_object* x_257; lean_object* x_258; 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; -x_241 = lean_ctor_get(x_213, 0); -lean_inc(x_241); -x_242 = lean_ctor_get(x_241, 0); -lean_inc(x_242); -x_243 = lean_ctor_get(x_242, 2); -lean_inc(x_243); -x_244 = lean_ctor_get(x_212, 0); -lean_inc(x_244); -lean_dec(x_212); -x_245 = lean_ctor_get(x_213, 1); -lean_inc(x_245); -if (lean_is_exclusive(x_213)) { - lean_ctor_release(x_213, 0); - lean_ctor_release(x_213, 1); - x_246 = x_213; -} else { - lean_dec_ref(x_213); - x_246 = lean_box(0); -} -x_247 = lean_ctor_get(x_241, 1); -lean_inc(x_247); -x_248 = lean_ctor_get(x_241, 2); -lean_inc(x_248); -x_249 = lean_ctor_get(x_241, 3); -lean_inc(x_249); -x_250 = lean_ctor_get(x_241, 4); -lean_inc(x_250); -x_251 = lean_ctor_get(x_241, 5); -lean_inc(x_251); -if (lean_is_exclusive(x_241)) { - lean_ctor_release(x_241, 0); - lean_ctor_release(x_241, 1); - lean_ctor_release(x_241, 2); - lean_ctor_release(x_241, 3); - lean_ctor_release(x_241, 4); - lean_ctor_release(x_241, 5); - x_252 = x_241; -} else { - lean_dec_ref(x_241); - x_252 = lean_box(0); -} -x_253 = lean_ctor_get(x_242, 0); -lean_inc(x_253); -x_254 = lean_ctor_get(x_242, 1); -lean_inc(x_254); -x_255 = lean_ctor_get(x_242, 3); -lean_inc(x_255); -x_256 = lean_ctor_get(x_242, 4); -lean_inc(x_256); -x_257 = lean_ctor_get(x_242, 5); -lean_inc(x_257); -if (lean_is_exclusive(x_242)) { - lean_ctor_release(x_242, 0); - lean_ctor_release(x_242, 1); - lean_ctor_release(x_242, 2); - lean_ctor_release(x_242, 3); - lean_ctor_release(x_242, 4); - lean_ctor_release(x_242, 5); - x_258 = x_242; -} else { - lean_dec_ref(x_242); - x_258 = lean_box(0); -} -x_259 = lean_ctor_get(x_243, 0); -lean_inc(x_259); -x_260 = lean_ctor_get(x_243, 1); -lean_inc(x_260); -x_261 = lean_ctor_get(x_243, 3); -lean_inc(x_261); -if (lean_is_exclusive(x_243)) { - lean_ctor_release(x_243, 0); - lean_ctor_release(x_243, 1); - lean_ctor_release(x_243, 2); - lean_ctor_release(x_243, 3); - x_262 = x_243; -} else { - lean_dec_ref(x_243); - x_262 = lean_box(0); -} -if (lean_is_scalar(x_262)) { - x_263 = lean_alloc_ctor(0, 4, 0); -} else { - x_263 = x_262; -} -lean_ctor_set(x_263, 0, x_259); -lean_ctor_set(x_263, 1, x_260); -lean_ctor_set(x_263, 2, x_211); -lean_ctor_set(x_263, 3, x_261); -if (lean_is_scalar(x_258)) { - x_264 = lean_alloc_ctor(0, 6, 0); -} else { - x_264 = x_258; -} -lean_ctor_set(x_264, 0, x_253); -lean_ctor_set(x_264, 1, x_254); -lean_ctor_set(x_264, 2, x_263); -lean_ctor_set(x_264, 3, x_255); -lean_ctor_set(x_264, 4, x_256); -lean_ctor_set(x_264, 5, x_257); -if (lean_is_scalar(x_252)) { - x_265 = lean_alloc_ctor(0, 6, 0); -} else { - x_265 = x_252; -} -lean_ctor_set(x_265, 0, x_264); -lean_ctor_set(x_265, 1, x_247); -lean_ctor_set(x_265, 2, x_248); -lean_ctor_set(x_265, 3, x_249); -lean_ctor_set(x_265, 4, x_250); -lean_ctor_set(x_265, 5, x_251); -if (lean_is_scalar(x_246)) { - x_266 = lean_alloc_ctor(0, 2, 0); -} else { - x_266 = x_246; -} -lean_ctor_set(x_266, 0, x_265); -lean_ctor_set(x_266, 1, x_245); -if (lean_is_scalar(x_10)) { - x_267 = lean_alloc_ctor(0, 2, 0); -} else { - x_267 = x_10; -} -lean_ctor_set(x_267, 0, x_244); -lean_ctor_set(x_267, 1, x_266); -return x_267; -} -} -} -} -} -} -else -{ -lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; lean_object* x_289; lean_object* x_290; lean_object* x_291; lean_object* x_292; lean_object* x_293; uint8_t x_294; uint8_t x_295; uint8_t x_296; lean_object* x_297; lean_object* x_298; lean_object* x_299; lean_object* x_300; lean_object* x_301; lean_object* x_302; lean_object* x_303; lean_object* x_304; lean_object* x_305; uint8_t x_306; lean_object* x_307; lean_object* x_308; lean_object* x_309; -x_285 = lean_ctor_get(x_6, 1); -x_286 = lean_ctor_get(x_6, 2); -x_287 = lean_ctor_get(x_6, 3); -x_288 = lean_ctor_get(x_6, 4); -x_289 = lean_ctor_get(x_6, 5); -x_290 = lean_ctor_get(x_6, 6); -x_291 = lean_ctor_get(x_6, 7); -x_292 = lean_ctor_get(x_6, 8); -x_293 = lean_ctor_get(x_6, 9); -x_294 = lean_ctor_get_uint8(x_6, sizeof(void*)*10); -x_295 = lean_ctor_get_uint8(x_6, sizeof(void*)*10 + 1); -x_296 = lean_ctor_get_uint8(x_6, sizeof(void*)*10 + 2); -lean_inc(x_293); -lean_inc(x_292); +x_291 = lean_ctor_get(x_280, 0); lean_inc(x_291); -lean_inc(x_290); -lean_inc(x_289); -lean_inc(x_288); -lean_inc(x_287); -lean_inc(x_286); -lean_inc(x_285); -lean_dec(x_6); -x_297 = lean_ctor_get(x_7, 0); -lean_inc(x_297); -x_298 = lean_ctor_get(x_7, 2); -lean_inc(x_298); -x_299 = lean_ctor_get(x_7, 3); -lean_inc(x_299); -x_300 = lean_ctor_get(x_7, 4); +x_292 = lean_ctor_get(x_280, 1); +lean_inc(x_292); +if (lean_is_exclusive(x_280)) { + lean_ctor_release(x_280, 0); + lean_ctor_release(x_280, 1); + x_293 = x_280; +} else { + lean_dec_ref(x_280); + x_293 = lean_box(0); +} +if (lean_is_scalar(x_293)) { + x_294 = lean_alloc_ctor(1, 2, 0); +} else { + x_294 = x_293; +} +lean_ctor_set(x_294, 0, x_291); +lean_ctor_set(x_294, 1, x_292); +return x_294; +} +block_278: +{ +if (lean_obj_tag(x_220) == 0) +{ +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; lean_object* x_231; lean_object* x_232; lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_object* x_236; lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; lean_object* x_242; 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; +x_222 = lean_ctor_get(x_221, 0); +lean_inc(x_222); +x_223 = lean_ctor_get(x_222, 0); +lean_inc(x_223); +x_224 = lean_ctor_get(x_223, 2); +lean_inc(x_224); +x_225 = lean_ctor_get(x_220, 0); +lean_inc(x_225); +lean_dec(x_220); +x_226 = lean_ctor_get(x_221, 1); +lean_inc(x_226); +if (lean_is_exclusive(x_221)) { + lean_ctor_release(x_221, 0); + lean_ctor_release(x_221, 1); + x_227 = x_221; +} else { + lean_dec_ref(x_221); + x_227 = lean_box(0); +} +x_228 = lean_ctor_get(x_222, 1); +lean_inc(x_228); +x_229 = lean_ctor_get(x_222, 2); +lean_inc(x_229); +x_230 = lean_ctor_get(x_222, 3); +lean_inc(x_230); +x_231 = lean_ctor_get(x_222, 4); +lean_inc(x_231); +x_232 = lean_ctor_get(x_222, 5); +lean_inc(x_232); +if (lean_is_exclusive(x_222)) { + lean_ctor_release(x_222, 0); + lean_ctor_release(x_222, 1); + lean_ctor_release(x_222, 2); + lean_ctor_release(x_222, 3); + lean_ctor_release(x_222, 4); + lean_ctor_release(x_222, 5); + x_233 = x_222; +} else { + lean_dec_ref(x_222); + x_233 = lean_box(0); +} +x_234 = lean_ctor_get(x_223, 0); +lean_inc(x_234); +x_235 = lean_ctor_get(x_223, 1); +lean_inc(x_235); +x_236 = lean_ctor_get(x_223, 3); +lean_inc(x_236); +x_237 = lean_ctor_get(x_223, 4); +lean_inc(x_237); +x_238 = lean_ctor_get(x_223, 5); +lean_inc(x_238); +if (lean_is_exclusive(x_223)) { + lean_ctor_release(x_223, 0); + lean_ctor_release(x_223, 1); + lean_ctor_release(x_223, 2); + lean_ctor_release(x_223, 3); + lean_ctor_release(x_223, 4); + lean_ctor_release(x_223, 5); + x_239 = x_223; +} else { + lean_dec_ref(x_223); + x_239 = lean_box(0); +} +x_240 = lean_ctor_get(x_224, 0); +lean_inc(x_240); +x_241 = lean_ctor_get(x_224, 1); +lean_inc(x_241); +x_242 = lean_ctor_get(x_224, 3); +lean_inc(x_242); +x_243 = lean_ctor_get(x_224, 4); +lean_inc(x_243); +if (lean_is_exclusive(x_224)) { + lean_ctor_release(x_224, 0); + lean_ctor_release(x_224, 1); + lean_ctor_release(x_224, 2); + lean_ctor_release(x_224, 3); + lean_ctor_release(x_224, 4); + x_244 = x_224; +} else { + lean_dec_ref(x_224); + x_244 = lean_box(0); +} +if (lean_is_scalar(x_244)) { + x_245 = lean_alloc_ctor(0, 5, 0); +} else { + x_245 = x_244; +} +lean_ctor_set(x_245, 0, x_240); +lean_ctor_set(x_245, 1, x_241); +lean_ctor_set(x_245, 2, x_219); +lean_ctor_set(x_245, 3, x_242); +lean_ctor_set(x_245, 4, x_243); +if (lean_is_scalar(x_239)) { + x_246 = lean_alloc_ctor(0, 6, 0); +} else { + x_246 = x_239; +} +lean_ctor_set(x_246, 0, x_234); +lean_ctor_set(x_246, 1, x_235); +lean_ctor_set(x_246, 2, x_245); +lean_ctor_set(x_246, 3, x_236); +lean_ctor_set(x_246, 4, x_237); +lean_ctor_set(x_246, 5, x_238); +if (lean_is_scalar(x_233)) { + x_247 = lean_alloc_ctor(0, 6, 0); +} else { + x_247 = x_233; +} +lean_ctor_set(x_247, 0, x_246); +lean_ctor_set(x_247, 1, x_228); +lean_ctor_set(x_247, 2, x_229); +lean_ctor_set(x_247, 3, x_230); +lean_ctor_set(x_247, 4, x_231); +lean_ctor_set(x_247, 5, x_232); +if (lean_is_scalar(x_227)) { + x_248 = lean_alloc_ctor(0, 2, 0); +} else { + x_248 = x_227; +} +lean_ctor_set(x_248, 0, x_247); +lean_ctor_set(x_248, 1, x_226); +if (lean_is_scalar(x_10)) { + x_249 = lean_alloc_ctor(1, 2, 0); +} else { + x_249 = x_10; + lean_ctor_set_tag(x_249, 1); +} +lean_ctor_set(x_249, 0, x_225); +lean_ctor_set(x_249, 1, x_248); +return x_249; +} +else +{ +lean_object* x_250; lean_object* x_251; lean_object* x_252; lean_object* x_253; lean_object* x_254; lean_object* x_255; lean_object* x_256; lean_object* x_257; lean_object* x_258; lean_object* x_259; lean_object* x_260; lean_object* x_261; lean_object* x_262; lean_object* x_263; lean_object* x_264; lean_object* x_265; lean_object* x_266; lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_object* x_270; lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_object* x_276; lean_object* x_277; +x_250 = lean_ctor_get(x_221, 0); +lean_inc(x_250); +x_251 = lean_ctor_get(x_250, 0); +lean_inc(x_251); +x_252 = lean_ctor_get(x_251, 2); +lean_inc(x_252); +x_253 = lean_ctor_get(x_220, 0); +lean_inc(x_253); +lean_dec(x_220); +x_254 = lean_ctor_get(x_221, 1); +lean_inc(x_254); +if (lean_is_exclusive(x_221)) { + lean_ctor_release(x_221, 0); + lean_ctor_release(x_221, 1); + x_255 = x_221; +} else { + lean_dec_ref(x_221); + x_255 = lean_box(0); +} +x_256 = lean_ctor_get(x_250, 1); +lean_inc(x_256); +x_257 = lean_ctor_get(x_250, 2); +lean_inc(x_257); +x_258 = lean_ctor_get(x_250, 3); +lean_inc(x_258); +x_259 = lean_ctor_get(x_250, 4); +lean_inc(x_259); +x_260 = lean_ctor_get(x_250, 5); +lean_inc(x_260); +if (lean_is_exclusive(x_250)) { + lean_ctor_release(x_250, 0); + lean_ctor_release(x_250, 1); + lean_ctor_release(x_250, 2); + lean_ctor_release(x_250, 3); + lean_ctor_release(x_250, 4); + lean_ctor_release(x_250, 5); + x_261 = x_250; +} else { + lean_dec_ref(x_250); + x_261 = lean_box(0); +} +x_262 = lean_ctor_get(x_251, 0); +lean_inc(x_262); +x_263 = lean_ctor_get(x_251, 1); +lean_inc(x_263); +x_264 = lean_ctor_get(x_251, 3); +lean_inc(x_264); +x_265 = lean_ctor_get(x_251, 4); +lean_inc(x_265); +x_266 = lean_ctor_get(x_251, 5); +lean_inc(x_266); +if (lean_is_exclusive(x_251)) { + lean_ctor_release(x_251, 0); + lean_ctor_release(x_251, 1); + lean_ctor_release(x_251, 2); + lean_ctor_release(x_251, 3); + lean_ctor_release(x_251, 4); + lean_ctor_release(x_251, 5); + x_267 = x_251; +} else { + lean_dec_ref(x_251); + x_267 = lean_box(0); +} +x_268 = lean_ctor_get(x_252, 0); +lean_inc(x_268); +x_269 = lean_ctor_get(x_252, 1); +lean_inc(x_269); +x_270 = lean_ctor_get(x_252, 3); +lean_inc(x_270); +x_271 = lean_ctor_get(x_252, 4); +lean_inc(x_271); +if (lean_is_exclusive(x_252)) { + lean_ctor_release(x_252, 0); + lean_ctor_release(x_252, 1); + lean_ctor_release(x_252, 2); + lean_ctor_release(x_252, 3); + lean_ctor_release(x_252, 4); + x_272 = x_252; +} else { + lean_dec_ref(x_252); + x_272 = lean_box(0); +} +if (lean_is_scalar(x_272)) { + x_273 = lean_alloc_ctor(0, 5, 0); +} else { + x_273 = x_272; +} +lean_ctor_set(x_273, 0, x_268); +lean_ctor_set(x_273, 1, x_269); +lean_ctor_set(x_273, 2, x_219); +lean_ctor_set(x_273, 3, x_270); +lean_ctor_set(x_273, 4, x_271); +if (lean_is_scalar(x_267)) { + x_274 = lean_alloc_ctor(0, 6, 0); +} else { + x_274 = x_267; +} +lean_ctor_set(x_274, 0, x_262); +lean_ctor_set(x_274, 1, x_263); +lean_ctor_set(x_274, 2, x_273); +lean_ctor_set(x_274, 3, x_264); +lean_ctor_set(x_274, 4, x_265); +lean_ctor_set(x_274, 5, x_266); +if (lean_is_scalar(x_261)) { + x_275 = lean_alloc_ctor(0, 6, 0); +} else { + x_275 = x_261; +} +lean_ctor_set(x_275, 0, x_274); +lean_ctor_set(x_275, 1, x_256); +lean_ctor_set(x_275, 2, x_257); +lean_ctor_set(x_275, 3, x_258); +lean_ctor_set(x_275, 4, x_259); +lean_ctor_set(x_275, 5, x_260); +if (lean_is_scalar(x_255)) { + x_276 = lean_alloc_ctor(0, 2, 0); +} else { + x_276 = x_255; +} +lean_ctor_set(x_276, 0, x_275); +lean_ctor_set(x_276, 1, x_254); +if (lean_is_scalar(x_10)) { + x_277 = lean_alloc_ctor(0, 2, 0); +} else { + x_277 = x_10; +} +lean_ctor_set(x_277, 0, x_253); +lean_ctor_set(x_277, 1, x_276); +return x_277; +} +} +} +} +} +} +else +{ +lean_object* x_295; lean_object* x_296; lean_object* x_297; lean_object* x_298; lean_object* x_299; lean_object* x_300; lean_object* x_301; lean_object* x_302; lean_object* x_303; uint8_t x_304; uint8_t x_305; uint8_t x_306; lean_object* x_307; lean_object* x_308; lean_object* x_309; lean_object* x_310; lean_object* x_311; lean_object* x_312; lean_object* x_313; lean_object* x_314; lean_object* x_315; uint8_t x_316; lean_object* x_317; lean_object* x_318; lean_object* x_319; +x_295 = lean_ctor_get(x_6, 1); +x_296 = lean_ctor_get(x_6, 2); +x_297 = lean_ctor_get(x_6, 3); +x_298 = lean_ctor_get(x_6, 4); +x_299 = lean_ctor_get(x_6, 5); +x_300 = lean_ctor_get(x_6, 6); +x_301 = lean_ctor_get(x_6, 7); +x_302 = lean_ctor_get(x_6, 8); +x_303 = lean_ctor_get(x_6, 9); +x_304 = lean_ctor_get_uint8(x_6, sizeof(void*)*10); +x_305 = lean_ctor_get_uint8(x_6, sizeof(void*)*10 + 1); +x_306 = lean_ctor_get_uint8(x_6, sizeof(void*)*10 + 2); +lean_inc(x_303); +lean_inc(x_302); +lean_inc(x_301); lean_inc(x_300); +lean_inc(x_299); +lean_inc(x_298); +lean_inc(x_297); +lean_inc(x_296); +lean_inc(x_295); +lean_dec(x_6); +x_307 = lean_ctor_get(x_7, 0); +lean_inc(x_307); +x_308 = lean_ctor_get(x_7, 2); +lean_inc(x_308); +x_309 = lean_ctor_get(x_7, 3); +lean_inc(x_309); +x_310 = lean_ctor_get(x_7, 4); +lean_inc(x_310); if (lean_is_exclusive(x_7)) { lean_ctor_release(x_7, 0); lean_ctor_release(x_7, 1); lean_ctor_release(x_7, 2); lean_ctor_release(x_7, 3); lean_ctor_release(x_7, 4); - x_301 = x_7; + x_311 = x_7; } else { lean_dec_ref(x_7); - x_301 = lean_box(0); + x_311 = lean_box(0); } -x_302 = lean_ctor_get(x_8, 1); -lean_inc(x_302); -x_303 = lean_ctor_get(x_8, 4); -lean_inc(x_303); -x_304 = lean_array_get_size(x_298); -x_305 = lean_array_get_size(x_303); -x_306 = lean_nat_dec_eq(x_304, x_305); -lean_dec(x_305); -lean_dec(x_304); -lean_inc(x_303); -if (lean_is_scalar(x_301)) { - x_307 = lean_alloc_ctor(0, 5, 0); -} else { - x_307 = x_301; -} -lean_ctor_set(x_307, 0, x_297); -lean_ctor_set(x_307, 1, x_302); -lean_ctor_set(x_307, 2, x_303); -lean_ctor_set(x_307, 3, x_299); -lean_ctor_set(x_307, 4, x_300); -x_308 = lean_alloc_ctor(0, 10, 3); -lean_ctor_set(x_308, 0, x_307); -lean_ctor_set(x_308, 1, x_285); -lean_ctor_set(x_308, 2, x_286); -lean_ctor_set(x_308, 3, x_287); -lean_ctor_set(x_308, 4, x_288); -lean_ctor_set(x_308, 5, x_289); -lean_ctor_set(x_308, 6, x_290); -lean_ctor_set(x_308, 7, x_291); -lean_ctor_set(x_308, 8, x_292); -lean_ctor_set(x_308, 9, x_293); -lean_ctor_set_uint8(x_308, sizeof(void*)*10, x_294); -lean_ctor_set_uint8(x_308, sizeof(void*)*10 + 1, x_295); -lean_ctor_set_uint8(x_308, sizeof(void*)*10 + 2, x_296); -x_309 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_309, 0, x_308); -lean_ctor_set(x_309, 1, x_11); -lean_ctor_set(x_309, 2, x_12); -if (x_306 == 0) -{ -lean_object* x_310; -lean_dec(x_303); -lean_dec(x_298); -lean_dec(x_10); -lean_dec(x_8); -lean_dec(x_3); -x_310 = lean_apply_2(x_2, x_309, x_9); -return x_310; -} -else -{ -lean_object* x_311; uint8_t x_312; -x_311 = lean_unsigned_to_nat(0u); -x_312 = l_Array_isEqvAux___main___at_Lean_Elab_Tactic_withMVarContext___spec__1(x_3, x_8, lean_box(0), x_298, x_303, x_311); -lean_dec(x_303); -lean_dec(x_298); -lean_dec(x_8); -lean_dec(x_3); -if (x_312 == 0) -{ -lean_object* x_313; -lean_dec(x_10); -x_313 = lean_apply_2(x_2, x_309, x_9); -return x_313; -} -else -{ -lean_object* x_314; lean_object* x_315; lean_object* x_316; lean_object* x_317; lean_object* x_318; lean_object* x_319; lean_object* x_375; lean_object* x_376; -x_314 = lean_ctor_get(x_9, 0); -lean_inc(x_314); -x_315 = lean_ctor_get(x_314, 0); -lean_inc(x_315); -lean_dec(x_314); -x_316 = lean_ctor_get(x_315, 2); -lean_inc(x_316); +x_312 = lean_ctor_get(x_8, 1); +lean_inc(x_312); +x_313 = lean_ctor_get(x_8, 4); +lean_inc(x_313); +x_314 = lean_array_get_size(x_308); +x_315 = lean_array_get_size(x_313); +x_316 = lean_nat_dec_eq(x_314, x_315); lean_dec(x_315); -x_317 = lean_ctor_get(x_316, 2); -lean_inc(x_317); -lean_dec(x_316); -x_375 = l_Lean_Elab_Tactic_resetSynthInstanceCache___closed__1; -lean_inc(x_309); -x_376 = l_Lean_Elab_Tactic_liftTermElabM___rarg(x_375, x_309, x_9); -if (lean_obj_tag(x_376) == 0) +lean_dec(x_314); +lean_inc(x_313); +if (lean_is_scalar(x_311)) { + x_317 = lean_alloc_ctor(0, 5, 0); +} else { + x_317 = x_311; +} +lean_ctor_set(x_317, 0, x_307); +lean_ctor_set(x_317, 1, x_312); +lean_ctor_set(x_317, 2, x_313); +lean_ctor_set(x_317, 3, x_309); +lean_ctor_set(x_317, 4, x_310); +x_318 = lean_alloc_ctor(0, 10, 3); +lean_ctor_set(x_318, 0, x_317); +lean_ctor_set(x_318, 1, x_295); +lean_ctor_set(x_318, 2, x_296); +lean_ctor_set(x_318, 3, x_297); +lean_ctor_set(x_318, 4, x_298); +lean_ctor_set(x_318, 5, x_299); +lean_ctor_set(x_318, 6, x_300); +lean_ctor_set(x_318, 7, x_301); +lean_ctor_set(x_318, 8, x_302); +lean_ctor_set(x_318, 9, x_303); +lean_ctor_set_uint8(x_318, sizeof(void*)*10, x_304); +lean_ctor_set_uint8(x_318, sizeof(void*)*10 + 1, x_305); +lean_ctor_set_uint8(x_318, sizeof(void*)*10 + 2, x_306); +x_319 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_319, 0, x_318); +lean_ctor_set(x_319, 1, x_11); +lean_ctor_set(x_319, 2, x_12); +if (x_316 == 0) { -lean_object* x_377; lean_object* x_378; lean_object* x_379; -x_377 = lean_ctor_get(x_376, 1); -lean_inc(x_377); -lean_dec(x_376); -x_378 = l_Lean_Elab_Tactic_save(x_377); -x_379 = lean_apply_2(x_2, x_309, x_377); -if (lean_obj_tag(x_379) == 0) -{ -lean_object* x_380; lean_object* x_381; lean_object* x_382; -lean_dec(x_378); -x_380 = lean_ctor_get(x_379, 0); -lean_inc(x_380); -x_381 = lean_ctor_get(x_379, 1); -lean_inc(x_381); -lean_dec(x_379); -x_382 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_382, 0, x_380); -x_318 = x_382; -x_319 = x_381; -goto block_374; +lean_object* x_320; +lean_dec(x_313); +lean_dec(x_308); +lean_dec(x_10); +lean_dec(x_8); +lean_dec(x_3); +x_320 = lean_apply_2(x_2, x_319, x_9); +return x_320; } else { -lean_object* x_383; lean_object* x_384; lean_object* x_385; lean_object* x_386; -x_383 = lean_ctor_get(x_379, 0); -lean_inc(x_383); -x_384 = lean_ctor_get(x_379, 1); -lean_inc(x_384); -lean_dec(x_379); -x_385 = l_Lean_Elab_Tactic_restore(x_384, x_378); -lean_dec(x_378); -x_386 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_386, 0, x_383); -x_318 = x_386; -x_319 = x_385; -goto block_374; +lean_object* x_321; uint8_t x_322; +x_321 = lean_unsigned_to_nat(0u); +x_322 = l_Array_isEqvAux___main___at_Lean_Elab_Tactic_withMVarContext___spec__1(x_3, x_8, lean_box(0), x_308, x_313, x_321); +lean_dec(x_313); +lean_dec(x_308); +lean_dec(x_8); +lean_dec(x_3); +if (x_322 == 0) +{ +lean_object* x_323; +lean_dec(x_10); +x_323 = lean_apply_2(x_2, x_319, x_9); +return x_323; +} +else +{ +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_387; lean_object* x_388; +x_324 = lean_ctor_get(x_9, 0); +lean_inc(x_324); +x_325 = lean_ctor_get(x_324, 0); +lean_inc(x_325); +lean_dec(x_324); +x_326 = lean_ctor_get(x_325, 2); +lean_inc(x_326); +lean_dec(x_325); +x_327 = lean_ctor_get(x_326, 2); +lean_inc(x_327); +lean_dec(x_326); +x_387 = l_Lean_Elab_Tactic_resetSynthInstanceCache___closed__1; +lean_inc(x_319); +x_388 = l_Lean_Elab_Tactic_liftTermElabM___rarg(x_387, x_319, x_9); +if (lean_obj_tag(x_388) == 0) +{ +lean_object* x_389; lean_object* x_390; lean_object* x_391; +x_389 = lean_ctor_get(x_388, 1); +lean_inc(x_389); +lean_dec(x_388); +x_390 = l_Lean_Elab_Tactic_save(x_389); +x_391 = lean_apply_2(x_2, x_319, x_389); +if (lean_obj_tag(x_391) == 0) +{ +lean_object* x_392; lean_object* x_393; lean_object* x_394; +lean_dec(x_390); +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); +x_394 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_394, 0, x_392); +x_328 = x_394; +x_329 = x_393; +goto block_386; +} +else +{ +lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; +x_395 = lean_ctor_get(x_391, 0); +lean_inc(x_395); +x_396 = lean_ctor_get(x_391, 1); +lean_inc(x_396); +lean_dec(x_391); +x_397 = l_Lean_Elab_Tactic_restore(x_396, x_390); +lean_dec(x_390); +x_398 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_398, 0, x_395); +x_328 = x_398; +x_329 = x_397; +goto block_386; } } else { -lean_object* x_387; lean_object* x_388; lean_object* x_389; lean_object* x_390; -lean_dec(x_317); -lean_dec(x_309); +lean_object* x_399; lean_object* x_400; lean_object* x_401; lean_object* x_402; +lean_dec(x_327); +lean_dec(x_319); lean_dec(x_10); lean_dec(x_2); -x_387 = lean_ctor_get(x_376, 0); -lean_inc(x_387); -x_388 = lean_ctor_get(x_376, 1); -lean_inc(x_388); -if (lean_is_exclusive(x_376)) { - lean_ctor_release(x_376, 0); - lean_ctor_release(x_376, 1); - x_389 = x_376; +x_399 = lean_ctor_get(x_388, 0); +lean_inc(x_399); +x_400 = lean_ctor_get(x_388, 1); +lean_inc(x_400); +if (lean_is_exclusive(x_388)) { + lean_ctor_release(x_388, 0); + lean_ctor_release(x_388, 1); + x_401 = x_388; } else { - lean_dec_ref(x_376); - x_389 = lean_box(0); + lean_dec_ref(x_388); + x_401 = lean_box(0); } -if (lean_is_scalar(x_389)) { - x_390 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_401)) { + x_402 = lean_alloc_ctor(1, 2, 0); } else { - x_390 = x_389; + x_402 = x_401; } -lean_ctor_set(x_390, 0, x_387); -lean_ctor_set(x_390, 1, x_388); -return x_390; +lean_ctor_set(x_402, 0, x_399); +lean_ctor_set(x_402, 1, x_400); +return x_402; } -block_374: +block_386: { -if (lean_obj_tag(x_318) == 0) +if (lean_obj_tag(x_328) == 0) { -lean_object* x_320; lean_object* x_321; lean_object* x_322; lean_object* x_323; lean_object* x_324; lean_object* x_325; lean_object* x_326; lean_object* x_327; lean_object* x_328; lean_object* x_329; lean_object* x_330; lean_object* x_331; lean_object* x_332; lean_object* x_333; lean_object* x_334; lean_object* x_335; lean_object* x_336; lean_object* x_337; lean_object* x_338; lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; lean_object* x_345; lean_object* x_346; -x_320 = lean_ctor_get(x_319, 0); -lean_inc(x_320); -x_321 = lean_ctor_get(x_320, 0); -lean_inc(x_321); -x_322 = lean_ctor_get(x_321, 2); -lean_inc(x_322); -x_323 = lean_ctor_get(x_318, 0); -lean_inc(x_323); -lean_dec(x_318); -x_324 = lean_ctor_get(x_319, 1); -lean_inc(x_324); -if (lean_is_exclusive(x_319)) { - lean_ctor_release(x_319, 0); - lean_ctor_release(x_319, 1); - x_325 = x_319; -} else { - lean_dec_ref(x_319); - x_325 = lean_box(0); -} -x_326 = lean_ctor_get(x_320, 1); -lean_inc(x_326); -x_327 = lean_ctor_get(x_320, 2); -lean_inc(x_327); -x_328 = lean_ctor_get(x_320, 3); -lean_inc(x_328); -x_329 = lean_ctor_get(x_320, 4); -lean_inc(x_329); -x_330 = lean_ctor_get(x_320, 5); +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; lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; lean_object* x_350; lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; +x_330 = lean_ctor_get(x_329, 0); lean_inc(x_330); -if (lean_is_exclusive(x_320)) { - lean_ctor_release(x_320, 0); - lean_ctor_release(x_320, 1); - lean_ctor_release(x_320, 2); - lean_ctor_release(x_320, 3); - lean_ctor_release(x_320, 4); - lean_ctor_release(x_320, 5); - x_331 = x_320; -} else { - lean_dec_ref(x_320); - x_331 = lean_box(0); -} -x_332 = lean_ctor_get(x_321, 0); +x_331 = lean_ctor_get(x_330, 0); +lean_inc(x_331); +x_332 = lean_ctor_get(x_331, 2); lean_inc(x_332); -x_333 = lean_ctor_get(x_321, 1); +x_333 = lean_ctor_get(x_328, 0); lean_inc(x_333); -x_334 = lean_ctor_get(x_321, 3); +lean_dec(x_328); +x_334 = lean_ctor_get(x_329, 1); lean_inc(x_334); -x_335 = lean_ctor_get(x_321, 4); -lean_inc(x_335); -x_336 = lean_ctor_get(x_321, 5); -lean_inc(x_336); -if (lean_is_exclusive(x_321)) { - lean_ctor_release(x_321, 0); - lean_ctor_release(x_321, 1); - lean_ctor_release(x_321, 2); - lean_ctor_release(x_321, 3); - lean_ctor_release(x_321, 4); - lean_ctor_release(x_321, 5); - x_337 = x_321; +if (lean_is_exclusive(x_329)) { + lean_ctor_release(x_329, 0); + lean_ctor_release(x_329, 1); + x_335 = x_329; } else { - lean_dec_ref(x_321); - x_337 = lean_box(0); + lean_dec_ref(x_329); + x_335 = lean_box(0); } -x_338 = lean_ctor_get(x_322, 0); +x_336 = lean_ctor_get(x_330, 1); +lean_inc(x_336); +x_337 = lean_ctor_get(x_330, 2); +lean_inc(x_337); +x_338 = lean_ctor_get(x_330, 3); lean_inc(x_338); -x_339 = lean_ctor_get(x_322, 1); +x_339 = lean_ctor_get(x_330, 4); lean_inc(x_339); -x_340 = lean_ctor_get(x_322, 3); +x_340 = lean_ctor_get(x_330, 5); lean_inc(x_340); -if (lean_is_exclusive(x_322)) { - lean_ctor_release(x_322, 0); - lean_ctor_release(x_322, 1); - lean_ctor_release(x_322, 2); - lean_ctor_release(x_322, 3); - x_341 = x_322; +if (lean_is_exclusive(x_330)) { + lean_ctor_release(x_330, 0); + lean_ctor_release(x_330, 1); + lean_ctor_release(x_330, 2); + lean_ctor_release(x_330, 3); + lean_ctor_release(x_330, 4); + lean_ctor_release(x_330, 5); + x_341 = x_330; } else { - lean_dec_ref(x_322); + lean_dec_ref(x_330); x_341 = lean_box(0); } +x_342 = lean_ctor_get(x_331, 0); +lean_inc(x_342); +x_343 = lean_ctor_get(x_331, 1); +lean_inc(x_343); +x_344 = lean_ctor_get(x_331, 3); +lean_inc(x_344); +x_345 = lean_ctor_get(x_331, 4); +lean_inc(x_345); +x_346 = lean_ctor_get(x_331, 5); +lean_inc(x_346); +if (lean_is_exclusive(x_331)) { + lean_ctor_release(x_331, 0); + lean_ctor_release(x_331, 1); + lean_ctor_release(x_331, 2); + lean_ctor_release(x_331, 3); + lean_ctor_release(x_331, 4); + lean_ctor_release(x_331, 5); + x_347 = x_331; +} else { + lean_dec_ref(x_331); + x_347 = lean_box(0); +} +x_348 = lean_ctor_get(x_332, 0); +lean_inc(x_348); +x_349 = lean_ctor_get(x_332, 1); +lean_inc(x_349); +x_350 = lean_ctor_get(x_332, 3); +lean_inc(x_350); +x_351 = lean_ctor_get(x_332, 4); +lean_inc(x_351); +if (lean_is_exclusive(x_332)) { + lean_ctor_release(x_332, 0); + lean_ctor_release(x_332, 1); + lean_ctor_release(x_332, 2); + lean_ctor_release(x_332, 3); + lean_ctor_release(x_332, 4); + x_352 = x_332; +} else { + lean_dec_ref(x_332); + x_352 = lean_box(0); +} +if (lean_is_scalar(x_352)) { + x_353 = lean_alloc_ctor(0, 5, 0); +} else { + x_353 = x_352; +} +lean_ctor_set(x_353, 0, x_348); +lean_ctor_set(x_353, 1, x_349); +lean_ctor_set(x_353, 2, x_327); +lean_ctor_set(x_353, 3, x_350); +lean_ctor_set(x_353, 4, x_351); +if (lean_is_scalar(x_347)) { + x_354 = lean_alloc_ctor(0, 6, 0); +} else { + x_354 = x_347; +} +lean_ctor_set(x_354, 0, x_342); +lean_ctor_set(x_354, 1, x_343); +lean_ctor_set(x_354, 2, x_353); +lean_ctor_set(x_354, 3, x_344); +lean_ctor_set(x_354, 4, x_345); +lean_ctor_set(x_354, 5, x_346); if (lean_is_scalar(x_341)) { - x_342 = lean_alloc_ctor(0, 4, 0); + x_355 = lean_alloc_ctor(0, 6, 0); } else { - x_342 = x_341; + x_355 = x_341; } -lean_ctor_set(x_342, 0, x_338); -lean_ctor_set(x_342, 1, x_339); -lean_ctor_set(x_342, 2, x_317); -lean_ctor_set(x_342, 3, x_340); -if (lean_is_scalar(x_337)) { - x_343 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_355, 0, x_354); +lean_ctor_set(x_355, 1, x_336); +lean_ctor_set(x_355, 2, x_337); +lean_ctor_set(x_355, 3, x_338); +lean_ctor_set(x_355, 4, x_339); +lean_ctor_set(x_355, 5, x_340); +if (lean_is_scalar(x_335)) { + x_356 = lean_alloc_ctor(0, 2, 0); } else { - x_343 = x_337; + x_356 = x_335; } -lean_ctor_set(x_343, 0, x_332); -lean_ctor_set(x_343, 1, x_333); -lean_ctor_set(x_343, 2, x_342); -lean_ctor_set(x_343, 3, x_334); -lean_ctor_set(x_343, 4, x_335); -lean_ctor_set(x_343, 5, x_336); -if (lean_is_scalar(x_331)) { - x_344 = lean_alloc_ctor(0, 6, 0); -} else { - x_344 = x_331; -} -lean_ctor_set(x_344, 0, x_343); -lean_ctor_set(x_344, 1, x_326); -lean_ctor_set(x_344, 2, x_327); -lean_ctor_set(x_344, 3, x_328); -lean_ctor_set(x_344, 4, x_329); -lean_ctor_set(x_344, 5, x_330); -if (lean_is_scalar(x_325)) { - x_345 = lean_alloc_ctor(0, 2, 0); -} else { - x_345 = x_325; -} -lean_ctor_set(x_345, 0, x_344); -lean_ctor_set(x_345, 1, x_324); +lean_ctor_set(x_356, 0, x_355); +lean_ctor_set(x_356, 1, x_334); if (lean_is_scalar(x_10)) { - x_346 = lean_alloc_ctor(1, 2, 0); + x_357 = lean_alloc_ctor(1, 2, 0); } else { - x_346 = x_10; - lean_ctor_set_tag(x_346, 1); + x_357 = x_10; + lean_ctor_set_tag(x_357, 1); } -lean_ctor_set(x_346, 0, x_323); -lean_ctor_set(x_346, 1, x_345); -return x_346; +lean_ctor_set(x_357, 0, x_333); +lean_ctor_set(x_357, 1, x_356); +return x_357; } else { -lean_object* x_347; lean_object* x_348; lean_object* x_349; lean_object* x_350; lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; 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_347 = lean_ctor_get(x_319, 0); -lean_inc(x_347); -x_348 = lean_ctor_get(x_347, 0); -lean_inc(x_348); -x_349 = lean_ctor_get(x_348, 2); -lean_inc(x_349); -x_350 = lean_ctor_get(x_318, 0); -lean_inc(x_350); -lean_dec(x_318); -x_351 = lean_ctor_get(x_319, 1); -lean_inc(x_351); -if (lean_is_exclusive(x_319)) { - lean_ctor_release(x_319, 0); - lean_ctor_release(x_319, 1); - x_352 = x_319; -} else { - lean_dec_ref(x_319); - x_352 = lean_box(0); -} -x_353 = lean_ctor_get(x_347, 1); -lean_inc(x_353); -x_354 = lean_ctor_get(x_347, 2); -lean_inc(x_354); -x_355 = lean_ctor_get(x_347, 3); -lean_inc(x_355); -x_356 = lean_ctor_get(x_347, 4); -lean_inc(x_356); -x_357 = lean_ctor_get(x_347, 5); -lean_inc(x_357); -if (lean_is_exclusive(x_347)) { - lean_ctor_release(x_347, 0); - lean_ctor_release(x_347, 1); - lean_ctor_release(x_347, 2); - lean_ctor_release(x_347, 3); - lean_ctor_release(x_347, 4); - lean_ctor_release(x_347, 5); - x_358 = x_347; -} else { - lean_dec_ref(x_347); - x_358 = lean_box(0); -} -x_359 = lean_ctor_get(x_348, 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; lean_object* x_374; lean_object* x_375; 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; +x_358 = lean_ctor_get(x_329, 0); +lean_inc(x_358); +x_359 = lean_ctor_get(x_358, 0); lean_inc(x_359); -x_360 = lean_ctor_get(x_348, 1); +x_360 = lean_ctor_get(x_359, 2); lean_inc(x_360); -x_361 = lean_ctor_get(x_348, 3); +x_361 = lean_ctor_get(x_328, 0); lean_inc(x_361); -x_362 = lean_ctor_get(x_348, 4); +lean_dec(x_328); +x_362 = lean_ctor_get(x_329, 1); lean_inc(x_362); -x_363 = lean_ctor_get(x_348, 5); -lean_inc(x_363); -if (lean_is_exclusive(x_348)) { - lean_ctor_release(x_348, 0); - lean_ctor_release(x_348, 1); - lean_ctor_release(x_348, 2); - lean_ctor_release(x_348, 3); - lean_ctor_release(x_348, 4); - lean_ctor_release(x_348, 5); - x_364 = x_348; +if (lean_is_exclusive(x_329)) { + lean_ctor_release(x_329, 0); + lean_ctor_release(x_329, 1); + x_363 = x_329; } else { - lean_dec_ref(x_348); - x_364 = lean_box(0); + lean_dec_ref(x_329); + x_363 = lean_box(0); } -x_365 = lean_ctor_get(x_349, 0); +x_364 = lean_ctor_get(x_358, 1); +lean_inc(x_364); +x_365 = lean_ctor_get(x_358, 2); lean_inc(x_365); -x_366 = lean_ctor_get(x_349, 1); +x_366 = lean_ctor_get(x_358, 3); lean_inc(x_366); -x_367 = lean_ctor_get(x_349, 3); +x_367 = lean_ctor_get(x_358, 4); lean_inc(x_367); -if (lean_is_exclusive(x_349)) { - lean_ctor_release(x_349, 0); - lean_ctor_release(x_349, 1); - lean_ctor_release(x_349, 2); - lean_ctor_release(x_349, 3); - x_368 = x_349; +x_368 = lean_ctor_get(x_358, 5); +lean_inc(x_368); +if (lean_is_exclusive(x_358)) { + lean_ctor_release(x_358, 0); + lean_ctor_release(x_358, 1); + lean_ctor_release(x_358, 2); + lean_ctor_release(x_358, 3); + lean_ctor_release(x_358, 4); + lean_ctor_release(x_358, 5); + x_369 = x_358; } else { - lean_dec_ref(x_349); - x_368 = lean_box(0); + lean_dec_ref(x_358); + x_369 = lean_box(0); } -if (lean_is_scalar(x_368)) { - x_369 = lean_alloc_ctor(0, 4, 0); +x_370 = lean_ctor_get(x_359, 0); +lean_inc(x_370); +x_371 = lean_ctor_get(x_359, 1); +lean_inc(x_371); +x_372 = lean_ctor_get(x_359, 3); +lean_inc(x_372); +x_373 = lean_ctor_get(x_359, 4); +lean_inc(x_373); +x_374 = lean_ctor_get(x_359, 5); +lean_inc(x_374); +if (lean_is_exclusive(x_359)) { + lean_ctor_release(x_359, 0); + lean_ctor_release(x_359, 1); + lean_ctor_release(x_359, 2); + lean_ctor_release(x_359, 3); + lean_ctor_release(x_359, 4); + lean_ctor_release(x_359, 5); + x_375 = x_359; } else { - x_369 = x_368; + lean_dec_ref(x_359); + x_375 = lean_box(0); } -lean_ctor_set(x_369, 0, x_365); -lean_ctor_set(x_369, 1, x_366); -lean_ctor_set(x_369, 2, x_317); -lean_ctor_set(x_369, 3, x_367); -if (lean_is_scalar(x_364)) { - x_370 = lean_alloc_ctor(0, 6, 0); +x_376 = lean_ctor_get(x_360, 0); +lean_inc(x_376); +x_377 = lean_ctor_get(x_360, 1); +lean_inc(x_377); +x_378 = lean_ctor_get(x_360, 3); +lean_inc(x_378); +x_379 = lean_ctor_get(x_360, 4); +lean_inc(x_379); +if (lean_is_exclusive(x_360)) { + lean_ctor_release(x_360, 0); + lean_ctor_release(x_360, 1); + lean_ctor_release(x_360, 2); + lean_ctor_release(x_360, 3); + lean_ctor_release(x_360, 4); + x_380 = x_360; } else { - x_370 = x_364; + lean_dec_ref(x_360); + x_380 = lean_box(0); } -lean_ctor_set(x_370, 0, x_359); -lean_ctor_set(x_370, 1, x_360); -lean_ctor_set(x_370, 2, x_369); -lean_ctor_set(x_370, 3, x_361); -lean_ctor_set(x_370, 4, x_362); -lean_ctor_set(x_370, 5, x_363); -if (lean_is_scalar(x_358)) { - x_371 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_380)) { + x_381 = lean_alloc_ctor(0, 5, 0); } else { - x_371 = x_358; + x_381 = x_380; } -lean_ctor_set(x_371, 0, x_370); -lean_ctor_set(x_371, 1, x_353); -lean_ctor_set(x_371, 2, x_354); -lean_ctor_set(x_371, 3, x_355); -lean_ctor_set(x_371, 4, x_356); -lean_ctor_set(x_371, 5, x_357); -if (lean_is_scalar(x_352)) { - x_372 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_381, 0, x_376); +lean_ctor_set(x_381, 1, x_377); +lean_ctor_set(x_381, 2, x_327); +lean_ctor_set(x_381, 3, x_378); +lean_ctor_set(x_381, 4, x_379); +if (lean_is_scalar(x_375)) { + x_382 = lean_alloc_ctor(0, 6, 0); } else { - x_372 = x_352; + x_382 = x_375; } -lean_ctor_set(x_372, 0, x_371); -lean_ctor_set(x_372, 1, x_351); +lean_ctor_set(x_382, 0, x_370); +lean_ctor_set(x_382, 1, x_371); +lean_ctor_set(x_382, 2, x_381); +lean_ctor_set(x_382, 3, x_372); +lean_ctor_set(x_382, 4, x_373); +lean_ctor_set(x_382, 5, x_374); +if (lean_is_scalar(x_369)) { + x_383 = lean_alloc_ctor(0, 6, 0); +} else { + x_383 = x_369; +} +lean_ctor_set(x_383, 0, x_382); +lean_ctor_set(x_383, 1, x_364); +lean_ctor_set(x_383, 2, x_365); +lean_ctor_set(x_383, 3, x_366); +lean_ctor_set(x_383, 4, x_367); +lean_ctor_set(x_383, 5, x_368); +if (lean_is_scalar(x_363)) { + x_384 = lean_alloc_ctor(0, 2, 0); +} else { + x_384 = x_363; +} +lean_ctor_set(x_384, 0, x_383); +lean_ctor_set(x_384, 1, x_362); if (lean_is_scalar(x_10)) { - x_373 = lean_alloc_ctor(0, 2, 0); + x_385 = lean_alloc_ctor(0, 2, 0); } else { - x_373 = x_10; + x_385 = x_10; } -lean_ctor_set(x_373, 0, x_350); -lean_ctor_set(x_373, 1, x_372); -return x_373; +lean_ctor_set(x_385, 0, x_361); +lean_ctor_set(x_385, 1, x_384); +return x_385; } } } diff --git a/stage0/stdlib/Lean/Elab/Term.c b/stage0/stdlib/Lean/Elab/Term.c index 574fc73018..3f2671365a 100644 --- a/stage0/stdlib/Lean/Elab/Term.c +++ b/stage0/stdlib/Lean/Elab/Term.c @@ -22144,107 +22144,114 @@ return x_12; } else { -lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; +lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; x_13 = lean_ctor_get(x_3, 0); x_14 = lean_ctor_get(x_3, 1); x_15 = lean_ctor_get(x_3, 3); +x_16 = lean_ctor_get(x_3, 4); +lean_inc(x_16); lean_inc(x_15); lean_inc(x_14); lean_inc(x_13); lean_dec(x_3); -x_16 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_17 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_17, 0, x_13); -lean_ctor_set(x_17, 1, x_14); -lean_ctor_set(x_17, 2, x_16); -lean_ctor_set(x_17, 3, x_15); -lean_ctor_set(x_2, 2, x_17); -x_18 = lean_box(0); -x_19 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_19, 0, x_18); -lean_ctor_set(x_19, 1, x_1); -return x_19; +x_17 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_18 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_18, 0, x_13); +lean_ctor_set(x_18, 1, x_14); +lean_ctor_set(x_18, 2, x_17); +lean_ctor_set(x_18, 3, x_15); +lean_ctor_set(x_18, 4, x_16); +lean_ctor_set(x_2, 2, x_18); +x_19 = lean_box(0); +x_20 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_20, 0, x_19); +lean_ctor_set(x_20, 1, x_1); +return x_20; } } else { -lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; -x_20 = lean_ctor_get(x_2, 0); -x_21 = lean_ctor_get(x_2, 1); -x_22 = lean_ctor_get(x_2, 3); -x_23 = lean_ctor_get(x_2, 4); -x_24 = lean_ctor_get(x_2, 5); +lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; +x_21 = lean_ctor_get(x_2, 0); +x_22 = lean_ctor_get(x_2, 1); +x_23 = lean_ctor_get(x_2, 3); +x_24 = lean_ctor_get(x_2, 4); +x_25 = lean_ctor_get(x_2, 5); +lean_inc(x_25); lean_inc(x_24); lean_inc(x_23); lean_inc(x_22); lean_inc(x_21); -lean_inc(x_20); lean_dec(x_2); -x_25 = lean_ctor_get(x_3, 0); -lean_inc(x_25); -x_26 = lean_ctor_get(x_3, 1); +x_26 = lean_ctor_get(x_3, 0); lean_inc(x_26); -x_27 = lean_ctor_get(x_3, 3); +x_27 = lean_ctor_get(x_3, 1); lean_inc(x_27); +x_28 = lean_ctor_get(x_3, 3); +lean_inc(x_28); +x_29 = lean_ctor_get(x_3, 4); +lean_inc(x_29); if (lean_is_exclusive(x_3)) { lean_ctor_release(x_3, 0); lean_ctor_release(x_3, 1); lean_ctor_release(x_3, 2); lean_ctor_release(x_3, 3); - x_28 = x_3; + lean_ctor_release(x_3, 4); + x_30 = x_3; } else { lean_dec_ref(x_3); - x_28 = lean_box(0); + x_30 = lean_box(0); } -x_29 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_28)) { - x_30 = lean_alloc_ctor(0, 4, 0); +x_31 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_30)) { + x_32 = lean_alloc_ctor(0, 5, 0); } else { - x_30 = x_28; + x_32 = x_30; } -lean_ctor_set(x_30, 0, x_25); -lean_ctor_set(x_30, 1, x_26); -lean_ctor_set(x_30, 2, x_29); -lean_ctor_set(x_30, 3, x_27); -x_31 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_31, 0, x_20); -lean_ctor_set(x_31, 1, x_21); -lean_ctor_set(x_31, 2, x_30); -lean_ctor_set(x_31, 3, x_22); -lean_ctor_set(x_31, 4, x_23); -lean_ctor_set(x_31, 5, x_24); -lean_ctor_set(x_1, 0, x_31); -x_32 = lean_box(0); -x_33 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_33, 0, x_32); -lean_ctor_set(x_33, 1, x_1); -return x_33; +lean_ctor_set(x_32, 0, x_26); +lean_ctor_set(x_32, 1, x_27); +lean_ctor_set(x_32, 2, x_31); +lean_ctor_set(x_32, 3, x_28); +lean_ctor_set(x_32, 4, x_29); +x_33 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_33, 0, x_21); +lean_ctor_set(x_33, 1, x_22); +lean_ctor_set(x_33, 2, x_32); +lean_ctor_set(x_33, 3, x_23); +lean_ctor_set(x_33, 4, x_24); +lean_ctor_set(x_33, 5, x_25); +lean_ctor_set(x_1, 0, x_33); +x_34 = lean_box(0); +x_35 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_35, 0, x_34); +lean_ctor_set(x_35, 1, x_1); +return x_35; } } else { -lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; -x_34 = lean_ctor_get(x_1, 1); -x_35 = lean_ctor_get(x_1, 2); -x_36 = lean_ctor_get(x_1, 3); -x_37 = lean_ctor_get(x_1, 4); -x_38 = lean_ctor_get(x_1, 5); +lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; +x_36 = lean_ctor_get(x_1, 1); +x_37 = lean_ctor_get(x_1, 2); +x_38 = lean_ctor_get(x_1, 3); +x_39 = lean_ctor_get(x_1, 4); +x_40 = lean_ctor_get(x_1, 5); +lean_inc(x_40); +lean_inc(x_39); lean_inc(x_38); lean_inc(x_37); lean_inc(x_36); -lean_inc(x_35); -lean_inc(x_34); lean_dec(x_1); -x_39 = lean_ctor_get(x_2, 0); -lean_inc(x_39); -x_40 = lean_ctor_get(x_2, 1); -lean_inc(x_40); -x_41 = lean_ctor_get(x_2, 3); +x_41 = lean_ctor_get(x_2, 0); lean_inc(x_41); -x_42 = lean_ctor_get(x_2, 4); +x_42 = lean_ctor_get(x_2, 1); lean_inc(x_42); -x_43 = lean_ctor_get(x_2, 5); +x_43 = lean_ctor_get(x_2, 3); lean_inc(x_43); +x_44 = lean_ctor_get(x_2, 4); +lean_inc(x_44); +x_45 = lean_ctor_get(x_2, 5); +lean_inc(x_45); if (lean_is_exclusive(x_2)) { lean_ctor_release(x_2, 0); lean_ctor_release(x_2, 1); @@ -22252,60 +22259,64 @@ if (lean_is_exclusive(x_2)) { lean_ctor_release(x_2, 3); lean_ctor_release(x_2, 4); lean_ctor_release(x_2, 5); - x_44 = x_2; + x_46 = x_2; } else { lean_dec_ref(x_2); - x_44 = lean_box(0); + x_46 = lean_box(0); } -x_45 = lean_ctor_get(x_3, 0); -lean_inc(x_45); -x_46 = lean_ctor_get(x_3, 1); -lean_inc(x_46); -x_47 = lean_ctor_get(x_3, 3); +x_47 = lean_ctor_get(x_3, 0); lean_inc(x_47); +x_48 = lean_ctor_get(x_3, 1); +lean_inc(x_48); +x_49 = lean_ctor_get(x_3, 3); +lean_inc(x_49); +x_50 = lean_ctor_get(x_3, 4); +lean_inc(x_50); if (lean_is_exclusive(x_3)) { lean_ctor_release(x_3, 0); lean_ctor_release(x_3, 1); lean_ctor_release(x_3, 2); lean_ctor_release(x_3, 3); - x_48 = x_3; + lean_ctor_release(x_3, 4); + x_51 = x_3; } else { lean_dec_ref(x_3); - x_48 = lean_box(0); + x_51 = lean_box(0); } -x_49 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_48)) { - x_50 = lean_alloc_ctor(0, 4, 0); +x_52 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_51)) { + x_53 = lean_alloc_ctor(0, 5, 0); } else { - x_50 = x_48; + x_53 = x_51; } -lean_ctor_set(x_50, 0, x_45); -lean_ctor_set(x_50, 1, x_46); -lean_ctor_set(x_50, 2, x_49); -lean_ctor_set(x_50, 3, x_47); -if (lean_is_scalar(x_44)) { - x_51 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_53, 0, x_47); +lean_ctor_set(x_53, 1, x_48); +lean_ctor_set(x_53, 2, x_52); +lean_ctor_set(x_53, 3, x_49); +lean_ctor_set(x_53, 4, x_50); +if (lean_is_scalar(x_46)) { + x_54 = lean_alloc_ctor(0, 6, 0); } else { - x_51 = x_44; + x_54 = x_46; } -lean_ctor_set(x_51, 0, x_39); -lean_ctor_set(x_51, 1, x_40); -lean_ctor_set(x_51, 2, x_50); -lean_ctor_set(x_51, 3, x_41); -lean_ctor_set(x_51, 4, x_42); -lean_ctor_set(x_51, 5, x_43); -x_52 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_52, 0, x_51); -lean_ctor_set(x_52, 1, x_34); -lean_ctor_set(x_52, 2, x_35); -lean_ctor_set(x_52, 3, x_36); -lean_ctor_set(x_52, 4, x_37); -lean_ctor_set(x_52, 5, x_38); -x_53 = lean_box(0); -x_54 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_54, 0, x_53); -lean_ctor_set(x_54, 1, x_52); -return x_54; +lean_ctor_set(x_54, 0, x_41); +lean_ctor_set(x_54, 1, x_42); +lean_ctor_set(x_54, 2, x_53); +lean_ctor_set(x_54, 3, x_43); +lean_ctor_set(x_54, 4, x_44); +lean_ctor_set(x_54, 5, x_45); +x_55 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_55, 0, x_54); +lean_ctor_set(x_55, 1, x_36); +lean_ctor_set(x_55, 2, x_37); +lean_ctor_set(x_55, 3, x_38); +lean_ctor_set(x_55, 4, x_39); +lean_ctor_set(x_55, 5, x_40); +x_56 = lean_box(0); +x_57 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_57, 0, x_56); +lean_ctor_set(x_57, 1, x_55); +return x_57; } } } @@ -22329,7 +22340,7 @@ return x_2; lean_object* l_Lean_Elab_Term_resettingSynthInstanceCache___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { -lean_object* x_4; lean_object* x_5; lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_102; lean_object* x_103; lean_object* x_104; +lean_object* x_4; lean_object* x_5; lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_108; lean_object* x_109; lean_object* x_110; x_4 = lean_ctor_get(x_3, 0); lean_inc(x_4); x_5 = lean_ctor_get(x_4, 2); @@ -22338,40 +22349,40 @@ lean_dec(x_4); x_6 = lean_ctor_get(x_5, 2); lean_inc(x_6); lean_dec(x_5); -x_102 = l_Lean_Elab_Term_resetSynthInstanceCache___rarg(x_3); -x_103 = lean_ctor_get(x_102, 1); -lean_inc(x_103); -lean_dec(x_102); -x_104 = lean_apply_2(x_1, x_2, x_103); -if (lean_obj_tag(x_104) == 0) +x_108 = l_Lean_Elab_Term_resetSynthInstanceCache___rarg(x_3); +x_109 = lean_ctor_get(x_108, 1); +lean_inc(x_109); +lean_dec(x_108); +x_110 = lean_apply_2(x_1, x_2, x_109); +if (lean_obj_tag(x_110) == 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); -x_107 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_107, 0, x_105); -x_7 = x_107; -x_8 = x_106; -goto block_101; +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); +x_113 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_113, 0, x_111); +x_7 = x_113; +x_8 = x_112; +goto block_107; } else { -lean_object* x_108; lean_object* x_109; lean_object* x_110; -x_108 = lean_ctor_get(x_104, 0); -lean_inc(x_108); -x_109 = lean_ctor_get(x_104, 1); -lean_inc(x_109); -lean_dec(x_104); -x_110 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_110, 0, x_108); -x_7 = x_110; -x_8 = x_109; -goto block_101; +lean_object* x_114; lean_object* x_115; lean_object* x_116; +x_114 = lean_ctor_get(x_110, 0); +lean_inc(x_114); +x_115 = lean_ctor_get(x_110, 1); +lean_inc(x_115); +lean_dec(x_110); +x_116 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_116, 0, x_114); +x_7 = x_116; +x_8 = x_115; +goto block_107; } -block_101: +block_107: { if (lean_obj_tag(x_7) == 0) { @@ -22409,103 +22420,110 @@ return x_18; } else { -lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; +lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; x_19 = lean_ctor_get(x_10, 0); x_20 = lean_ctor_get(x_10, 1); x_21 = lean_ctor_get(x_10, 3); +x_22 = lean_ctor_get(x_10, 4); +lean_inc(x_22); lean_inc(x_21); lean_inc(x_20); lean_inc(x_19); lean_dec(x_10); -x_22 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_22, 0, x_19); -lean_ctor_set(x_22, 1, x_20); -lean_ctor_set(x_22, 2, x_6); -lean_ctor_set(x_22, 3, x_21); -lean_ctor_set(x_9, 2, x_22); -x_23 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_23, 0, x_11); -lean_ctor_set(x_23, 1, x_8); -return x_23; +x_23 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_23, 0, x_19); +lean_ctor_set(x_23, 1, x_20); +lean_ctor_set(x_23, 2, x_6); +lean_ctor_set(x_23, 3, x_21); +lean_ctor_set(x_23, 4, x_22); +lean_ctor_set(x_9, 2, x_23); +x_24 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_24, 0, x_11); +lean_ctor_set(x_24, 1, x_8); +return x_24; } } else { -lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; -x_24 = lean_ctor_get(x_9, 0); -x_25 = lean_ctor_get(x_9, 1); -x_26 = lean_ctor_get(x_9, 3); -x_27 = lean_ctor_get(x_9, 4); -x_28 = lean_ctor_get(x_9, 5); +lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; +x_25 = lean_ctor_get(x_9, 0); +x_26 = lean_ctor_get(x_9, 1); +x_27 = lean_ctor_get(x_9, 3); +x_28 = lean_ctor_get(x_9, 4); +x_29 = lean_ctor_get(x_9, 5); +lean_inc(x_29); lean_inc(x_28); lean_inc(x_27); lean_inc(x_26); lean_inc(x_25); -lean_inc(x_24); lean_dec(x_9); -x_29 = lean_ctor_get(x_10, 0); -lean_inc(x_29); -x_30 = lean_ctor_get(x_10, 1); +x_30 = lean_ctor_get(x_10, 0); lean_inc(x_30); -x_31 = lean_ctor_get(x_10, 3); +x_31 = lean_ctor_get(x_10, 1); lean_inc(x_31); +x_32 = lean_ctor_get(x_10, 3); +lean_inc(x_32); +x_33 = lean_ctor_get(x_10, 4); +lean_inc(x_33); if (lean_is_exclusive(x_10)) { lean_ctor_release(x_10, 0); lean_ctor_release(x_10, 1); lean_ctor_release(x_10, 2); lean_ctor_release(x_10, 3); - x_32 = x_10; + lean_ctor_release(x_10, 4); + x_34 = x_10; } else { lean_dec_ref(x_10); - x_32 = lean_box(0); + x_34 = lean_box(0); } -if (lean_is_scalar(x_32)) { - x_33 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_34)) { + x_35 = lean_alloc_ctor(0, 5, 0); } else { - x_33 = x_32; + x_35 = x_34; } -lean_ctor_set(x_33, 0, x_29); -lean_ctor_set(x_33, 1, x_30); -lean_ctor_set(x_33, 2, x_6); -lean_ctor_set(x_33, 3, x_31); -x_34 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_34, 0, x_24); -lean_ctor_set(x_34, 1, x_25); -lean_ctor_set(x_34, 2, x_33); -lean_ctor_set(x_34, 3, x_26); -lean_ctor_set(x_34, 4, x_27); -lean_ctor_set(x_34, 5, x_28); -lean_ctor_set(x_8, 0, x_34); -x_35 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_35, 0, x_11); -lean_ctor_set(x_35, 1, x_8); -return x_35; +lean_ctor_set(x_35, 0, x_30); +lean_ctor_set(x_35, 1, x_31); +lean_ctor_set(x_35, 2, x_6); +lean_ctor_set(x_35, 3, x_32); +lean_ctor_set(x_35, 4, x_33); +x_36 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_36, 0, x_25); +lean_ctor_set(x_36, 1, x_26); +lean_ctor_set(x_36, 2, x_35); +lean_ctor_set(x_36, 3, x_27); +lean_ctor_set(x_36, 4, x_28); +lean_ctor_set(x_36, 5, x_29); +lean_ctor_set(x_8, 0, x_36); +x_37 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_37, 0, x_11); +lean_ctor_set(x_37, 1, x_8); +return x_37; } } else { -lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; 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; -x_36 = lean_ctor_get(x_8, 1); -x_37 = lean_ctor_get(x_8, 2); -x_38 = lean_ctor_get(x_8, 3); -x_39 = lean_ctor_get(x_8, 4); -x_40 = lean_ctor_get(x_8, 5); +lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; +x_38 = lean_ctor_get(x_8, 1); +x_39 = lean_ctor_get(x_8, 2); +x_40 = lean_ctor_get(x_8, 3); +x_41 = lean_ctor_get(x_8, 4); +x_42 = lean_ctor_get(x_8, 5); +lean_inc(x_42); +lean_inc(x_41); lean_inc(x_40); lean_inc(x_39); lean_inc(x_38); -lean_inc(x_37); -lean_inc(x_36); lean_dec(x_8); -x_41 = lean_ctor_get(x_9, 0); -lean_inc(x_41); -x_42 = lean_ctor_get(x_9, 1); -lean_inc(x_42); -x_43 = lean_ctor_get(x_9, 3); +x_43 = lean_ctor_get(x_9, 0); lean_inc(x_43); -x_44 = lean_ctor_get(x_9, 4); +x_44 = lean_ctor_get(x_9, 1); lean_inc(x_44); -x_45 = lean_ctor_get(x_9, 5); +x_45 = lean_ctor_get(x_9, 3); lean_inc(x_45); +x_46 = lean_ctor_get(x_9, 4); +lean_inc(x_46); +x_47 = lean_ctor_get(x_9, 5); +lean_inc(x_47); if (lean_is_exclusive(x_9)) { lean_ctor_release(x_9, 0); lean_ctor_release(x_9, 1); @@ -22513,252 +22531,267 @@ if (lean_is_exclusive(x_9)) { lean_ctor_release(x_9, 3); lean_ctor_release(x_9, 4); lean_ctor_release(x_9, 5); - x_46 = x_9; + x_48 = x_9; } else { lean_dec_ref(x_9); - x_46 = lean_box(0); + x_48 = lean_box(0); } -x_47 = lean_ctor_get(x_10, 0); -lean_inc(x_47); -x_48 = lean_ctor_get(x_10, 1); -lean_inc(x_48); -x_49 = lean_ctor_get(x_10, 3); +x_49 = lean_ctor_get(x_10, 0); lean_inc(x_49); +x_50 = lean_ctor_get(x_10, 1); +lean_inc(x_50); +x_51 = lean_ctor_get(x_10, 3); +lean_inc(x_51); +x_52 = lean_ctor_get(x_10, 4); +lean_inc(x_52); if (lean_is_exclusive(x_10)) { lean_ctor_release(x_10, 0); lean_ctor_release(x_10, 1); lean_ctor_release(x_10, 2); lean_ctor_release(x_10, 3); - x_50 = x_10; + lean_ctor_release(x_10, 4); + x_53 = x_10; } else { lean_dec_ref(x_10); - x_50 = lean_box(0); + x_53 = lean_box(0); } -if (lean_is_scalar(x_50)) { - x_51 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_53)) { + x_54 = lean_alloc_ctor(0, 5, 0); } else { - x_51 = x_50; + x_54 = x_53; } -lean_ctor_set(x_51, 0, x_47); -lean_ctor_set(x_51, 1, x_48); -lean_ctor_set(x_51, 2, x_6); -lean_ctor_set(x_51, 3, x_49); -if (lean_is_scalar(x_46)) { - x_52 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_54, 0, x_49); +lean_ctor_set(x_54, 1, x_50); +lean_ctor_set(x_54, 2, x_6); +lean_ctor_set(x_54, 3, x_51); +lean_ctor_set(x_54, 4, x_52); +if (lean_is_scalar(x_48)) { + x_55 = lean_alloc_ctor(0, 6, 0); } else { - x_52 = x_46; + x_55 = x_48; } -lean_ctor_set(x_52, 0, x_41); -lean_ctor_set(x_52, 1, x_42); -lean_ctor_set(x_52, 2, x_51); -lean_ctor_set(x_52, 3, x_43); -lean_ctor_set(x_52, 4, x_44); -lean_ctor_set(x_52, 5, x_45); -x_53 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_53, 0, x_52); -lean_ctor_set(x_53, 1, x_36); -lean_ctor_set(x_53, 2, x_37); -lean_ctor_set(x_53, 3, x_38); -lean_ctor_set(x_53, 4, x_39); -lean_ctor_set(x_53, 5, x_40); -x_54 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_54, 0, x_11); -lean_ctor_set(x_54, 1, x_53); -return x_54; +lean_ctor_set(x_55, 0, x_43); +lean_ctor_set(x_55, 1, x_44); +lean_ctor_set(x_55, 2, x_54); +lean_ctor_set(x_55, 3, x_45); +lean_ctor_set(x_55, 4, x_46); +lean_ctor_set(x_55, 5, x_47); +x_56 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_56, 0, x_55); +lean_ctor_set(x_56, 1, x_38); +lean_ctor_set(x_56, 2, x_39); +lean_ctor_set(x_56, 3, x_40); +lean_ctor_set(x_56, 4, x_41); +lean_ctor_set(x_56, 5, x_42); +x_57 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_57, 0, x_11); +lean_ctor_set(x_57, 1, x_56); +return x_57; } } else { -lean_object* x_55; lean_object* x_56; lean_object* x_57; uint8_t x_58; -x_55 = lean_ctor_get(x_8, 0); -lean_inc(x_55); -x_56 = lean_ctor_get(x_55, 2); -lean_inc(x_56); -x_57 = lean_ctor_get(x_7, 0); -lean_inc(x_57); +lean_object* x_58; lean_object* x_59; lean_object* x_60; uint8_t x_61; +x_58 = lean_ctor_get(x_8, 0); +lean_inc(x_58); +x_59 = lean_ctor_get(x_58, 2); +lean_inc(x_59); +x_60 = lean_ctor_get(x_7, 0); +lean_inc(x_60); lean_dec(x_7); -x_58 = !lean_is_exclusive(x_8); -if (x_58 == 0) +x_61 = !lean_is_exclusive(x_8); +if (x_61 == 0) { -lean_object* x_59; uint8_t x_60; -x_59 = lean_ctor_get(x_8, 0); -lean_dec(x_59); -x_60 = !lean_is_exclusive(x_55); -if (x_60 == 0) +lean_object* x_62; uint8_t x_63; +x_62 = lean_ctor_get(x_8, 0); +lean_dec(x_62); +x_63 = !lean_is_exclusive(x_58); +if (x_63 == 0) { -lean_object* x_61; uint8_t x_62; -x_61 = lean_ctor_get(x_55, 2); -lean_dec(x_61); -x_62 = !lean_is_exclusive(x_56); -if (x_62 == 0) +lean_object* x_64; uint8_t x_65; +x_64 = lean_ctor_get(x_58, 2); +lean_dec(x_64); +x_65 = !lean_is_exclusive(x_59); +if (x_65 == 0) { -lean_object* x_63; lean_object* x_64; -x_63 = lean_ctor_get(x_56, 2); -lean_dec(x_63); -lean_ctor_set(x_56, 2, x_6); -x_64 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_64, 0, x_57); -lean_ctor_set(x_64, 1, x_8); -return x_64; +lean_object* x_66; lean_object* x_67; +x_66 = lean_ctor_get(x_59, 2); +lean_dec(x_66); +lean_ctor_set(x_59, 2, x_6); +x_67 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_67, 0, x_60); +lean_ctor_set(x_67, 1, x_8); +return x_67; } else { -lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; -x_65 = lean_ctor_get(x_56, 0); -x_66 = lean_ctor_get(x_56, 1); -x_67 = lean_ctor_get(x_56, 3); -lean_inc(x_67); -lean_inc(x_66); -lean_inc(x_65); -lean_dec(x_56); -x_68 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_68, 0, x_65); -lean_ctor_set(x_68, 1, x_66); -lean_ctor_set(x_68, 2, x_6); -lean_ctor_set(x_68, 3, x_67); -lean_ctor_set(x_55, 2, x_68); -x_69 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_69, 0, x_57); -lean_ctor_set(x_69, 1, x_8); -return x_69; -} -} -else -{ -lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; -x_70 = lean_ctor_get(x_55, 0); -x_71 = lean_ctor_get(x_55, 1); -x_72 = lean_ctor_get(x_55, 3); -x_73 = lean_ctor_get(x_55, 4); -x_74 = lean_ctor_get(x_55, 5); -lean_inc(x_74); -lean_inc(x_73); -lean_inc(x_72); +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_68 = lean_ctor_get(x_59, 0); +x_69 = lean_ctor_get(x_59, 1); +x_70 = lean_ctor_get(x_59, 3); +x_71 = lean_ctor_get(x_59, 4); lean_inc(x_71); lean_inc(x_70); -lean_dec(x_55); -x_75 = lean_ctor_get(x_56, 0); -lean_inc(x_75); -x_76 = lean_ctor_get(x_56, 1); -lean_inc(x_76); -x_77 = lean_ctor_get(x_56, 3); -lean_inc(x_77); -if (lean_is_exclusive(x_56)) { - lean_ctor_release(x_56, 0); - lean_ctor_release(x_56, 1); - lean_ctor_release(x_56, 2); - lean_ctor_release(x_56, 3); - x_78 = x_56; -} else { - lean_dec_ref(x_56); - x_78 = lean_box(0); -} -if (lean_is_scalar(x_78)) { - x_79 = lean_alloc_ctor(0, 4, 0); -} else { - x_79 = x_78; -} -lean_ctor_set(x_79, 0, x_75); -lean_ctor_set(x_79, 1, x_76); -lean_ctor_set(x_79, 2, x_6); -lean_ctor_set(x_79, 3, x_77); -x_80 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_80, 0, x_70); -lean_ctor_set(x_80, 1, x_71); -lean_ctor_set(x_80, 2, x_79); -lean_ctor_set(x_80, 3, x_72); -lean_ctor_set(x_80, 4, x_73); -lean_ctor_set(x_80, 5, x_74); -lean_ctor_set(x_8, 0, x_80); -x_81 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_81, 0, x_57); -lean_ctor_set(x_81, 1, x_8); -return x_81; +lean_inc(x_69); +lean_inc(x_68); +lean_dec(x_59); +x_72 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_72, 0, x_68); +lean_ctor_set(x_72, 1, x_69); +lean_ctor_set(x_72, 2, x_6); +lean_ctor_set(x_72, 3, x_70); +lean_ctor_set(x_72, 4, x_71); +lean_ctor_set(x_58, 2, x_72); +x_73 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_73, 0, x_60); +lean_ctor_set(x_73, 1, x_8); +return x_73; } } else { -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; -x_82 = lean_ctor_get(x_8, 1); -x_83 = lean_ctor_get(x_8, 2); -x_84 = lean_ctor_get(x_8, 3); -x_85 = lean_ctor_get(x_8, 4); -x_86 = lean_ctor_get(x_8, 5); -lean_inc(x_86); -lean_inc(x_85); -lean_inc(x_84); -lean_inc(x_83); +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; +x_74 = lean_ctor_get(x_58, 0); +x_75 = lean_ctor_get(x_58, 1); +x_76 = lean_ctor_get(x_58, 3); +x_77 = lean_ctor_get(x_58, 4); +x_78 = lean_ctor_get(x_58, 5); +lean_inc(x_78); +lean_inc(x_77); +lean_inc(x_76); +lean_inc(x_75); +lean_inc(x_74); +lean_dec(x_58); +x_79 = lean_ctor_get(x_59, 0); +lean_inc(x_79); +x_80 = lean_ctor_get(x_59, 1); +lean_inc(x_80); +x_81 = lean_ctor_get(x_59, 3); +lean_inc(x_81); +x_82 = lean_ctor_get(x_59, 4); lean_inc(x_82); -lean_dec(x_8); -x_87 = lean_ctor_get(x_55, 0); -lean_inc(x_87); -x_88 = lean_ctor_get(x_55, 1); -lean_inc(x_88); -x_89 = lean_ctor_get(x_55, 3); -lean_inc(x_89); -x_90 = lean_ctor_get(x_55, 4); -lean_inc(x_90); -x_91 = lean_ctor_get(x_55, 5); +if (lean_is_exclusive(x_59)) { + lean_ctor_release(x_59, 0); + lean_ctor_release(x_59, 1); + lean_ctor_release(x_59, 2); + lean_ctor_release(x_59, 3); + lean_ctor_release(x_59, 4); + x_83 = x_59; +} else { + lean_dec_ref(x_59); + x_83 = lean_box(0); +} +if (lean_is_scalar(x_83)) { + x_84 = lean_alloc_ctor(0, 5, 0); +} else { + x_84 = x_83; +} +lean_ctor_set(x_84, 0, x_79); +lean_ctor_set(x_84, 1, x_80); +lean_ctor_set(x_84, 2, x_6); +lean_ctor_set(x_84, 3, x_81); +lean_ctor_set(x_84, 4, x_82); +x_85 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_85, 0, x_74); +lean_ctor_set(x_85, 1, x_75); +lean_ctor_set(x_85, 2, x_84); +lean_ctor_set(x_85, 3, x_76); +lean_ctor_set(x_85, 4, x_77); +lean_ctor_set(x_85, 5, x_78); +lean_ctor_set(x_8, 0, x_85); +x_86 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_86, 0, x_60); +lean_ctor_set(x_86, 1, x_8); +return x_86; +} +} +else +{ +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; +x_87 = lean_ctor_get(x_8, 1); +x_88 = lean_ctor_get(x_8, 2); +x_89 = lean_ctor_get(x_8, 3); +x_90 = lean_ctor_get(x_8, 4); +x_91 = lean_ctor_get(x_8, 5); lean_inc(x_91); -if (lean_is_exclusive(x_55)) { - lean_ctor_release(x_55, 0); - lean_ctor_release(x_55, 1); - lean_ctor_release(x_55, 2); - lean_ctor_release(x_55, 3); - lean_ctor_release(x_55, 4); - lean_ctor_release(x_55, 5); - x_92 = x_55; -} else { - lean_dec_ref(x_55); - x_92 = lean_box(0); -} -x_93 = lean_ctor_get(x_56, 0); +lean_inc(x_90); +lean_inc(x_89); +lean_inc(x_88); +lean_inc(x_87); +lean_dec(x_8); +x_92 = lean_ctor_get(x_58, 0); +lean_inc(x_92); +x_93 = lean_ctor_get(x_58, 1); lean_inc(x_93); -x_94 = lean_ctor_get(x_56, 1); +x_94 = lean_ctor_get(x_58, 3); lean_inc(x_94); -x_95 = lean_ctor_get(x_56, 3); +x_95 = lean_ctor_get(x_58, 4); lean_inc(x_95); -if (lean_is_exclusive(x_56)) { - lean_ctor_release(x_56, 0); - lean_ctor_release(x_56, 1); - lean_ctor_release(x_56, 2); - lean_ctor_release(x_56, 3); - x_96 = x_56; +x_96 = lean_ctor_get(x_58, 5); +lean_inc(x_96); +if (lean_is_exclusive(x_58)) { + lean_ctor_release(x_58, 0); + lean_ctor_release(x_58, 1); + lean_ctor_release(x_58, 2); + lean_ctor_release(x_58, 3); + lean_ctor_release(x_58, 4); + lean_ctor_release(x_58, 5); + x_97 = x_58; } else { - lean_dec_ref(x_56); - x_96 = lean_box(0); + lean_dec_ref(x_58); + x_97 = lean_box(0); } -if (lean_is_scalar(x_96)) { - x_97 = lean_alloc_ctor(0, 4, 0); +x_98 = lean_ctor_get(x_59, 0); +lean_inc(x_98); +x_99 = lean_ctor_get(x_59, 1); +lean_inc(x_99); +x_100 = lean_ctor_get(x_59, 3); +lean_inc(x_100); +x_101 = lean_ctor_get(x_59, 4); +lean_inc(x_101); +if (lean_is_exclusive(x_59)) { + lean_ctor_release(x_59, 0); + lean_ctor_release(x_59, 1); + lean_ctor_release(x_59, 2); + lean_ctor_release(x_59, 3); + lean_ctor_release(x_59, 4); + x_102 = x_59; } else { - x_97 = x_96; + lean_dec_ref(x_59); + x_102 = lean_box(0); } -lean_ctor_set(x_97, 0, x_93); -lean_ctor_set(x_97, 1, x_94); -lean_ctor_set(x_97, 2, x_6); -lean_ctor_set(x_97, 3, x_95); -if (lean_is_scalar(x_92)) { - x_98 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_102)) { + x_103 = lean_alloc_ctor(0, 5, 0); } else { - x_98 = x_92; + x_103 = x_102; } -lean_ctor_set(x_98, 0, x_87); -lean_ctor_set(x_98, 1, x_88); -lean_ctor_set(x_98, 2, x_97); -lean_ctor_set(x_98, 3, x_89); -lean_ctor_set(x_98, 4, x_90); -lean_ctor_set(x_98, 5, x_91); -x_99 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_99, 0, x_98); -lean_ctor_set(x_99, 1, x_82); -lean_ctor_set(x_99, 2, x_83); -lean_ctor_set(x_99, 3, x_84); -lean_ctor_set(x_99, 4, x_85); -lean_ctor_set(x_99, 5, x_86); -x_100 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_100, 0, x_57); -lean_ctor_set(x_100, 1, x_99); -return x_100; +lean_ctor_set(x_103, 0, x_98); +lean_ctor_set(x_103, 1, x_99); +lean_ctor_set(x_103, 2, x_6); +lean_ctor_set(x_103, 3, x_100); +lean_ctor_set(x_103, 4, x_101); +if (lean_is_scalar(x_97)) { + x_104 = lean_alloc_ctor(0, 6, 0); +} else { + x_104 = x_97; +} +lean_ctor_set(x_104, 0, x_92); +lean_ctor_set(x_104, 1, x_93); +lean_ctor_set(x_104, 2, x_103); +lean_ctor_set(x_104, 3, x_94); +lean_ctor_set(x_104, 4, x_95); +lean_ctor_set(x_104, 5, x_96); +x_105 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_105, 0, x_104); +lean_ctor_set(x_105, 1, x_87); +lean_ctor_set(x_105, 2, x_88); +lean_ctor_set(x_105, 3, x_89); +lean_ctor_set(x_105, 4, x_90); +lean_ctor_set(x_105, 5, x_91); +x_106 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_106, 0, x_60); +lean_ctor_set(x_106, 1, x_105); +return x_106; } } } @@ -22783,7 +22816,7 @@ return x_5; } else { -lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_104; lean_object* x_105; lean_object* x_106; +lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_110; lean_object* x_111; lean_object* x_112; x_6 = lean_ctor_get(x_4, 0); lean_inc(x_6); x_7 = lean_ctor_get(x_6, 2); @@ -22792,40 +22825,40 @@ lean_dec(x_6); x_8 = lean_ctor_get(x_7, 2); lean_inc(x_8); lean_dec(x_7); -x_104 = l_Lean_Elab_Term_resetSynthInstanceCache___rarg(x_4); -x_105 = lean_ctor_get(x_104, 1); -lean_inc(x_105); -lean_dec(x_104); -x_106 = lean_apply_2(x_2, x_3, x_105); -if (lean_obj_tag(x_106) == 0) +x_110 = l_Lean_Elab_Term_resetSynthInstanceCache___rarg(x_4); +x_111 = lean_ctor_get(x_110, 1); +lean_inc(x_111); +lean_dec(x_110); +x_112 = lean_apply_2(x_2, x_3, x_111); +if (lean_obj_tag(x_112) == 0) { -lean_object* x_107; lean_object* x_108; lean_object* x_109; -x_107 = lean_ctor_get(x_106, 0); -lean_inc(x_107); -x_108 = lean_ctor_get(x_106, 1); -lean_inc(x_108); -lean_dec(x_106); -x_109 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_109, 0, x_107); -x_9 = x_109; -x_10 = x_108; -goto block_103; +lean_object* x_113; lean_object* x_114; lean_object* x_115; +x_113 = lean_ctor_get(x_112, 0); +lean_inc(x_113); +x_114 = lean_ctor_get(x_112, 1); +lean_inc(x_114); +lean_dec(x_112); +x_115 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_115, 0, x_113); +x_9 = x_115; +x_10 = x_114; +goto block_109; } else { -lean_object* x_110; lean_object* x_111; lean_object* x_112; -x_110 = lean_ctor_get(x_106, 0); -lean_inc(x_110); -x_111 = lean_ctor_get(x_106, 1); -lean_inc(x_111); -lean_dec(x_106); -x_112 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_112, 0, x_110); -x_9 = x_112; -x_10 = x_111; -goto block_103; +lean_object* x_116; lean_object* x_117; lean_object* x_118; +x_116 = lean_ctor_get(x_112, 0); +lean_inc(x_116); +x_117 = lean_ctor_get(x_112, 1); +lean_inc(x_117); +lean_dec(x_112); +x_118 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_118, 0, x_116); +x_9 = x_118; +x_10 = x_117; +goto block_109; } -block_103: +block_109: { if (lean_obj_tag(x_9) == 0) { @@ -22863,103 +22896,110 @@ return x_20; } else { -lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; +lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; x_21 = lean_ctor_get(x_12, 0); x_22 = lean_ctor_get(x_12, 1); x_23 = lean_ctor_get(x_12, 3); +x_24 = lean_ctor_get(x_12, 4); +lean_inc(x_24); lean_inc(x_23); lean_inc(x_22); lean_inc(x_21); lean_dec(x_12); -x_24 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_24, 0, x_21); -lean_ctor_set(x_24, 1, x_22); -lean_ctor_set(x_24, 2, x_8); -lean_ctor_set(x_24, 3, x_23); -lean_ctor_set(x_11, 2, x_24); -x_25 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_25, 0, x_13); -lean_ctor_set(x_25, 1, x_10); -return x_25; +x_25 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_25, 0, x_21); +lean_ctor_set(x_25, 1, x_22); +lean_ctor_set(x_25, 2, x_8); +lean_ctor_set(x_25, 3, x_23); +lean_ctor_set(x_25, 4, x_24); +lean_ctor_set(x_11, 2, x_25); +x_26 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_26, 0, x_13); +lean_ctor_set(x_26, 1, x_10); +return x_26; } } else { -lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; -x_26 = lean_ctor_get(x_11, 0); -x_27 = lean_ctor_get(x_11, 1); -x_28 = lean_ctor_get(x_11, 3); -x_29 = lean_ctor_get(x_11, 4); -x_30 = lean_ctor_get(x_11, 5); +lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; +x_27 = lean_ctor_get(x_11, 0); +x_28 = lean_ctor_get(x_11, 1); +x_29 = lean_ctor_get(x_11, 3); +x_30 = lean_ctor_get(x_11, 4); +x_31 = lean_ctor_get(x_11, 5); +lean_inc(x_31); lean_inc(x_30); lean_inc(x_29); lean_inc(x_28); lean_inc(x_27); -lean_inc(x_26); lean_dec(x_11); -x_31 = lean_ctor_get(x_12, 0); -lean_inc(x_31); -x_32 = lean_ctor_get(x_12, 1); +x_32 = lean_ctor_get(x_12, 0); lean_inc(x_32); -x_33 = lean_ctor_get(x_12, 3); +x_33 = lean_ctor_get(x_12, 1); lean_inc(x_33); +x_34 = lean_ctor_get(x_12, 3); +lean_inc(x_34); +x_35 = lean_ctor_get(x_12, 4); +lean_inc(x_35); if (lean_is_exclusive(x_12)) { lean_ctor_release(x_12, 0); lean_ctor_release(x_12, 1); lean_ctor_release(x_12, 2); lean_ctor_release(x_12, 3); - x_34 = x_12; + lean_ctor_release(x_12, 4); + x_36 = x_12; } else { lean_dec_ref(x_12); - x_34 = lean_box(0); + x_36 = lean_box(0); } -if (lean_is_scalar(x_34)) { - x_35 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_36)) { + x_37 = lean_alloc_ctor(0, 5, 0); } else { - x_35 = x_34; + x_37 = x_36; } -lean_ctor_set(x_35, 0, x_31); -lean_ctor_set(x_35, 1, x_32); -lean_ctor_set(x_35, 2, x_8); -lean_ctor_set(x_35, 3, x_33); -x_36 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_36, 0, x_26); -lean_ctor_set(x_36, 1, x_27); -lean_ctor_set(x_36, 2, x_35); -lean_ctor_set(x_36, 3, x_28); -lean_ctor_set(x_36, 4, x_29); -lean_ctor_set(x_36, 5, x_30); -lean_ctor_set(x_10, 0, x_36); -x_37 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_37, 0, x_13); -lean_ctor_set(x_37, 1, x_10); -return x_37; +lean_ctor_set(x_37, 0, x_32); +lean_ctor_set(x_37, 1, x_33); +lean_ctor_set(x_37, 2, x_8); +lean_ctor_set(x_37, 3, x_34); +lean_ctor_set(x_37, 4, x_35); +x_38 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_38, 0, x_27); +lean_ctor_set(x_38, 1, x_28); +lean_ctor_set(x_38, 2, x_37); +lean_ctor_set(x_38, 3, x_29); +lean_ctor_set(x_38, 4, x_30); +lean_ctor_set(x_38, 5, x_31); +lean_ctor_set(x_10, 0, x_38); +x_39 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_39, 0, x_13); +lean_ctor_set(x_39, 1, x_10); +return x_39; } } else { -lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; -x_38 = lean_ctor_get(x_10, 1); -x_39 = lean_ctor_get(x_10, 2); -x_40 = lean_ctor_get(x_10, 3); -x_41 = lean_ctor_get(x_10, 4); -x_42 = lean_ctor_get(x_10, 5); +lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; +x_40 = lean_ctor_get(x_10, 1); +x_41 = lean_ctor_get(x_10, 2); +x_42 = lean_ctor_get(x_10, 3); +x_43 = lean_ctor_get(x_10, 4); +x_44 = lean_ctor_get(x_10, 5); +lean_inc(x_44); +lean_inc(x_43); lean_inc(x_42); lean_inc(x_41); lean_inc(x_40); -lean_inc(x_39); -lean_inc(x_38); lean_dec(x_10); -x_43 = lean_ctor_get(x_11, 0); -lean_inc(x_43); -x_44 = lean_ctor_get(x_11, 1); -lean_inc(x_44); -x_45 = lean_ctor_get(x_11, 3); +x_45 = lean_ctor_get(x_11, 0); lean_inc(x_45); -x_46 = lean_ctor_get(x_11, 4); +x_46 = lean_ctor_get(x_11, 1); lean_inc(x_46); -x_47 = lean_ctor_get(x_11, 5); +x_47 = lean_ctor_get(x_11, 3); lean_inc(x_47); +x_48 = lean_ctor_get(x_11, 4); +lean_inc(x_48); +x_49 = lean_ctor_get(x_11, 5); +lean_inc(x_49); if (lean_is_exclusive(x_11)) { lean_ctor_release(x_11, 0); lean_ctor_release(x_11, 1); @@ -22967,252 +23007,267 @@ if (lean_is_exclusive(x_11)) { lean_ctor_release(x_11, 3); lean_ctor_release(x_11, 4); lean_ctor_release(x_11, 5); - x_48 = x_11; + x_50 = x_11; } else { lean_dec_ref(x_11); - x_48 = lean_box(0); + x_50 = lean_box(0); } -x_49 = lean_ctor_get(x_12, 0); -lean_inc(x_49); -x_50 = lean_ctor_get(x_12, 1); -lean_inc(x_50); -x_51 = lean_ctor_get(x_12, 3); +x_51 = lean_ctor_get(x_12, 0); lean_inc(x_51); +x_52 = lean_ctor_get(x_12, 1); +lean_inc(x_52); +x_53 = lean_ctor_get(x_12, 3); +lean_inc(x_53); +x_54 = lean_ctor_get(x_12, 4); +lean_inc(x_54); if (lean_is_exclusive(x_12)) { lean_ctor_release(x_12, 0); lean_ctor_release(x_12, 1); lean_ctor_release(x_12, 2); lean_ctor_release(x_12, 3); - x_52 = x_12; + lean_ctor_release(x_12, 4); + x_55 = x_12; } else { lean_dec_ref(x_12); - x_52 = lean_box(0); + x_55 = lean_box(0); } -if (lean_is_scalar(x_52)) { - x_53 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_55)) { + x_56 = lean_alloc_ctor(0, 5, 0); } else { - x_53 = x_52; + x_56 = x_55; } -lean_ctor_set(x_53, 0, x_49); -lean_ctor_set(x_53, 1, x_50); -lean_ctor_set(x_53, 2, x_8); -lean_ctor_set(x_53, 3, x_51); -if (lean_is_scalar(x_48)) { - x_54 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_56, 0, x_51); +lean_ctor_set(x_56, 1, x_52); +lean_ctor_set(x_56, 2, x_8); +lean_ctor_set(x_56, 3, x_53); +lean_ctor_set(x_56, 4, x_54); +if (lean_is_scalar(x_50)) { + x_57 = lean_alloc_ctor(0, 6, 0); } else { - x_54 = x_48; + x_57 = x_50; } -lean_ctor_set(x_54, 0, x_43); -lean_ctor_set(x_54, 1, x_44); -lean_ctor_set(x_54, 2, x_53); -lean_ctor_set(x_54, 3, x_45); -lean_ctor_set(x_54, 4, x_46); -lean_ctor_set(x_54, 5, x_47); -x_55 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_55, 0, x_54); -lean_ctor_set(x_55, 1, x_38); -lean_ctor_set(x_55, 2, x_39); -lean_ctor_set(x_55, 3, x_40); -lean_ctor_set(x_55, 4, x_41); -lean_ctor_set(x_55, 5, x_42); -x_56 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_56, 0, x_13); -lean_ctor_set(x_56, 1, x_55); -return x_56; +lean_ctor_set(x_57, 0, x_45); +lean_ctor_set(x_57, 1, x_46); +lean_ctor_set(x_57, 2, x_56); +lean_ctor_set(x_57, 3, x_47); +lean_ctor_set(x_57, 4, x_48); +lean_ctor_set(x_57, 5, x_49); +x_58 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_58, 0, x_57); +lean_ctor_set(x_58, 1, x_40); +lean_ctor_set(x_58, 2, x_41); +lean_ctor_set(x_58, 3, x_42); +lean_ctor_set(x_58, 4, x_43); +lean_ctor_set(x_58, 5, x_44); +x_59 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_59, 0, x_13); +lean_ctor_set(x_59, 1, x_58); +return x_59; } } else { -lean_object* x_57; lean_object* x_58; lean_object* x_59; uint8_t x_60; -x_57 = lean_ctor_get(x_10, 0); -lean_inc(x_57); -x_58 = lean_ctor_get(x_57, 2); -lean_inc(x_58); -x_59 = lean_ctor_get(x_9, 0); -lean_inc(x_59); +lean_object* x_60; lean_object* x_61; lean_object* x_62; uint8_t x_63; +x_60 = lean_ctor_get(x_10, 0); +lean_inc(x_60); +x_61 = lean_ctor_get(x_60, 2); +lean_inc(x_61); +x_62 = lean_ctor_get(x_9, 0); +lean_inc(x_62); lean_dec(x_9); -x_60 = !lean_is_exclusive(x_10); -if (x_60 == 0) +x_63 = !lean_is_exclusive(x_10); +if (x_63 == 0) { -lean_object* x_61; uint8_t x_62; -x_61 = lean_ctor_get(x_10, 0); -lean_dec(x_61); -x_62 = !lean_is_exclusive(x_57); -if (x_62 == 0) +lean_object* x_64; uint8_t x_65; +x_64 = lean_ctor_get(x_10, 0); +lean_dec(x_64); +x_65 = !lean_is_exclusive(x_60); +if (x_65 == 0) { -lean_object* x_63; uint8_t x_64; -x_63 = lean_ctor_get(x_57, 2); -lean_dec(x_63); -x_64 = !lean_is_exclusive(x_58); -if (x_64 == 0) +lean_object* x_66; uint8_t x_67; +x_66 = lean_ctor_get(x_60, 2); +lean_dec(x_66); +x_67 = !lean_is_exclusive(x_61); +if (x_67 == 0) { -lean_object* x_65; lean_object* x_66; -x_65 = lean_ctor_get(x_58, 2); -lean_dec(x_65); -lean_ctor_set(x_58, 2, x_8); -x_66 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_66, 0, x_59); -lean_ctor_set(x_66, 1, x_10); -return x_66; +lean_object* x_68; lean_object* x_69; +x_68 = lean_ctor_get(x_61, 2); +lean_dec(x_68); +lean_ctor_set(x_61, 2, x_8); +x_69 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_69, 0, x_62); +lean_ctor_set(x_69, 1, x_10); +return x_69; } else { -lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; -x_67 = lean_ctor_get(x_58, 0); -x_68 = lean_ctor_get(x_58, 1); -x_69 = lean_ctor_get(x_58, 3); -lean_inc(x_69); -lean_inc(x_68); -lean_inc(x_67); -lean_dec(x_58); -x_70 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_70, 0, x_67); -lean_ctor_set(x_70, 1, x_68); -lean_ctor_set(x_70, 2, x_8); -lean_ctor_set(x_70, 3, x_69); -lean_ctor_set(x_57, 2, x_70); -x_71 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_71, 0, x_59); -lean_ctor_set(x_71, 1, x_10); -return x_71; -} -} -else -{ -lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; -x_72 = lean_ctor_get(x_57, 0); -x_73 = lean_ctor_get(x_57, 1); -x_74 = lean_ctor_get(x_57, 3); -x_75 = lean_ctor_get(x_57, 4); -x_76 = lean_ctor_get(x_57, 5); -lean_inc(x_76); -lean_inc(x_75); -lean_inc(x_74); +lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; +x_70 = lean_ctor_get(x_61, 0); +x_71 = lean_ctor_get(x_61, 1); +x_72 = lean_ctor_get(x_61, 3); +x_73 = lean_ctor_get(x_61, 4); lean_inc(x_73); lean_inc(x_72); -lean_dec(x_57); -x_77 = lean_ctor_get(x_58, 0); -lean_inc(x_77); -x_78 = lean_ctor_get(x_58, 1); -lean_inc(x_78); -x_79 = lean_ctor_get(x_58, 3); -lean_inc(x_79); -if (lean_is_exclusive(x_58)) { - lean_ctor_release(x_58, 0); - lean_ctor_release(x_58, 1); - lean_ctor_release(x_58, 2); - lean_ctor_release(x_58, 3); - x_80 = x_58; -} else { - lean_dec_ref(x_58); - x_80 = lean_box(0); -} -if (lean_is_scalar(x_80)) { - x_81 = lean_alloc_ctor(0, 4, 0); -} else { - x_81 = x_80; -} -lean_ctor_set(x_81, 0, x_77); -lean_ctor_set(x_81, 1, x_78); -lean_ctor_set(x_81, 2, x_8); -lean_ctor_set(x_81, 3, x_79); -x_82 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_82, 0, x_72); -lean_ctor_set(x_82, 1, x_73); -lean_ctor_set(x_82, 2, x_81); -lean_ctor_set(x_82, 3, x_74); -lean_ctor_set(x_82, 4, x_75); -lean_ctor_set(x_82, 5, x_76); -lean_ctor_set(x_10, 0, x_82); -x_83 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_83, 0, x_59); -lean_ctor_set(x_83, 1, x_10); -return x_83; +lean_inc(x_71); +lean_inc(x_70); +lean_dec(x_61); +x_74 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_74, 0, x_70); +lean_ctor_set(x_74, 1, x_71); +lean_ctor_set(x_74, 2, x_8); +lean_ctor_set(x_74, 3, x_72); +lean_ctor_set(x_74, 4, x_73); +lean_ctor_set(x_60, 2, x_74); +x_75 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_75, 0, x_62); +lean_ctor_set(x_75, 1, x_10); +return x_75; } } else { -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; -x_84 = lean_ctor_get(x_10, 1); -x_85 = lean_ctor_get(x_10, 2); -x_86 = lean_ctor_get(x_10, 3); -x_87 = lean_ctor_get(x_10, 4); -x_88 = lean_ctor_get(x_10, 5); -lean_inc(x_88); -lean_inc(x_87); -lean_inc(x_86); -lean_inc(x_85); +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; +x_76 = lean_ctor_get(x_60, 0); +x_77 = lean_ctor_get(x_60, 1); +x_78 = lean_ctor_get(x_60, 3); +x_79 = lean_ctor_get(x_60, 4); +x_80 = lean_ctor_get(x_60, 5); +lean_inc(x_80); +lean_inc(x_79); +lean_inc(x_78); +lean_inc(x_77); +lean_inc(x_76); +lean_dec(x_60); +x_81 = lean_ctor_get(x_61, 0); +lean_inc(x_81); +x_82 = lean_ctor_get(x_61, 1); +lean_inc(x_82); +x_83 = lean_ctor_get(x_61, 3); +lean_inc(x_83); +x_84 = lean_ctor_get(x_61, 4); lean_inc(x_84); -lean_dec(x_10); -x_89 = lean_ctor_get(x_57, 0); -lean_inc(x_89); -x_90 = lean_ctor_get(x_57, 1); -lean_inc(x_90); -x_91 = lean_ctor_get(x_57, 3); -lean_inc(x_91); -x_92 = lean_ctor_get(x_57, 4); -lean_inc(x_92); -x_93 = lean_ctor_get(x_57, 5); +if (lean_is_exclusive(x_61)) { + lean_ctor_release(x_61, 0); + lean_ctor_release(x_61, 1); + lean_ctor_release(x_61, 2); + lean_ctor_release(x_61, 3); + lean_ctor_release(x_61, 4); + x_85 = x_61; +} else { + lean_dec_ref(x_61); + x_85 = lean_box(0); +} +if (lean_is_scalar(x_85)) { + x_86 = lean_alloc_ctor(0, 5, 0); +} else { + x_86 = x_85; +} +lean_ctor_set(x_86, 0, x_81); +lean_ctor_set(x_86, 1, x_82); +lean_ctor_set(x_86, 2, x_8); +lean_ctor_set(x_86, 3, x_83); +lean_ctor_set(x_86, 4, x_84); +x_87 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_87, 0, x_76); +lean_ctor_set(x_87, 1, x_77); +lean_ctor_set(x_87, 2, x_86); +lean_ctor_set(x_87, 3, x_78); +lean_ctor_set(x_87, 4, x_79); +lean_ctor_set(x_87, 5, x_80); +lean_ctor_set(x_10, 0, x_87); +x_88 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_88, 0, x_62); +lean_ctor_set(x_88, 1, x_10); +return x_88; +} +} +else +{ +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; +x_89 = lean_ctor_get(x_10, 1); +x_90 = lean_ctor_get(x_10, 2); +x_91 = lean_ctor_get(x_10, 3); +x_92 = lean_ctor_get(x_10, 4); +x_93 = lean_ctor_get(x_10, 5); lean_inc(x_93); -if (lean_is_exclusive(x_57)) { - lean_ctor_release(x_57, 0); - lean_ctor_release(x_57, 1); - lean_ctor_release(x_57, 2); - lean_ctor_release(x_57, 3); - lean_ctor_release(x_57, 4); - lean_ctor_release(x_57, 5); - x_94 = x_57; -} else { - lean_dec_ref(x_57); - x_94 = lean_box(0); -} -x_95 = lean_ctor_get(x_58, 0); +lean_inc(x_92); +lean_inc(x_91); +lean_inc(x_90); +lean_inc(x_89); +lean_dec(x_10); +x_94 = lean_ctor_get(x_60, 0); +lean_inc(x_94); +x_95 = lean_ctor_get(x_60, 1); lean_inc(x_95); -x_96 = lean_ctor_get(x_58, 1); +x_96 = lean_ctor_get(x_60, 3); lean_inc(x_96); -x_97 = lean_ctor_get(x_58, 3); +x_97 = lean_ctor_get(x_60, 4); lean_inc(x_97); -if (lean_is_exclusive(x_58)) { - lean_ctor_release(x_58, 0); - lean_ctor_release(x_58, 1); - lean_ctor_release(x_58, 2); - lean_ctor_release(x_58, 3); - x_98 = x_58; +x_98 = lean_ctor_get(x_60, 5); +lean_inc(x_98); +if (lean_is_exclusive(x_60)) { + lean_ctor_release(x_60, 0); + lean_ctor_release(x_60, 1); + lean_ctor_release(x_60, 2); + lean_ctor_release(x_60, 3); + lean_ctor_release(x_60, 4); + lean_ctor_release(x_60, 5); + x_99 = x_60; } else { - lean_dec_ref(x_58); - x_98 = lean_box(0); + lean_dec_ref(x_60); + x_99 = lean_box(0); } -if (lean_is_scalar(x_98)) { - x_99 = lean_alloc_ctor(0, 4, 0); +x_100 = lean_ctor_get(x_61, 0); +lean_inc(x_100); +x_101 = lean_ctor_get(x_61, 1); +lean_inc(x_101); +x_102 = lean_ctor_get(x_61, 3); +lean_inc(x_102); +x_103 = lean_ctor_get(x_61, 4); +lean_inc(x_103); +if (lean_is_exclusive(x_61)) { + lean_ctor_release(x_61, 0); + lean_ctor_release(x_61, 1); + lean_ctor_release(x_61, 2); + lean_ctor_release(x_61, 3); + lean_ctor_release(x_61, 4); + x_104 = x_61; } else { - x_99 = x_98; + lean_dec_ref(x_61); + x_104 = lean_box(0); } -lean_ctor_set(x_99, 0, x_95); -lean_ctor_set(x_99, 1, x_96); -lean_ctor_set(x_99, 2, x_8); -lean_ctor_set(x_99, 3, x_97); -if (lean_is_scalar(x_94)) { - x_100 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_104)) { + x_105 = lean_alloc_ctor(0, 5, 0); } else { - x_100 = x_94; + x_105 = x_104; } -lean_ctor_set(x_100, 0, x_89); -lean_ctor_set(x_100, 1, x_90); -lean_ctor_set(x_100, 2, x_99); -lean_ctor_set(x_100, 3, x_91); -lean_ctor_set(x_100, 4, x_92); -lean_ctor_set(x_100, 5, x_93); -x_101 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_101, 0, x_100); -lean_ctor_set(x_101, 1, x_84); -lean_ctor_set(x_101, 2, x_85); -lean_ctor_set(x_101, 3, x_86); -lean_ctor_set(x_101, 4, x_87); -lean_ctor_set(x_101, 5, x_88); -x_102 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_102, 0, x_59); -lean_ctor_set(x_102, 1, x_101); -return x_102; +lean_ctor_set(x_105, 0, x_100); +lean_ctor_set(x_105, 1, x_101); +lean_ctor_set(x_105, 2, x_8); +lean_ctor_set(x_105, 3, x_102); +lean_ctor_set(x_105, 4, x_103); +if (lean_is_scalar(x_99)) { + x_106 = lean_alloc_ctor(0, 6, 0); +} else { + x_106 = x_99; +} +lean_ctor_set(x_106, 0, x_94); +lean_ctor_set(x_106, 1, x_95); +lean_ctor_set(x_106, 2, x_105); +lean_ctor_set(x_106, 3, x_96); +lean_ctor_set(x_106, 4, x_97); +lean_ctor_set(x_106, 5, x_98); +x_107 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_107, 0, x_106); +lean_ctor_set(x_107, 1, x_89); +lean_ctor_set(x_107, 2, x_90); +lean_ctor_set(x_107, 3, x_91); +lean_ctor_set(x_107, 4, x_92); +lean_ctor_set(x_107, 5, x_93); +x_108 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_108, 0, x_62); +lean_ctor_set(x_108, 1, x_107); +return x_108; } } } @@ -23319,38 +23374,38 @@ lean_ctor_set(x_14, 2, x_2); lean_ctor_set(x_14, 1, x_1); if (x_12 == 0) { -lean_object* x_127; +lean_object* x_133; lean_dec(x_7); lean_dec(x_2); -x_127 = lean_box(0); -x_18 = x_127; -goto block_126; +x_133 = lean_box(0); +x_18 = x_133; +goto block_132; } else { -lean_object* x_128; uint8_t x_129; -x_128 = lean_unsigned_to_nat(0u); -x_129 = l_Array_isEqvAux___main___at_Lean_Elab_Term_withLocalContext___spec__1(x_2, x_7, lean_box(0), x_2, x_7, x_128); +lean_object* x_134; uint8_t x_135; +x_134 = lean_unsigned_to_nat(0u); +x_135 = l_Array_isEqvAux___main___at_Lean_Elab_Term_withLocalContext___spec__1(x_2, x_7, lean_box(0), x_2, x_7, x_134); lean_dec(x_7); lean_dec(x_2); -if (x_129 == 0) +if (x_135 == 0) { -lean_object* x_130; -x_130 = lean_box(0); -x_18 = x_130; -goto block_126; +lean_object* x_136; +x_136 = lean_box(0); +x_18 = x_136; +goto block_132; } else { -lean_object* x_131; +lean_object* x_137; lean_dec(x_9); -x_131 = lean_apply_2(x_3, x_4, x_8); -return x_131; +x_137 = lean_apply_2(x_3, x_4, x_8); +return x_137; } } -block_126: +block_132: { -lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_117; lean_object* x_118; lean_object* x_119; +lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_dec(x_18); x_19 = lean_ctor_get(x_8, 0); lean_inc(x_19); @@ -23360,40 +23415,40 @@ lean_dec(x_19); x_21 = lean_ctor_get(x_20, 2); lean_inc(x_21); lean_dec(x_20); -x_117 = l_Lean_Elab_Term_resetSynthInstanceCache___rarg(x_8); -x_118 = lean_ctor_get(x_117, 1); -lean_inc(x_118); -lean_dec(x_117); -x_119 = lean_apply_2(x_3, x_4, x_118); -if (lean_obj_tag(x_119) == 0) +x_123 = l_Lean_Elab_Term_resetSynthInstanceCache___rarg(x_8); +x_124 = lean_ctor_get(x_123, 1); +lean_inc(x_124); +lean_dec(x_123); +x_125 = lean_apply_2(x_3, x_4, x_124); +if (lean_obj_tag(x_125) == 0) { -lean_object* x_120; lean_object* x_121; lean_object* x_122; -x_120 = lean_ctor_get(x_119, 0); -lean_inc(x_120); -x_121 = lean_ctor_get(x_119, 1); -lean_inc(x_121); -lean_dec(x_119); -x_122 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_122, 0, x_120); -x_22 = x_122; -x_23 = x_121; -goto block_116; +lean_object* x_126; lean_object* x_127; lean_object* x_128; +x_126 = lean_ctor_get(x_125, 0); +lean_inc(x_126); +x_127 = lean_ctor_get(x_125, 1); +lean_inc(x_127); +lean_dec(x_125); +x_128 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_128, 0, x_126); +x_22 = x_128; +x_23 = x_127; +goto block_122; } else { -lean_object* x_123; lean_object* x_124; lean_object* x_125; -x_123 = lean_ctor_get(x_119, 0); -lean_inc(x_123); -x_124 = lean_ctor_get(x_119, 1); -lean_inc(x_124); -lean_dec(x_119); -x_125 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_125, 0, x_123); -x_22 = x_125; -x_23 = x_124; -goto block_116; +lean_object* x_129; lean_object* x_130; lean_object* x_131; +x_129 = lean_ctor_get(x_125, 0); +lean_inc(x_129); +x_130 = lean_ctor_get(x_125, 1); +lean_inc(x_130); +lean_dec(x_125); +x_131 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_131, 0, x_129); +x_22 = x_131; +x_23 = x_130; +goto block_122; } -block_116: +block_122: { if (lean_obj_tag(x_22) == 0) { @@ -23436,113 +23491,120 @@ return x_33; } else { -lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; +lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; x_34 = lean_ctor_get(x_25, 0); x_35 = lean_ctor_get(x_25, 1); x_36 = lean_ctor_get(x_25, 3); +x_37 = lean_ctor_get(x_25, 4); +lean_inc(x_37); lean_inc(x_36); lean_inc(x_35); lean_inc(x_34); lean_dec(x_25); -x_37 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_37, 0, x_34); -lean_ctor_set(x_37, 1, x_35); -lean_ctor_set(x_37, 2, x_21); -lean_ctor_set(x_37, 3, x_36); -lean_ctor_set(x_24, 2, x_37); +x_38 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_38, 0, x_34); +lean_ctor_set(x_38, 1, x_35); +lean_ctor_set(x_38, 2, x_21); +lean_ctor_set(x_38, 3, x_36); +lean_ctor_set(x_38, 4, x_37); +lean_ctor_set(x_24, 2, x_38); if (lean_is_scalar(x_9)) { - x_38 = lean_alloc_ctor(1, 2, 0); + x_39 = lean_alloc_ctor(1, 2, 0); } else { - x_38 = x_9; - lean_ctor_set_tag(x_38, 1); + x_39 = x_9; + lean_ctor_set_tag(x_39, 1); } -lean_ctor_set(x_38, 0, x_26); -lean_ctor_set(x_38, 1, x_23); -return x_38; +lean_ctor_set(x_39, 0, x_26); +lean_ctor_set(x_39, 1, x_23); +return x_39; } } else { -lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; -x_39 = lean_ctor_get(x_24, 0); -x_40 = lean_ctor_get(x_24, 1); -x_41 = lean_ctor_get(x_24, 3); -x_42 = lean_ctor_get(x_24, 4); -x_43 = lean_ctor_get(x_24, 5); +lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; +x_40 = lean_ctor_get(x_24, 0); +x_41 = lean_ctor_get(x_24, 1); +x_42 = lean_ctor_get(x_24, 3); +x_43 = lean_ctor_get(x_24, 4); +x_44 = lean_ctor_get(x_24, 5); +lean_inc(x_44); lean_inc(x_43); lean_inc(x_42); lean_inc(x_41); lean_inc(x_40); -lean_inc(x_39); lean_dec(x_24); -x_44 = lean_ctor_get(x_25, 0); -lean_inc(x_44); -x_45 = lean_ctor_get(x_25, 1); +x_45 = lean_ctor_get(x_25, 0); lean_inc(x_45); -x_46 = lean_ctor_get(x_25, 3); +x_46 = lean_ctor_get(x_25, 1); lean_inc(x_46); +x_47 = lean_ctor_get(x_25, 3); +lean_inc(x_47); +x_48 = lean_ctor_get(x_25, 4); +lean_inc(x_48); if (lean_is_exclusive(x_25)) { lean_ctor_release(x_25, 0); lean_ctor_release(x_25, 1); lean_ctor_release(x_25, 2); lean_ctor_release(x_25, 3); - x_47 = x_25; + lean_ctor_release(x_25, 4); + x_49 = x_25; } else { lean_dec_ref(x_25); - x_47 = lean_box(0); + x_49 = lean_box(0); } -if (lean_is_scalar(x_47)) { - x_48 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_49)) { + x_50 = lean_alloc_ctor(0, 5, 0); } else { - x_48 = x_47; + x_50 = x_49; } -lean_ctor_set(x_48, 0, x_44); -lean_ctor_set(x_48, 1, x_45); -lean_ctor_set(x_48, 2, x_21); -lean_ctor_set(x_48, 3, x_46); -x_49 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_49, 0, x_39); -lean_ctor_set(x_49, 1, x_40); -lean_ctor_set(x_49, 2, x_48); -lean_ctor_set(x_49, 3, x_41); -lean_ctor_set(x_49, 4, x_42); -lean_ctor_set(x_49, 5, x_43); -lean_ctor_set(x_23, 0, x_49); +lean_ctor_set(x_50, 0, x_45); +lean_ctor_set(x_50, 1, x_46); +lean_ctor_set(x_50, 2, x_21); +lean_ctor_set(x_50, 3, x_47); +lean_ctor_set(x_50, 4, x_48); +x_51 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_51, 0, x_40); +lean_ctor_set(x_51, 1, x_41); +lean_ctor_set(x_51, 2, x_50); +lean_ctor_set(x_51, 3, x_42); +lean_ctor_set(x_51, 4, x_43); +lean_ctor_set(x_51, 5, x_44); +lean_ctor_set(x_23, 0, x_51); if (lean_is_scalar(x_9)) { - x_50 = lean_alloc_ctor(1, 2, 0); + x_52 = lean_alloc_ctor(1, 2, 0); } else { - x_50 = x_9; - lean_ctor_set_tag(x_50, 1); + x_52 = x_9; + lean_ctor_set_tag(x_52, 1); } -lean_ctor_set(x_50, 0, x_26); -lean_ctor_set(x_50, 1, x_23); -return x_50; +lean_ctor_set(x_52, 0, x_26); +lean_ctor_set(x_52, 1, x_23); +return x_52; } } else { -lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; -x_51 = lean_ctor_get(x_23, 1); -x_52 = lean_ctor_get(x_23, 2); -x_53 = lean_ctor_get(x_23, 3); -x_54 = lean_ctor_get(x_23, 4); -x_55 = lean_ctor_get(x_23, 5); +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_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; +x_53 = lean_ctor_get(x_23, 1); +x_54 = lean_ctor_get(x_23, 2); +x_55 = lean_ctor_get(x_23, 3); +x_56 = lean_ctor_get(x_23, 4); +x_57 = lean_ctor_get(x_23, 5); +lean_inc(x_57); +lean_inc(x_56); lean_inc(x_55); lean_inc(x_54); lean_inc(x_53); -lean_inc(x_52); -lean_inc(x_51); lean_dec(x_23); -x_56 = lean_ctor_get(x_24, 0); -lean_inc(x_56); -x_57 = lean_ctor_get(x_24, 1); -lean_inc(x_57); -x_58 = lean_ctor_get(x_24, 3); +x_58 = lean_ctor_get(x_24, 0); lean_inc(x_58); -x_59 = lean_ctor_get(x_24, 4); +x_59 = lean_ctor_get(x_24, 1); lean_inc(x_59); -x_60 = lean_ctor_get(x_24, 5); +x_60 = lean_ctor_get(x_24, 3); lean_inc(x_60); +x_61 = lean_ctor_get(x_24, 4); +lean_inc(x_61); +x_62 = lean_ctor_get(x_24, 5); +lean_inc(x_62); if (lean_is_exclusive(x_24)) { lean_ctor_release(x_24, 0); lean_ctor_release(x_24, 1); @@ -23550,273 +23612,288 @@ if (lean_is_exclusive(x_24)) { lean_ctor_release(x_24, 3); lean_ctor_release(x_24, 4); lean_ctor_release(x_24, 5); - x_61 = x_24; + x_63 = x_24; } else { lean_dec_ref(x_24); - x_61 = lean_box(0); + x_63 = lean_box(0); } -x_62 = lean_ctor_get(x_25, 0); -lean_inc(x_62); -x_63 = lean_ctor_get(x_25, 1); -lean_inc(x_63); -x_64 = lean_ctor_get(x_25, 3); +x_64 = lean_ctor_get(x_25, 0); lean_inc(x_64); +x_65 = lean_ctor_get(x_25, 1); +lean_inc(x_65); +x_66 = lean_ctor_get(x_25, 3); +lean_inc(x_66); +x_67 = lean_ctor_get(x_25, 4); +lean_inc(x_67); if (lean_is_exclusive(x_25)) { lean_ctor_release(x_25, 0); lean_ctor_release(x_25, 1); lean_ctor_release(x_25, 2); lean_ctor_release(x_25, 3); - x_65 = x_25; + lean_ctor_release(x_25, 4); + x_68 = x_25; } else { lean_dec_ref(x_25); - x_65 = lean_box(0); + x_68 = lean_box(0); } -if (lean_is_scalar(x_65)) { - x_66 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_68)) { + x_69 = lean_alloc_ctor(0, 5, 0); } else { - x_66 = x_65; + x_69 = x_68; } -lean_ctor_set(x_66, 0, x_62); -lean_ctor_set(x_66, 1, x_63); -lean_ctor_set(x_66, 2, x_21); -lean_ctor_set(x_66, 3, x_64); -if (lean_is_scalar(x_61)) { - x_67 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_69, 0, x_64); +lean_ctor_set(x_69, 1, x_65); +lean_ctor_set(x_69, 2, x_21); +lean_ctor_set(x_69, 3, x_66); +lean_ctor_set(x_69, 4, x_67); +if (lean_is_scalar(x_63)) { + x_70 = lean_alloc_ctor(0, 6, 0); } else { - x_67 = x_61; + x_70 = x_63; } -lean_ctor_set(x_67, 0, x_56); -lean_ctor_set(x_67, 1, x_57); -lean_ctor_set(x_67, 2, x_66); -lean_ctor_set(x_67, 3, x_58); -lean_ctor_set(x_67, 4, x_59); -lean_ctor_set(x_67, 5, x_60); -x_68 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_68, 0, x_67); -lean_ctor_set(x_68, 1, x_51); -lean_ctor_set(x_68, 2, x_52); -lean_ctor_set(x_68, 3, x_53); -lean_ctor_set(x_68, 4, x_54); -lean_ctor_set(x_68, 5, x_55); +lean_ctor_set(x_70, 0, x_58); +lean_ctor_set(x_70, 1, x_59); +lean_ctor_set(x_70, 2, x_69); +lean_ctor_set(x_70, 3, x_60); +lean_ctor_set(x_70, 4, x_61); +lean_ctor_set(x_70, 5, x_62); +x_71 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_71, 0, x_70); +lean_ctor_set(x_71, 1, x_53); +lean_ctor_set(x_71, 2, x_54); +lean_ctor_set(x_71, 3, x_55); +lean_ctor_set(x_71, 4, x_56); +lean_ctor_set(x_71, 5, x_57); if (lean_is_scalar(x_9)) { - x_69 = lean_alloc_ctor(1, 2, 0); + x_72 = lean_alloc_ctor(1, 2, 0); } else { - x_69 = x_9; - lean_ctor_set_tag(x_69, 1); + x_72 = x_9; + lean_ctor_set_tag(x_72, 1); } -lean_ctor_set(x_69, 0, x_26); -lean_ctor_set(x_69, 1, x_68); -return x_69; +lean_ctor_set(x_72, 0, x_26); +lean_ctor_set(x_72, 1, x_71); +return x_72; } } else { -lean_object* x_70; lean_object* x_71; lean_object* x_72; uint8_t x_73; -x_70 = lean_ctor_get(x_23, 0); -lean_inc(x_70); -x_71 = lean_ctor_get(x_70, 2); -lean_inc(x_71); -x_72 = lean_ctor_get(x_22, 0); -lean_inc(x_72); +lean_object* x_73; lean_object* x_74; lean_object* x_75; uint8_t x_76; +x_73 = lean_ctor_get(x_23, 0); +lean_inc(x_73); +x_74 = lean_ctor_get(x_73, 2); +lean_inc(x_74); +x_75 = lean_ctor_get(x_22, 0); +lean_inc(x_75); lean_dec(x_22); -x_73 = !lean_is_exclusive(x_23); -if (x_73 == 0) +x_76 = !lean_is_exclusive(x_23); +if (x_76 == 0) { -lean_object* x_74; uint8_t x_75; -x_74 = lean_ctor_get(x_23, 0); -lean_dec(x_74); -x_75 = !lean_is_exclusive(x_70); -if (x_75 == 0) +lean_object* x_77; uint8_t x_78; +x_77 = lean_ctor_get(x_23, 0); +lean_dec(x_77); +x_78 = !lean_is_exclusive(x_73); +if (x_78 == 0) { -lean_object* x_76; uint8_t x_77; -x_76 = lean_ctor_get(x_70, 2); -lean_dec(x_76); -x_77 = !lean_is_exclusive(x_71); -if (x_77 == 0) +lean_object* x_79; uint8_t x_80; +x_79 = lean_ctor_get(x_73, 2); +lean_dec(x_79); +x_80 = !lean_is_exclusive(x_74); +if (x_80 == 0) { -lean_object* x_78; lean_object* x_79; -x_78 = lean_ctor_get(x_71, 2); -lean_dec(x_78); -lean_ctor_set(x_71, 2, x_21); +lean_object* x_81; lean_object* x_82; +x_81 = lean_ctor_get(x_74, 2); +lean_dec(x_81); +lean_ctor_set(x_74, 2, x_21); if (lean_is_scalar(x_9)) { - x_79 = lean_alloc_ctor(0, 2, 0); + x_82 = lean_alloc_ctor(0, 2, 0); } else { - x_79 = x_9; + x_82 = x_9; } -lean_ctor_set(x_79, 0, x_72); -lean_ctor_set(x_79, 1, x_23); -return x_79; +lean_ctor_set(x_82, 0, x_75); +lean_ctor_set(x_82, 1, x_23); +return x_82; } else { -lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; -x_80 = lean_ctor_get(x_71, 0); -x_81 = lean_ctor_get(x_71, 1); -x_82 = lean_ctor_get(x_71, 3); -lean_inc(x_82); -lean_inc(x_81); -lean_inc(x_80); -lean_dec(x_71); -x_83 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_83, 0, x_80); -lean_ctor_set(x_83, 1, x_81); -lean_ctor_set(x_83, 2, x_21); -lean_ctor_set(x_83, 3, x_82); -lean_ctor_set(x_70, 2, x_83); -if (lean_is_scalar(x_9)) { - x_84 = lean_alloc_ctor(0, 2, 0); -} else { - x_84 = x_9; -} -lean_ctor_set(x_84, 0, x_72); -lean_ctor_set(x_84, 1, x_23); -return x_84; -} -} -else -{ -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; -x_85 = lean_ctor_get(x_70, 0); -x_86 = lean_ctor_get(x_70, 1); -x_87 = lean_ctor_get(x_70, 3); -x_88 = lean_ctor_get(x_70, 4); -x_89 = lean_ctor_get(x_70, 5); -lean_inc(x_89); -lean_inc(x_88); -lean_inc(x_87); +lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; +x_83 = lean_ctor_get(x_74, 0); +x_84 = lean_ctor_get(x_74, 1); +x_85 = lean_ctor_get(x_74, 3); +x_86 = lean_ctor_get(x_74, 4); lean_inc(x_86); lean_inc(x_85); -lean_dec(x_70); -x_90 = lean_ctor_get(x_71, 0); -lean_inc(x_90); -x_91 = lean_ctor_get(x_71, 1); -lean_inc(x_91); -x_92 = lean_ctor_get(x_71, 3); +lean_inc(x_84); +lean_inc(x_83); +lean_dec(x_74); +x_87 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_87, 0, x_83); +lean_ctor_set(x_87, 1, x_84); +lean_ctor_set(x_87, 2, x_21); +lean_ctor_set(x_87, 3, x_85); +lean_ctor_set(x_87, 4, x_86); +lean_ctor_set(x_73, 2, x_87); +if (lean_is_scalar(x_9)) { + x_88 = lean_alloc_ctor(0, 2, 0); +} else { + x_88 = x_9; +} +lean_ctor_set(x_88, 0, x_75); +lean_ctor_set(x_88, 1, x_23); +return x_88; +} +} +else +{ +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; +x_89 = lean_ctor_get(x_73, 0); +x_90 = lean_ctor_get(x_73, 1); +x_91 = lean_ctor_get(x_73, 3); +x_92 = lean_ctor_get(x_73, 4); +x_93 = lean_ctor_get(x_73, 5); +lean_inc(x_93); lean_inc(x_92); -if (lean_is_exclusive(x_71)) { - lean_ctor_release(x_71, 0); - lean_ctor_release(x_71, 1); - lean_ctor_release(x_71, 2); - lean_ctor_release(x_71, 3); - x_93 = x_71; -} else { - lean_dec_ref(x_71); - x_93 = lean_box(0); -} -if (lean_is_scalar(x_93)) { - x_94 = lean_alloc_ctor(0, 4, 0); -} else { - x_94 = x_93; -} -lean_ctor_set(x_94, 0, x_90); -lean_ctor_set(x_94, 1, x_91); -lean_ctor_set(x_94, 2, x_21); -lean_ctor_set(x_94, 3, x_92); -x_95 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_95, 0, x_85); -lean_ctor_set(x_95, 1, x_86); -lean_ctor_set(x_95, 2, x_94); -lean_ctor_set(x_95, 3, x_87); -lean_ctor_set(x_95, 4, x_88); -lean_ctor_set(x_95, 5, x_89); -lean_ctor_set(x_23, 0, x_95); -if (lean_is_scalar(x_9)) { - x_96 = lean_alloc_ctor(0, 2, 0); -} else { - x_96 = x_9; -} -lean_ctor_set(x_96, 0, x_72); -lean_ctor_set(x_96, 1, x_23); -return x_96; -} -} -else -{ -lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; 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; -x_97 = lean_ctor_get(x_23, 1); -x_98 = lean_ctor_get(x_23, 2); -x_99 = lean_ctor_get(x_23, 3); -x_100 = lean_ctor_get(x_23, 4); -x_101 = lean_ctor_get(x_23, 5); -lean_inc(x_101); -lean_inc(x_100); -lean_inc(x_99); -lean_inc(x_98); +lean_inc(x_91); +lean_inc(x_90); +lean_inc(x_89); +lean_dec(x_73); +x_94 = lean_ctor_get(x_74, 0); +lean_inc(x_94); +x_95 = lean_ctor_get(x_74, 1); +lean_inc(x_95); +x_96 = lean_ctor_get(x_74, 3); +lean_inc(x_96); +x_97 = lean_ctor_get(x_74, 4); lean_inc(x_97); -lean_dec(x_23); -x_102 = lean_ctor_get(x_70, 0); -lean_inc(x_102); -x_103 = lean_ctor_get(x_70, 1); -lean_inc(x_103); -x_104 = lean_ctor_get(x_70, 3); -lean_inc(x_104); -x_105 = lean_ctor_get(x_70, 4); -lean_inc(x_105); -x_106 = lean_ctor_get(x_70, 5); -lean_inc(x_106); -if (lean_is_exclusive(x_70)) { - lean_ctor_release(x_70, 0); - lean_ctor_release(x_70, 1); - lean_ctor_release(x_70, 2); - lean_ctor_release(x_70, 3); - lean_ctor_release(x_70, 4); - lean_ctor_release(x_70, 5); - x_107 = x_70; +if (lean_is_exclusive(x_74)) { + lean_ctor_release(x_74, 0); + lean_ctor_release(x_74, 1); + lean_ctor_release(x_74, 2); + lean_ctor_release(x_74, 3); + lean_ctor_release(x_74, 4); + x_98 = x_74; } else { - lean_dec_ref(x_70); - x_107 = lean_box(0); + lean_dec_ref(x_74); + x_98 = lean_box(0); } -x_108 = lean_ctor_get(x_71, 0); -lean_inc(x_108); -x_109 = lean_ctor_get(x_71, 1); -lean_inc(x_109); -x_110 = lean_ctor_get(x_71, 3); -lean_inc(x_110); -if (lean_is_exclusive(x_71)) { - lean_ctor_release(x_71, 0); - lean_ctor_release(x_71, 1); - lean_ctor_release(x_71, 2); - lean_ctor_release(x_71, 3); - x_111 = x_71; +if (lean_is_scalar(x_98)) { + x_99 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_71); - x_111 = lean_box(0); + x_99 = x_98; } -if (lean_is_scalar(x_111)) { - x_112 = lean_alloc_ctor(0, 4, 0); -} else { - x_112 = x_111; -} -lean_ctor_set(x_112, 0, x_108); -lean_ctor_set(x_112, 1, x_109); -lean_ctor_set(x_112, 2, x_21); -lean_ctor_set(x_112, 3, x_110); -if (lean_is_scalar(x_107)) { - x_113 = lean_alloc_ctor(0, 6, 0); -} else { - x_113 = x_107; -} -lean_ctor_set(x_113, 0, x_102); -lean_ctor_set(x_113, 1, x_103); -lean_ctor_set(x_113, 2, x_112); -lean_ctor_set(x_113, 3, x_104); -lean_ctor_set(x_113, 4, x_105); -lean_ctor_set(x_113, 5, x_106); -x_114 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_114, 0, x_113); -lean_ctor_set(x_114, 1, x_97); -lean_ctor_set(x_114, 2, x_98); -lean_ctor_set(x_114, 3, x_99); -lean_ctor_set(x_114, 4, x_100); -lean_ctor_set(x_114, 5, x_101); +lean_ctor_set(x_99, 0, x_94); +lean_ctor_set(x_99, 1, x_95); +lean_ctor_set(x_99, 2, x_21); +lean_ctor_set(x_99, 3, x_96); +lean_ctor_set(x_99, 4, x_97); +x_100 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_100, 0, x_89); +lean_ctor_set(x_100, 1, x_90); +lean_ctor_set(x_100, 2, x_99); +lean_ctor_set(x_100, 3, x_91); +lean_ctor_set(x_100, 4, x_92); +lean_ctor_set(x_100, 5, x_93); +lean_ctor_set(x_23, 0, x_100); if (lean_is_scalar(x_9)) { - x_115 = lean_alloc_ctor(0, 2, 0); + x_101 = lean_alloc_ctor(0, 2, 0); } else { - x_115 = x_9; + x_101 = x_9; } -lean_ctor_set(x_115, 0, x_72); -lean_ctor_set(x_115, 1, x_114); -return x_115; +lean_ctor_set(x_101, 0, x_75); +lean_ctor_set(x_101, 1, x_23); +return x_101; +} +} +else +{ +lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; +x_102 = lean_ctor_get(x_23, 1); +x_103 = lean_ctor_get(x_23, 2); +x_104 = lean_ctor_get(x_23, 3); +x_105 = lean_ctor_get(x_23, 4); +x_106 = lean_ctor_get(x_23, 5); +lean_inc(x_106); +lean_inc(x_105); +lean_inc(x_104); +lean_inc(x_103); +lean_inc(x_102); +lean_dec(x_23); +x_107 = lean_ctor_get(x_73, 0); +lean_inc(x_107); +x_108 = lean_ctor_get(x_73, 1); +lean_inc(x_108); +x_109 = lean_ctor_get(x_73, 3); +lean_inc(x_109); +x_110 = lean_ctor_get(x_73, 4); +lean_inc(x_110); +x_111 = lean_ctor_get(x_73, 5); +lean_inc(x_111); +if (lean_is_exclusive(x_73)) { + lean_ctor_release(x_73, 0); + lean_ctor_release(x_73, 1); + lean_ctor_release(x_73, 2); + lean_ctor_release(x_73, 3); + lean_ctor_release(x_73, 4); + lean_ctor_release(x_73, 5); + x_112 = x_73; +} else { + lean_dec_ref(x_73); + x_112 = lean_box(0); +} +x_113 = lean_ctor_get(x_74, 0); +lean_inc(x_113); +x_114 = lean_ctor_get(x_74, 1); +lean_inc(x_114); +x_115 = lean_ctor_get(x_74, 3); +lean_inc(x_115); +x_116 = lean_ctor_get(x_74, 4); +lean_inc(x_116); +if (lean_is_exclusive(x_74)) { + lean_ctor_release(x_74, 0); + lean_ctor_release(x_74, 1); + lean_ctor_release(x_74, 2); + lean_ctor_release(x_74, 3); + lean_ctor_release(x_74, 4); + x_117 = x_74; +} else { + lean_dec_ref(x_74); + x_117 = lean_box(0); +} +if (lean_is_scalar(x_117)) { + x_118 = lean_alloc_ctor(0, 5, 0); +} else { + x_118 = x_117; +} +lean_ctor_set(x_118, 0, x_113); +lean_ctor_set(x_118, 1, x_114); +lean_ctor_set(x_118, 2, x_21); +lean_ctor_set(x_118, 3, x_115); +lean_ctor_set(x_118, 4, x_116); +if (lean_is_scalar(x_112)) { + x_119 = lean_alloc_ctor(0, 6, 0); +} else { + x_119 = x_112; +} +lean_ctor_set(x_119, 0, x_107); +lean_ctor_set(x_119, 1, x_108); +lean_ctor_set(x_119, 2, x_118); +lean_ctor_set(x_119, 3, x_109); +lean_ctor_set(x_119, 4, x_110); +lean_ctor_set(x_119, 5, x_111); +x_120 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_120, 0, x_119); +lean_ctor_set(x_120, 1, x_102); +lean_ctor_set(x_120, 2, x_103); +lean_ctor_set(x_120, 3, x_104); +lean_ctor_set(x_120, 4, x_105); +lean_ctor_set(x_120, 5, x_106); +if (lean_is_scalar(x_9)) { + x_121 = lean_alloc_ctor(0, 2, 0); +} else { + x_121 = x_9; +} +lean_ctor_set(x_121, 0, x_75); +lean_ctor_set(x_121, 1, x_120); +return x_121; } } } @@ -23824,320 +23901,328 @@ return x_115; } else { -lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; -x_132 = lean_ctor_get(x_14, 0); -x_133 = lean_ctor_get(x_14, 3); -x_134 = lean_ctor_get(x_14, 4); -lean_inc(x_134); -lean_inc(x_133); -lean_inc(x_132); +lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; +x_138 = lean_ctor_get(x_14, 0); +x_139 = lean_ctor_get(x_14, 3); +x_140 = lean_ctor_get(x_14, 4); +lean_inc(x_140); +lean_inc(x_139); +lean_inc(x_138); lean_dec(x_14); lean_inc(x_2); -x_135 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_135, 0, x_132); -lean_ctor_set(x_135, 1, x_1); -lean_ctor_set(x_135, 2, x_2); -lean_ctor_set(x_135, 3, x_133); -lean_ctor_set(x_135, 4, x_134); -lean_ctor_set(x_4, 0, x_135); +x_141 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_141, 0, x_138); +lean_ctor_set(x_141, 1, x_1); +lean_ctor_set(x_141, 2, x_2); +lean_ctor_set(x_141, 3, x_139); +lean_ctor_set(x_141, 4, x_140); +lean_ctor_set(x_4, 0, x_141); if (x_12 == 0) { -lean_object* x_199; +lean_object* x_207; lean_dec(x_7); lean_dec(x_2); -x_199 = lean_box(0); -x_136 = x_199; -goto block_198; +x_207 = lean_box(0); +x_142 = x_207; +goto block_206; } else { -lean_object* x_200; uint8_t x_201; -x_200 = lean_unsigned_to_nat(0u); -x_201 = l_Array_isEqvAux___main___at_Lean_Elab_Term_withLocalContext___spec__1(x_2, x_7, lean_box(0), x_2, x_7, x_200); +lean_object* x_208; uint8_t x_209; +x_208 = lean_unsigned_to_nat(0u); +x_209 = l_Array_isEqvAux___main___at_Lean_Elab_Term_withLocalContext___spec__1(x_2, x_7, lean_box(0), x_2, x_7, x_208); lean_dec(x_7); lean_dec(x_2); -if (x_201 == 0) +if (x_209 == 0) { -lean_object* x_202; -x_202 = lean_box(0); -x_136 = x_202; -goto block_198; +lean_object* x_210; +x_210 = lean_box(0); +x_142 = x_210; +goto block_206; } else { -lean_object* x_203; +lean_object* x_211; lean_dec(x_9); -x_203 = lean_apply_2(x_3, x_4, x_8); -return x_203; +x_211 = lean_apply_2(x_3, x_4, x_8); +return x_211; } } -block_198: +block_206: { -lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_189; lean_object* x_190; lean_object* x_191; -lean_dec(x_136); -x_137 = lean_ctor_get(x_8, 0); -lean_inc(x_137); -x_138 = lean_ctor_get(x_137, 2); -lean_inc(x_138); -lean_dec(x_137); -x_139 = lean_ctor_get(x_138, 2); -lean_inc(x_139); -lean_dec(x_138); -x_189 = l_Lean_Elab_Term_resetSynthInstanceCache___rarg(x_8); -x_190 = lean_ctor_get(x_189, 1); -lean_inc(x_190); -lean_dec(x_189); -x_191 = lean_apply_2(x_3, x_4, x_190); -if (lean_obj_tag(x_191) == 0) +lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_197; lean_object* x_198; lean_object* x_199; +lean_dec(x_142); +x_143 = lean_ctor_get(x_8, 0); +lean_inc(x_143); +x_144 = lean_ctor_get(x_143, 2); +lean_inc(x_144); +lean_dec(x_143); +x_145 = lean_ctor_get(x_144, 2); +lean_inc(x_145); +lean_dec(x_144); +x_197 = l_Lean_Elab_Term_resetSynthInstanceCache___rarg(x_8); +x_198 = lean_ctor_get(x_197, 1); +lean_inc(x_198); +lean_dec(x_197); +x_199 = lean_apply_2(x_3, x_4, x_198); +if (lean_obj_tag(x_199) == 0) { -lean_object* x_192; lean_object* x_193; lean_object* x_194; -x_192 = lean_ctor_get(x_191, 0); -lean_inc(x_192); -x_193 = lean_ctor_get(x_191, 1); -lean_inc(x_193); -lean_dec(x_191); -x_194 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_194, 0, x_192); -x_140 = x_194; -x_141 = x_193; -goto block_188; +lean_object* x_200; lean_object* x_201; lean_object* x_202; +x_200 = lean_ctor_get(x_199, 0); +lean_inc(x_200); +x_201 = lean_ctor_get(x_199, 1); +lean_inc(x_201); +lean_dec(x_199); +x_202 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_202, 0, x_200); +x_146 = x_202; +x_147 = x_201; +goto block_196; } else { -lean_object* x_195; lean_object* x_196; lean_object* x_197; -x_195 = lean_ctor_get(x_191, 0); -lean_inc(x_195); -x_196 = lean_ctor_get(x_191, 1); -lean_inc(x_196); -lean_dec(x_191); -x_197 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_197, 0, x_195); -x_140 = x_197; -x_141 = x_196; -goto block_188; +lean_object* x_203; lean_object* x_204; lean_object* x_205; +x_203 = lean_ctor_get(x_199, 0); +lean_inc(x_203); +x_204 = lean_ctor_get(x_199, 1); +lean_inc(x_204); +lean_dec(x_199); +x_205 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_205, 0, x_203); +x_146 = x_205; +x_147 = x_204; +goto block_196; } -block_188: +block_196: { -if (lean_obj_tag(x_140) == 0) +if (lean_obj_tag(x_146) == 0) { -lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; 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; -x_142 = lean_ctor_get(x_141, 0); -lean_inc(x_142); -x_143 = lean_ctor_get(x_142, 2); -lean_inc(x_143); -x_144 = lean_ctor_get(x_140, 0); -lean_inc(x_144); -lean_dec(x_140); -x_145 = lean_ctor_get(x_141, 1); -lean_inc(x_145); -x_146 = lean_ctor_get(x_141, 2); -lean_inc(x_146); -x_147 = lean_ctor_get(x_141, 3); -lean_inc(x_147); -x_148 = lean_ctor_get(x_141, 4); +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; lean_object* x_169; lean_object* x_170; lean_object* x_171; +x_148 = lean_ctor_get(x_147, 0); lean_inc(x_148); -x_149 = lean_ctor_get(x_141, 5); +x_149 = lean_ctor_get(x_148, 2); lean_inc(x_149); -if (lean_is_exclusive(x_141)) { - lean_ctor_release(x_141, 0); - lean_ctor_release(x_141, 1); - lean_ctor_release(x_141, 2); - lean_ctor_release(x_141, 3); - lean_ctor_release(x_141, 4); - lean_ctor_release(x_141, 5); - x_150 = x_141; -} else { - lean_dec_ref(x_141); - x_150 = lean_box(0); -} -x_151 = lean_ctor_get(x_142, 0); +x_150 = lean_ctor_get(x_146, 0); +lean_inc(x_150); +lean_dec(x_146); +x_151 = lean_ctor_get(x_147, 1); lean_inc(x_151); -x_152 = lean_ctor_get(x_142, 1); +x_152 = lean_ctor_get(x_147, 2); lean_inc(x_152); -x_153 = lean_ctor_get(x_142, 3); +x_153 = lean_ctor_get(x_147, 3); lean_inc(x_153); -x_154 = lean_ctor_get(x_142, 4); +x_154 = lean_ctor_get(x_147, 4); lean_inc(x_154); -x_155 = lean_ctor_get(x_142, 5); +x_155 = lean_ctor_get(x_147, 5); lean_inc(x_155); -if (lean_is_exclusive(x_142)) { - lean_ctor_release(x_142, 0); - lean_ctor_release(x_142, 1); - lean_ctor_release(x_142, 2); - lean_ctor_release(x_142, 3); - lean_ctor_release(x_142, 4); - lean_ctor_release(x_142, 5); - x_156 = x_142; +if (lean_is_exclusive(x_147)) { + lean_ctor_release(x_147, 0); + lean_ctor_release(x_147, 1); + lean_ctor_release(x_147, 2); + lean_ctor_release(x_147, 3); + lean_ctor_release(x_147, 4); + lean_ctor_release(x_147, 5); + x_156 = x_147; } else { - lean_dec_ref(x_142); + lean_dec_ref(x_147); x_156 = lean_box(0); } -x_157 = lean_ctor_get(x_143, 0); +x_157 = lean_ctor_get(x_148, 0); lean_inc(x_157); -x_158 = lean_ctor_get(x_143, 1); +x_158 = lean_ctor_get(x_148, 1); lean_inc(x_158); -x_159 = lean_ctor_get(x_143, 3); +x_159 = lean_ctor_get(x_148, 3); lean_inc(x_159); -if (lean_is_exclusive(x_143)) { - lean_ctor_release(x_143, 0); - lean_ctor_release(x_143, 1); - lean_ctor_release(x_143, 2); - lean_ctor_release(x_143, 3); - x_160 = x_143; +x_160 = lean_ctor_get(x_148, 4); +lean_inc(x_160); +x_161 = lean_ctor_get(x_148, 5); +lean_inc(x_161); +if (lean_is_exclusive(x_148)) { + lean_ctor_release(x_148, 0); + lean_ctor_release(x_148, 1); + lean_ctor_release(x_148, 2); + lean_ctor_release(x_148, 3); + lean_ctor_release(x_148, 4); + lean_ctor_release(x_148, 5); + x_162 = x_148; } else { - lean_dec_ref(x_143); - x_160 = lean_box(0); + lean_dec_ref(x_148); + x_162 = lean_box(0); } -if (lean_is_scalar(x_160)) { - x_161 = lean_alloc_ctor(0, 4, 0); -} else { - x_161 = x_160; -} -lean_ctor_set(x_161, 0, x_157); -lean_ctor_set(x_161, 1, x_158); -lean_ctor_set(x_161, 2, x_139); -lean_ctor_set(x_161, 3, x_159); -if (lean_is_scalar(x_156)) { - x_162 = lean_alloc_ctor(0, 6, 0); -} else { - x_162 = x_156; -} -lean_ctor_set(x_162, 0, x_151); -lean_ctor_set(x_162, 1, x_152); -lean_ctor_set(x_162, 2, x_161); -lean_ctor_set(x_162, 3, x_153); -lean_ctor_set(x_162, 4, x_154); -lean_ctor_set(x_162, 5, x_155); -if (lean_is_scalar(x_150)) { - x_163 = lean_alloc_ctor(0, 6, 0); -} else { - x_163 = x_150; -} -lean_ctor_set(x_163, 0, x_162); -lean_ctor_set(x_163, 1, x_145); -lean_ctor_set(x_163, 2, x_146); -lean_ctor_set(x_163, 3, x_147); -lean_ctor_set(x_163, 4, x_148); -lean_ctor_set(x_163, 5, x_149); -if (lean_is_scalar(x_9)) { - x_164 = lean_alloc_ctor(1, 2, 0); -} else { - x_164 = x_9; - lean_ctor_set_tag(x_164, 1); -} -lean_ctor_set(x_164, 0, x_144); -lean_ctor_set(x_164, 1, x_163); -return x_164; -} -else -{ -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_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; -x_165 = lean_ctor_get(x_141, 0); +x_163 = lean_ctor_get(x_149, 0); +lean_inc(x_163); +x_164 = lean_ctor_get(x_149, 1); +lean_inc(x_164); +x_165 = lean_ctor_get(x_149, 3); lean_inc(x_165); -x_166 = lean_ctor_get(x_165, 2); +x_166 = lean_ctor_get(x_149, 4); lean_inc(x_166); -x_167 = lean_ctor_get(x_140, 0); -lean_inc(x_167); -lean_dec(x_140); -x_168 = lean_ctor_get(x_141, 1); -lean_inc(x_168); -x_169 = lean_ctor_get(x_141, 2); -lean_inc(x_169); -x_170 = lean_ctor_get(x_141, 3); -lean_inc(x_170); -x_171 = lean_ctor_get(x_141, 4); -lean_inc(x_171); -x_172 = lean_ctor_get(x_141, 5); -lean_inc(x_172); -if (lean_is_exclusive(x_141)) { - lean_ctor_release(x_141, 0); - lean_ctor_release(x_141, 1); - lean_ctor_release(x_141, 2); - lean_ctor_release(x_141, 3); - lean_ctor_release(x_141, 4); - lean_ctor_release(x_141, 5); - x_173 = x_141; +if (lean_is_exclusive(x_149)) { + lean_ctor_release(x_149, 0); + lean_ctor_release(x_149, 1); + lean_ctor_release(x_149, 2); + lean_ctor_release(x_149, 3); + lean_ctor_release(x_149, 4); + x_167 = x_149; } else { - lean_dec_ref(x_141); - x_173 = lean_box(0); + lean_dec_ref(x_149); + x_167 = lean_box(0); } -x_174 = lean_ctor_get(x_165, 0); -lean_inc(x_174); -x_175 = lean_ctor_get(x_165, 1); -lean_inc(x_175); -x_176 = lean_ctor_get(x_165, 3); -lean_inc(x_176); -x_177 = lean_ctor_get(x_165, 4); -lean_inc(x_177); -x_178 = lean_ctor_get(x_165, 5); -lean_inc(x_178); -if (lean_is_exclusive(x_165)) { - lean_ctor_release(x_165, 0); - lean_ctor_release(x_165, 1); - lean_ctor_release(x_165, 2); - lean_ctor_release(x_165, 3); - lean_ctor_release(x_165, 4); - lean_ctor_release(x_165, 5); - x_179 = x_165; +if (lean_is_scalar(x_167)) { + x_168 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_165); - x_179 = lean_box(0); + x_168 = x_167; } -x_180 = lean_ctor_get(x_166, 0); -lean_inc(x_180); -x_181 = lean_ctor_get(x_166, 1); -lean_inc(x_181); -x_182 = lean_ctor_get(x_166, 3); -lean_inc(x_182); -if (lean_is_exclusive(x_166)) { - lean_ctor_release(x_166, 0); - lean_ctor_release(x_166, 1); - lean_ctor_release(x_166, 2); - lean_ctor_release(x_166, 3); - x_183 = x_166; +lean_ctor_set(x_168, 0, x_163); +lean_ctor_set(x_168, 1, x_164); +lean_ctor_set(x_168, 2, x_145); +lean_ctor_set(x_168, 3, x_165); +lean_ctor_set(x_168, 4, x_166); +if (lean_is_scalar(x_162)) { + x_169 = lean_alloc_ctor(0, 6, 0); } else { - lean_dec_ref(x_166); - x_183 = lean_box(0); + x_169 = x_162; } -if (lean_is_scalar(x_183)) { - x_184 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_169, 0, x_157); +lean_ctor_set(x_169, 1, x_158); +lean_ctor_set(x_169, 2, x_168); +lean_ctor_set(x_169, 3, x_159); +lean_ctor_set(x_169, 4, x_160); +lean_ctor_set(x_169, 5, x_161); +if (lean_is_scalar(x_156)) { + x_170 = lean_alloc_ctor(0, 6, 0); } else { - x_184 = x_183; + x_170 = x_156; } -lean_ctor_set(x_184, 0, x_180); -lean_ctor_set(x_184, 1, x_181); -lean_ctor_set(x_184, 2, x_139); -lean_ctor_set(x_184, 3, x_182); -if (lean_is_scalar(x_179)) { - x_185 = lean_alloc_ctor(0, 6, 0); -} else { - x_185 = x_179; -} -lean_ctor_set(x_185, 0, x_174); -lean_ctor_set(x_185, 1, x_175); -lean_ctor_set(x_185, 2, x_184); -lean_ctor_set(x_185, 3, x_176); -lean_ctor_set(x_185, 4, x_177); -lean_ctor_set(x_185, 5, x_178); -if (lean_is_scalar(x_173)) { - x_186 = lean_alloc_ctor(0, 6, 0); -} else { - x_186 = x_173; -} -lean_ctor_set(x_186, 0, x_185); -lean_ctor_set(x_186, 1, x_168); -lean_ctor_set(x_186, 2, x_169); -lean_ctor_set(x_186, 3, x_170); -lean_ctor_set(x_186, 4, x_171); -lean_ctor_set(x_186, 5, x_172); +lean_ctor_set(x_170, 0, x_169); +lean_ctor_set(x_170, 1, x_151); +lean_ctor_set(x_170, 2, x_152); +lean_ctor_set(x_170, 3, x_153); +lean_ctor_set(x_170, 4, x_154); +lean_ctor_set(x_170, 5, x_155); if (lean_is_scalar(x_9)) { - x_187 = lean_alloc_ctor(0, 2, 0); + x_171 = lean_alloc_ctor(1, 2, 0); } else { - x_187 = x_9; + x_171 = x_9; + lean_ctor_set_tag(x_171, 1); } -lean_ctor_set(x_187, 0, x_167); -lean_ctor_set(x_187, 1, x_186); -return x_187; +lean_ctor_set(x_171, 0, x_150); +lean_ctor_set(x_171, 1, x_170); +return x_171; +} +else +{ +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; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; +x_172 = lean_ctor_get(x_147, 0); +lean_inc(x_172); +x_173 = lean_ctor_get(x_172, 2); +lean_inc(x_173); +x_174 = lean_ctor_get(x_146, 0); +lean_inc(x_174); +lean_dec(x_146); +x_175 = lean_ctor_get(x_147, 1); +lean_inc(x_175); +x_176 = lean_ctor_get(x_147, 2); +lean_inc(x_176); +x_177 = lean_ctor_get(x_147, 3); +lean_inc(x_177); +x_178 = lean_ctor_get(x_147, 4); +lean_inc(x_178); +x_179 = lean_ctor_get(x_147, 5); +lean_inc(x_179); +if (lean_is_exclusive(x_147)) { + lean_ctor_release(x_147, 0); + lean_ctor_release(x_147, 1); + lean_ctor_release(x_147, 2); + lean_ctor_release(x_147, 3); + lean_ctor_release(x_147, 4); + lean_ctor_release(x_147, 5); + x_180 = x_147; +} else { + lean_dec_ref(x_147); + x_180 = lean_box(0); +} +x_181 = lean_ctor_get(x_172, 0); +lean_inc(x_181); +x_182 = lean_ctor_get(x_172, 1); +lean_inc(x_182); +x_183 = lean_ctor_get(x_172, 3); +lean_inc(x_183); +x_184 = lean_ctor_get(x_172, 4); +lean_inc(x_184); +x_185 = lean_ctor_get(x_172, 5); +lean_inc(x_185); +if (lean_is_exclusive(x_172)) { + lean_ctor_release(x_172, 0); + lean_ctor_release(x_172, 1); + lean_ctor_release(x_172, 2); + lean_ctor_release(x_172, 3); + lean_ctor_release(x_172, 4); + lean_ctor_release(x_172, 5); + x_186 = x_172; +} else { + lean_dec_ref(x_172); + x_186 = lean_box(0); +} +x_187 = lean_ctor_get(x_173, 0); +lean_inc(x_187); +x_188 = lean_ctor_get(x_173, 1); +lean_inc(x_188); +x_189 = lean_ctor_get(x_173, 3); +lean_inc(x_189); +x_190 = lean_ctor_get(x_173, 4); +lean_inc(x_190); +if (lean_is_exclusive(x_173)) { + lean_ctor_release(x_173, 0); + lean_ctor_release(x_173, 1); + lean_ctor_release(x_173, 2); + lean_ctor_release(x_173, 3); + lean_ctor_release(x_173, 4); + x_191 = x_173; +} else { + lean_dec_ref(x_173); + x_191 = lean_box(0); +} +if (lean_is_scalar(x_191)) { + x_192 = lean_alloc_ctor(0, 5, 0); +} else { + x_192 = x_191; +} +lean_ctor_set(x_192, 0, x_187); +lean_ctor_set(x_192, 1, x_188); +lean_ctor_set(x_192, 2, x_145); +lean_ctor_set(x_192, 3, x_189); +lean_ctor_set(x_192, 4, x_190); +if (lean_is_scalar(x_186)) { + x_193 = lean_alloc_ctor(0, 6, 0); +} else { + x_193 = x_186; +} +lean_ctor_set(x_193, 0, x_181); +lean_ctor_set(x_193, 1, x_182); +lean_ctor_set(x_193, 2, x_192); +lean_ctor_set(x_193, 3, x_183); +lean_ctor_set(x_193, 4, x_184); +lean_ctor_set(x_193, 5, x_185); +if (lean_is_scalar(x_180)) { + x_194 = lean_alloc_ctor(0, 6, 0); +} else { + x_194 = x_180; +} +lean_ctor_set(x_194, 0, x_193); +lean_ctor_set(x_194, 1, x_175); +lean_ctor_set(x_194, 2, x_176); +lean_ctor_set(x_194, 3, x_177); +lean_ctor_set(x_194, 4, x_178); +lean_ctor_set(x_194, 5, x_179); +if (lean_is_scalar(x_9)) { + x_195 = lean_alloc_ctor(0, 2, 0); +} else { + x_195 = x_9; +} +lean_ctor_set(x_195, 0, x_174); +lean_ctor_set(x_195, 1, x_194); +return x_195; } } } @@ -24145,371 +24230,379 @@ return x_187; } else { -lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; uint8_t x_214; uint8_t x_215; uint8_t x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; -x_204 = lean_ctor_get(x_4, 0); -x_205 = lean_ctor_get(x_4, 1); -x_206 = lean_ctor_get(x_4, 2); -x_207 = lean_ctor_get(x_4, 3); -x_208 = lean_ctor_get(x_4, 4); -x_209 = lean_ctor_get(x_4, 5); -x_210 = lean_ctor_get(x_4, 6); -x_211 = lean_ctor_get(x_4, 7); -x_212 = lean_ctor_get(x_4, 8); -x_213 = lean_ctor_get(x_4, 9); -x_214 = lean_ctor_get_uint8(x_4, sizeof(void*)*10); -x_215 = lean_ctor_get_uint8(x_4, sizeof(void*)*10 + 1); -x_216 = lean_ctor_get_uint8(x_4, sizeof(void*)*10 + 2); +lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; uint8_t x_222; uint8_t x_223; uint8_t 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; lean_object* x_231; +x_212 = lean_ctor_get(x_4, 0); +x_213 = lean_ctor_get(x_4, 1); +x_214 = lean_ctor_get(x_4, 2); +x_215 = lean_ctor_get(x_4, 3); +x_216 = lean_ctor_get(x_4, 4); +x_217 = lean_ctor_get(x_4, 5); +x_218 = lean_ctor_get(x_4, 6); +x_219 = lean_ctor_get(x_4, 7); +x_220 = lean_ctor_get(x_4, 8); +x_221 = lean_ctor_get(x_4, 9); +x_222 = lean_ctor_get_uint8(x_4, sizeof(void*)*10); +x_223 = lean_ctor_get_uint8(x_4, sizeof(void*)*10 + 1); +x_224 = lean_ctor_get_uint8(x_4, sizeof(void*)*10 + 2); +lean_inc(x_221); +lean_inc(x_220); +lean_inc(x_219); +lean_inc(x_218); +lean_inc(x_217); +lean_inc(x_216); +lean_inc(x_215); +lean_inc(x_214); lean_inc(x_213); lean_inc(x_212); -lean_inc(x_211); -lean_inc(x_210); -lean_inc(x_209); -lean_inc(x_208); -lean_inc(x_207); -lean_inc(x_206); -lean_inc(x_205); -lean_inc(x_204); lean_dec(x_4); -x_217 = lean_ctor_get(x_204, 0); -lean_inc(x_217); -x_218 = lean_ctor_get(x_204, 3); -lean_inc(x_218); -x_219 = lean_ctor_get(x_204, 4); -lean_inc(x_219); -if (lean_is_exclusive(x_204)) { - lean_ctor_release(x_204, 0); - lean_ctor_release(x_204, 1); - lean_ctor_release(x_204, 2); - lean_ctor_release(x_204, 3); - lean_ctor_release(x_204, 4); - x_220 = x_204; +x_225 = lean_ctor_get(x_212, 0); +lean_inc(x_225); +x_226 = lean_ctor_get(x_212, 3); +lean_inc(x_226); +x_227 = lean_ctor_get(x_212, 4); +lean_inc(x_227); +if (lean_is_exclusive(x_212)) { + lean_ctor_release(x_212, 0); + lean_ctor_release(x_212, 1); + lean_ctor_release(x_212, 2); + lean_ctor_release(x_212, 3); + lean_ctor_release(x_212, 4); + x_228 = x_212; } else { - lean_dec_ref(x_204); - x_220 = lean_box(0); + lean_dec_ref(x_212); + x_228 = lean_box(0); } lean_inc(x_2); -if (lean_is_scalar(x_220)) { - x_221 = lean_alloc_ctor(0, 5, 0); +if (lean_is_scalar(x_228)) { + x_229 = lean_alloc_ctor(0, 5, 0); } else { - x_221 = x_220; + x_229 = x_228; } -lean_ctor_set(x_221, 0, x_217); -lean_ctor_set(x_221, 1, x_1); -lean_ctor_set(x_221, 2, x_2); -lean_ctor_set(x_221, 3, x_218); -lean_ctor_set(x_221, 4, x_219); -x_222 = lean_alloc_ctor(0, 10, 3); -lean_ctor_set(x_222, 0, x_221); -lean_ctor_set(x_222, 1, x_205); -lean_ctor_set(x_222, 2, x_206); -lean_ctor_set(x_222, 3, x_207); -lean_ctor_set(x_222, 4, x_208); -lean_ctor_set(x_222, 5, x_209); -lean_ctor_set(x_222, 6, x_210); -lean_ctor_set(x_222, 7, x_211); -lean_ctor_set(x_222, 8, x_212); -lean_ctor_set(x_222, 9, x_213); -lean_ctor_set_uint8(x_222, sizeof(void*)*10, x_214); -lean_ctor_set_uint8(x_222, sizeof(void*)*10 + 1, x_215); -lean_ctor_set_uint8(x_222, sizeof(void*)*10 + 2, x_216); +lean_ctor_set(x_229, 0, x_225); +lean_ctor_set(x_229, 1, x_1); +lean_ctor_set(x_229, 2, x_2); +lean_ctor_set(x_229, 3, x_226); +lean_ctor_set(x_229, 4, x_227); +x_230 = lean_alloc_ctor(0, 10, 3); +lean_ctor_set(x_230, 0, x_229); +lean_ctor_set(x_230, 1, x_213); +lean_ctor_set(x_230, 2, x_214); +lean_ctor_set(x_230, 3, x_215); +lean_ctor_set(x_230, 4, x_216); +lean_ctor_set(x_230, 5, x_217); +lean_ctor_set(x_230, 6, x_218); +lean_ctor_set(x_230, 7, x_219); +lean_ctor_set(x_230, 8, x_220); +lean_ctor_set(x_230, 9, x_221); +lean_ctor_set_uint8(x_230, sizeof(void*)*10, x_222); +lean_ctor_set_uint8(x_230, sizeof(void*)*10 + 1, x_223); +lean_ctor_set_uint8(x_230, sizeof(void*)*10 + 2, x_224); if (x_12 == 0) { -lean_object* x_286; +lean_object* x_296; lean_dec(x_7); lean_dec(x_2); -x_286 = lean_box(0); -x_223 = x_286; -goto block_285; +x_296 = lean_box(0); +x_231 = x_296; +goto block_295; } else { -lean_object* x_287; uint8_t x_288; -x_287 = lean_unsigned_to_nat(0u); -x_288 = l_Array_isEqvAux___main___at_Lean_Elab_Term_withLocalContext___spec__1(x_2, x_7, lean_box(0), x_2, x_7, x_287); +lean_object* x_297; uint8_t x_298; +x_297 = lean_unsigned_to_nat(0u); +x_298 = l_Array_isEqvAux___main___at_Lean_Elab_Term_withLocalContext___spec__1(x_2, x_7, lean_box(0), x_2, x_7, x_297); lean_dec(x_7); lean_dec(x_2); -if (x_288 == 0) +if (x_298 == 0) { -lean_object* x_289; -x_289 = lean_box(0); -x_223 = x_289; -goto block_285; +lean_object* x_299; +x_299 = lean_box(0); +x_231 = x_299; +goto block_295; } else { -lean_object* x_290; +lean_object* x_300; lean_dec(x_9); -x_290 = lean_apply_2(x_3, x_222, x_8); -return x_290; +x_300 = lean_apply_2(x_3, x_230, x_8); +return x_300; } } +block_295: +{ +lean_object* x_232; lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_object* x_236; lean_object* x_286; lean_object* x_287; lean_object* x_288; +lean_dec(x_231); +x_232 = lean_ctor_get(x_8, 0); +lean_inc(x_232); +x_233 = lean_ctor_get(x_232, 2); +lean_inc(x_233); +lean_dec(x_232); +x_234 = lean_ctor_get(x_233, 2); +lean_inc(x_234); +lean_dec(x_233); +x_286 = l_Lean_Elab_Term_resetSynthInstanceCache___rarg(x_8); +x_287 = lean_ctor_get(x_286, 1); +lean_inc(x_287); +lean_dec(x_286); +x_288 = lean_apply_2(x_3, x_230, x_287); +if (lean_obj_tag(x_288) == 0) +{ +lean_object* x_289; lean_object* x_290; lean_object* x_291; +x_289 = lean_ctor_get(x_288, 0); +lean_inc(x_289); +x_290 = lean_ctor_get(x_288, 1); +lean_inc(x_290); +lean_dec(x_288); +x_291 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_291, 0, x_289); +x_235 = x_291; +x_236 = x_290; +goto block_285; +} +else +{ +lean_object* x_292; lean_object* x_293; lean_object* x_294; +x_292 = lean_ctor_get(x_288, 0); +lean_inc(x_292); +x_293 = lean_ctor_get(x_288, 1); +lean_inc(x_293); +lean_dec(x_288); +x_294 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_294, 0, x_292); +x_235 = x_294; +x_236 = x_293; +goto block_285; +} block_285: { -lean_object* x_224; lean_object* x_225; lean_object* x_226; lean_object* x_227; lean_object* x_228; lean_object* x_276; lean_object* x_277; lean_object* x_278; -lean_dec(x_223); -x_224 = lean_ctor_get(x_8, 0); -lean_inc(x_224); -x_225 = lean_ctor_get(x_224, 2); -lean_inc(x_225); -lean_dec(x_224); -x_226 = lean_ctor_get(x_225, 2); -lean_inc(x_226); -lean_dec(x_225); -x_276 = l_Lean_Elab_Term_resetSynthInstanceCache___rarg(x_8); -x_277 = lean_ctor_get(x_276, 1); -lean_inc(x_277); -lean_dec(x_276); -x_278 = lean_apply_2(x_3, x_222, x_277); -if (lean_obj_tag(x_278) == 0) +if (lean_obj_tag(x_235) == 0) { -lean_object* x_279; lean_object* x_280; lean_object* x_281; -x_279 = lean_ctor_get(x_278, 0); -lean_inc(x_279); -x_280 = lean_ctor_get(x_278, 1); -lean_inc(x_280); -lean_dec(x_278); -x_281 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_281, 0, x_279); -x_227 = x_281; -x_228 = x_280; -goto block_275; -} -else -{ -lean_object* x_282; lean_object* x_283; lean_object* x_284; -x_282 = lean_ctor_get(x_278, 0); -lean_inc(x_282); -x_283 = lean_ctor_get(x_278, 1); -lean_inc(x_283); -lean_dec(x_278); -x_284 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_284, 0, x_282); -x_227 = x_284; -x_228 = x_283; -goto block_275; -} -block_275: -{ -if (lean_obj_tag(x_227) == 0) -{ -lean_object* x_229; lean_object* x_230; lean_object* x_231; lean_object* x_232; lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_object* x_236; lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_object* x_240; 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_229 = lean_ctor_get(x_228, 0); -lean_inc(x_229); -x_230 = lean_ctor_get(x_229, 2); -lean_inc(x_230); -x_231 = lean_ctor_get(x_227, 0); -lean_inc(x_231); -lean_dec(x_227); -x_232 = lean_ctor_get(x_228, 1); -lean_inc(x_232); -x_233 = lean_ctor_get(x_228, 2); -lean_inc(x_233); -x_234 = lean_ctor_get(x_228, 3); -lean_inc(x_234); -x_235 = lean_ctor_get(x_228, 4); -lean_inc(x_235); -x_236 = lean_ctor_get(x_228, 5); -lean_inc(x_236); -if (lean_is_exclusive(x_228)) { - lean_ctor_release(x_228, 0); - lean_ctor_release(x_228, 1); - lean_ctor_release(x_228, 2); - lean_ctor_release(x_228, 3); - lean_ctor_release(x_228, 4); - lean_ctor_release(x_228, 5); - x_237 = x_228; -} else { - lean_dec_ref(x_228); - x_237 = lean_box(0); -} -x_238 = lean_ctor_get(x_229, 0); +lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; lean_object* x_242; lean_object* x_243; lean_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; lean_object* x_252; lean_object* x_253; lean_object* x_254; lean_object* x_255; lean_object* x_256; lean_object* x_257; lean_object* x_258; lean_object* x_259; lean_object* x_260; +x_237 = lean_ctor_get(x_236, 0); +lean_inc(x_237); +x_238 = lean_ctor_get(x_237, 2); lean_inc(x_238); -x_239 = lean_ctor_get(x_229, 1); +x_239 = lean_ctor_get(x_235, 0); lean_inc(x_239); -x_240 = lean_ctor_get(x_229, 3); +lean_dec(x_235); +x_240 = lean_ctor_get(x_236, 1); lean_inc(x_240); -x_241 = lean_ctor_get(x_229, 4); +x_241 = lean_ctor_get(x_236, 2); lean_inc(x_241); -x_242 = lean_ctor_get(x_229, 5); +x_242 = lean_ctor_get(x_236, 3); lean_inc(x_242); -if (lean_is_exclusive(x_229)) { - lean_ctor_release(x_229, 0); - lean_ctor_release(x_229, 1); - lean_ctor_release(x_229, 2); - lean_ctor_release(x_229, 3); - lean_ctor_release(x_229, 4); - lean_ctor_release(x_229, 5); - x_243 = x_229; -} else { - lean_dec_ref(x_229); - x_243 = lean_box(0); -} -x_244 = lean_ctor_get(x_230, 0); +x_243 = lean_ctor_get(x_236, 4); +lean_inc(x_243); +x_244 = lean_ctor_get(x_236, 5); lean_inc(x_244); -x_245 = lean_ctor_get(x_230, 1); -lean_inc(x_245); -x_246 = lean_ctor_get(x_230, 3); +if (lean_is_exclusive(x_236)) { + lean_ctor_release(x_236, 0); + lean_ctor_release(x_236, 1); + lean_ctor_release(x_236, 2); + lean_ctor_release(x_236, 3); + lean_ctor_release(x_236, 4); + lean_ctor_release(x_236, 5); + x_245 = x_236; +} else { + lean_dec_ref(x_236); + x_245 = lean_box(0); +} +x_246 = lean_ctor_get(x_237, 0); lean_inc(x_246); -if (lean_is_exclusive(x_230)) { - lean_ctor_release(x_230, 0); - lean_ctor_release(x_230, 1); - lean_ctor_release(x_230, 2); - lean_ctor_release(x_230, 3); - x_247 = x_230; +x_247 = lean_ctor_get(x_237, 1); +lean_inc(x_247); +x_248 = lean_ctor_get(x_237, 3); +lean_inc(x_248); +x_249 = lean_ctor_get(x_237, 4); +lean_inc(x_249); +x_250 = lean_ctor_get(x_237, 5); +lean_inc(x_250); +if (lean_is_exclusive(x_237)) { + lean_ctor_release(x_237, 0); + lean_ctor_release(x_237, 1); + lean_ctor_release(x_237, 2); + lean_ctor_release(x_237, 3); + lean_ctor_release(x_237, 4); + lean_ctor_release(x_237, 5); + x_251 = x_237; } else { - lean_dec_ref(x_230); - x_247 = lean_box(0); + lean_dec_ref(x_237); + x_251 = lean_box(0); } -if (lean_is_scalar(x_247)) { - x_248 = lean_alloc_ctor(0, 4, 0); +x_252 = lean_ctor_get(x_238, 0); +lean_inc(x_252); +x_253 = lean_ctor_get(x_238, 1); +lean_inc(x_253); +x_254 = lean_ctor_get(x_238, 3); +lean_inc(x_254); +x_255 = lean_ctor_get(x_238, 4); +lean_inc(x_255); +if (lean_is_exclusive(x_238)) { + lean_ctor_release(x_238, 0); + lean_ctor_release(x_238, 1); + lean_ctor_release(x_238, 2); + lean_ctor_release(x_238, 3); + lean_ctor_release(x_238, 4); + x_256 = x_238; } else { - x_248 = x_247; + lean_dec_ref(x_238); + x_256 = lean_box(0); } -lean_ctor_set(x_248, 0, x_244); -lean_ctor_set(x_248, 1, x_245); -lean_ctor_set(x_248, 2, x_226); -lean_ctor_set(x_248, 3, x_246); -if (lean_is_scalar(x_243)) { - x_249 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_256)) { + x_257 = lean_alloc_ctor(0, 5, 0); } else { - x_249 = x_243; + x_257 = x_256; } -lean_ctor_set(x_249, 0, x_238); -lean_ctor_set(x_249, 1, x_239); -lean_ctor_set(x_249, 2, x_248); -lean_ctor_set(x_249, 3, x_240); -lean_ctor_set(x_249, 4, x_241); -lean_ctor_set(x_249, 5, x_242); -if (lean_is_scalar(x_237)) { - x_250 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_257, 0, x_252); +lean_ctor_set(x_257, 1, x_253); +lean_ctor_set(x_257, 2, x_234); +lean_ctor_set(x_257, 3, x_254); +lean_ctor_set(x_257, 4, x_255); +if (lean_is_scalar(x_251)) { + x_258 = lean_alloc_ctor(0, 6, 0); } else { - x_250 = x_237; + x_258 = x_251; } -lean_ctor_set(x_250, 0, x_249); -lean_ctor_set(x_250, 1, x_232); -lean_ctor_set(x_250, 2, x_233); -lean_ctor_set(x_250, 3, x_234); -lean_ctor_set(x_250, 4, x_235); -lean_ctor_set(x_250, 5, x_236); +lean_ctor_set(x_258, 0, x_246); +lean_ctor_set(x_258, 1, x_247); +lean_ctor_set(x_258, 2, x_257); +lean_ctor_set(x_258, 3, x_248); +lean_ctor_set(x_258, 4, x_249); +lean_ctor_set(x_258, 5, x_250); +if (lean_is_scalar(x_245)) { + x_259 = lean_alloc_ctor(0, 6, 0); +} else { + x_259 = x_245; +} +lean_ctor_set(x_259, 0, x_258); +lean_ctor_set(x_259, 1, x_240); +lean_ctor_set(x_259, 2, x_241); +lean_ctor_set(x_259, 3, x_242); +lean_ctor_set(x_259, 4, x_243); +lean_ctor_set(x_259, 5, x_244); if (lean_is_scalar(x_9)) { - x_251 = lean_alloc_ctor(1, 2, 0); + x_260 = lean_alloc_ctor(1, 2, 0); } else { - x_251 = x_9; - lean_ctor_set_tag(x_251, 1); + x_260 = x_9; + lean_ctor_set_tag(x_260, 1); } -lean_ctor_set(x_251, 0, x_231); -lean_ctor_set(x_251, 1, x_250); -return x_251; +lean_ctor_set(x_260, 0, x_239); +lean_ctor_set(x_260, 1, x_259); +return x_260; } else { -lean_object* x_252; lean_object* x_253; lean_object* x_254; lean_object* x_255; lean_object* x_256; lean_object* x_257; lean_object* x_258; lean_object* x_259; lean_object* x_260; lean_object* x_261; lean_object* x_262; lean_object* x_263; lean_object* x_264; lean_object* x_265; lean_object* x_266; lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_object* x_270; lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; -x_252 = lean_ctor_get(x_228, 0); -lean_inc(x_252); -x_253 = lean_ctor_get(x_252, 2); -lean_inc(x_253); -x_254 = lean_ctor_get(x_227, 0); -lean_inc(x_254); -lean_dec(x_227); -x_255 = lean_ctor_get(x_228, 1); -lean_inc(x_255); -x_256 = lean_ctor_get(x_228, 2); -lean_inc(x_256); -x_257 = lean_ctor_get(x_228, 3); -lean_inc(x_257); -x_258 = lean_ctor_get(x_228, 4); -lean_inc(x_258); -x_259 = lean_ctor_get(x_228, 5); -lean_inc(x_259); -if (lean_is_exclusive(x_228)) { - lean_ctor_release(x_228, 0); - lean_ctor_release(x_228, 1); - lean_ctor_release(x_228, 2); - lean_ctor_release(x_228, 3); - lean_ctor_release(x_228, 4); - lean_ctor_release(x_228, 5); - x_260 = x_228; -} else { - lean_dec_ref(x_228); - x_260 = lean_box(0); -} -x_261 = lean_ctor_get(x_252, 0); +lean_object* x_261; lean_object* x_262; lean_object* x_263; lean_object* x_264; lean_object* x_265; lean_object* x_266; lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_object* x_270; lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_object* x_276; lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; lean_object* x_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; +x_261 = lean_ctor_get(x_236, 0); lean_inc(x_261); -x_262 = lean_ctor_get(x_252, 1); +x_262 = lean_ctor_get(x_261, 2); lean_inc(x_262); -x_263 = lean_ctor_get(x_252, 3); +x_263 = lean_ctor_get(x_235, 0); lean_inc(x_263); -x_264 = lean_ctor_get(x_252, 4); +lean_dec(x_235); +x_264 = lean_ctor_get(x_236, 1); lean_inc(x_264); -x_265 = lean_ctor_get(x_252, 5); +x_265 = lean_ctor_get(x_236, 2); lean_inc(x_265); -if (lean_is_exclusive(x_252)) { - lean_ctor_release(x_252, 0); - lean_ctor_release(x_252, 1); - lean_ctor_release(x_252, 2); - lean_ctor_release(x_252, 3); - lean_ctor_release(x_252, 4); - lean_ctor_release(x_252, 5); - x_266 = x_252; -} else { - lean_dec_ref(x_252); - x_266 = lean_box(0); -} -x_267 = lean_ctor_get(x_253, 0); +x_266 = lean_ctor_get(x_236, 3); +lean_inc(x_266); +x_267 = lean_ctor_get(x_236, 4); lean_inc(x_267); -x_268 = lean_ctor_get(x_253, 1); +x_268 = lean_ctor_get(x_236, 5); lean_inc(x_268); -x_269 = lean_ctor_get(x_253, 3); -lean_inc(x_269); -if (lean_is_exclusive(x_253)) { - lean_ctor_release(x_253, 0); - lean_ctor_release(x_253, 1); - lean_ctor_release(x_253, 2); - lean_ctor_release(x_253, 3); - x_270 = x_253; +if (lean_is_exclusive(x_236)) { + lean_ctor_release(x_236, 0); + lean_ctor_release(x_236, 1); + lean_ctor_release(x_236, 2); + lean_ctor_release(x_236, 3); + lean_ctor_release(x_236, 4); + lean_ctor_release(x_236, 5); + x_269 = x_236; } else { - lean_dec_ref(x_253); - x_270 = lean_box(0); + lean_dec_ref(x_236); + x_269 = lean_box(0); } -if (lean_is_scalar(x_270)) { - x_271 = lean_alloc_ctor(0, 4, 0); +x_270 = lean_ctor_get(x_261, 0); +lean_inc(x_270); +x_271 = lean_ctor_get(x_261, 1); +lean_inc(x_271); +x_272 = lean_ctor_get(x_261, 3); +lean_inc(x_272); +x_273 = lean_ctor_get(x_261, 4); +lean_inc(x_273); +x_274 = lean_ctor_get(x_261, 5); +lean_inc(x_274); +if (lean_is_exclusive(x_261)) { + lean_ctor_release(x_261, 0); + lean_ctor_release(x_261, 1); + lean_ctor_release(x_261, 2); + lean_ctor_release(x_261, 3); + lean_ctor_release(x_261, 4); + lean_ctor_release(x_261, 5); + x_275 = x_261; } else { - x_271 = x_270; + lean_dec_ref(x_261); + x_275 = lean_box(0); } -lean_ctor_set(x_271, 0, x_267); -lean_ctor_set(x_271, 1, x_268); -lean_ctor_set(x_271, 2, x_226); -lean_ctor_set(x_271, 3, x_269); -if (lean_is_scalar(x_266)) { - x_272 = lean_alloc_ctor(0, 6, 0); +x_276 = lean_ctor_get(x_262, 0); +lean_inc(x_276); +x_277 = lean_ctor_get(x_262, 1); +lean_inc(x_277); +x_278 = lean_ctor_get(x_262, 3); +lean_inc(x_278); +x_279 = lean_ctor_get(x_262, 4); +lean_inc(x_279); +if (lean_is_exclusive(x_262)) { + lean_ctor_release(x_262, 0); + lean_ctor_release(x_262, 1); + lean_ctor_release(x_262, 2); + lean_ctor_release(x_262, 3); + lean_ctor_release(x_262, 4); + x_280 = x_262; } else { - x_272 = x_266; + lean_dec_ref(x_262); + x_280 = lean_box(0); } -lean_ctor_set(x_272, 0, x_261); -lean_ctor_set(x_272, 1, x_262); -lean_ctor_set(x_272, 2, x_271); -lean_ctor_set(x_272, 3, x_263); -lean_ctor_set(x_272, 4, x_264); -lean_ctor_set(x_272, 5, x_265); -if (lean_is_scalar(x_260)) { - x_273 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_280)) { + x_281 = lean_alloc_ctor(0, 5, 0); } else { - x_273 = x_260; + x_281 = x_280; } -lean_ctor_set(x_273, 0, x_272); -lean_ctor_set(x_273, 1, x_255); -lean_ctor_set(x_273, 2, x_256); -lean_ctor_set(x_273, 3, x_257); -lean_ctor_set(x_273, 4, x_258); -lean_ctor_set(x_273, 5, x_259); +lean_ctor_set(x_281, 0, x_276); +lean_ctor_set(x_281, 1, x_277); +lean_ctor_set(x_281, 2, x_234); +lean_ctor_set(x_281, 3, x_278); +lean_ctor_set(x_281, 4, x_279); +if (lean_is_scalar(x_275)) { + x_282 = lean_alloc_ctor(0, 6, 0); +} else { + x_282 = x_275; +} +lean_ctor_set(x_282, 0, x_270); +lean_ctor_set(x_282, 1, x_271); +lean_ctor_set(x_282, 2, x_281); +lean_ctor_set(x_282, 3, x_272); +lean_ctor_set(x_282, 4, x_273); +lean_ctor_set(x_282, 5, x_274); +if (lean_is_scalar(x_269)) { + x_283 = lean_alloc_ctor(0, 6, 0); +} else { + x_283 = x_269; +} +lean_ctor_set(x_283, 0, x_282); +lean_ctor_set(x_283, 1, x_264); +lean_ctor_set(x_283, 2, x_265); +lean_ctor_set(x_283, 3, x_266); +lean_ctor_set(x_283, 4, x_267); +lean_ctor_set(x_283, 5, x_268); if (lean_is_scalar(x_9)) { - x_274 = lean_alloc_ctor(0, 2, 0); + x_284 = lean_alloc_ctor(0, 2, 0); } else { - x_274 = x_9; + x_284 = x_9; } -lean_ctor_set(x_274, 0, x_254); -lean_ctor_set(x_274, 1, x_273); -return x_274; +lean_ctor_set(x_284, 0, x_263); +lean_ctor_set(x_284, 1, x_283); +return x_284; } } } @@ -24681,7 +24774,7 @@ return x_34; } else { -lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_133; lean_object* x_134; lean_object* x_135; +lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_139; lean_object* x_140; lean_object* x_141; x_35 = lean_ctor_get(x_8, 0); lean_inc(x_35); x_36 = lean_ctor_get(x_35, 2); @@ -24690,40 +24783,40 @@ lean_dec(x_35); x_37 = lean_ctor_get(x_36, 2); lean_inc(x_37); lean_dec(x_36); -x_133 = l_Lean_Elab_Term_resetSynthInstanceCache___rarg(x_8); -x_134 = lean_ctor_get(x_133, 1); -lean_inc(x_134); -lean_dec(x_133); -x_135 = lean_apply_2(x_2, x_30, x_134); -if (lean_obj_tag(x_135) == 0) +x_139 = l_Lean_Elab_Term_resetSynthInstanceCache___rarg(x_8); +x_140 = lean_ctor_get(x_139, 1); +lean_inc(x_140); +lean_dec(x_139); +x_141 = lean_apply_2(x_2, x_30, x_140); +if (lean_obj_tag(x_141) == 0) { -lean_object* x_136; lean_object* x_137; lean_object* x_138; -x_136 = lean_ctor_get(x_135, 0); -lean_inc(x_136); -x_137 = lean_ctor_get(x_135, 1); -lean_inc(x_137); -lean_dec(x_135); -x_138 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_138, 0, x_136); -x_38 = x_138; -x_39 = x_137; -goto block_132; +lean_object* x_142; lean_object* x_143; lean_object* x_144; +x_142 = lean_ctor_get(x_141, 0); +lean_inc(x_142); +x_143 = lean_ctor_get(x_141, 1); +lean_inc(x_143); +lean_dec(x_141); +x_144 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_144, 0, x_142); +x_38 = x_144; +x_39 = x_143; +goto block_138; } else { -lean_object* x_139; lean_object* x_140; lean_object* x_141; -x_139 = lean_ctor_get(x_135, 0); -lean_inc(x_139); -x_140 = lean_ctor_get(x_135, 1); -lean_inc(x_140); -lean_dec(x_135); -x_141 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_141, 0, x_139); -x_38 = x_141; -x_39 = x_140; -goto block_132; +lean_object* x_145; lean_object* x_146; lean_object* x_147; +x_145 = lean_ctor_get(x_141, 0); +lean_inc(x_145); +x_146 = lean_ctor_get(x_141, 1); +lean_inc(x_146); +lean_dec(x_141); +x_147 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_147, 0, x_145); +x_38 = x_147; +x_39 = x_146; +goto block_138; } -block_132: +block_138: { if (lean_obj_tag(x_38) == 0) { @@ -24766,113 +24859,120 @@ 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_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; x_50 = lean_ctor_get(x_41, 0); x_51 = lean_ctor_get(x_41, 1); x_52 = lean_ctor_get(x_41, 3); +x_53 = lean_ctor_get(x_41, 4); +lean_inc(x_53); lean_inc(x_52); lean_inc(x_51); lean_inc(x_50); lean_dec(x_41); -x_53 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_53, 0, x_50); -lean_ctor_set(x_53, 1, x_51); -lean_ctor_set(x_53, 2, x_37); -lean_ctor_set(x_53, 3, x_52); -lean_ctor_set(x_40, 2, x_53); +x_54 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_54, 0, x_50); +lean_ctor_set(x_54, 1, x_51); +lean_ctor_set(x_54, 2, x_37); +lean_ctor_set(x_54, 3, x_52); +lean_ctor_set(x_54, 4, x_53); +lean_ctor_set(x_40, 2, x_54); if (lean_is_scalar(x_9)) { - x_54 = lean_alloc_ctor(1, 2, 0); + x_55 = lean_alloc_ctor(1, 2, 0); } else { - x_54 = x_9; - lean_ctor_set_tag(x_54, 1); + x_55 = x_9; + lean_ctor_set_tag(x_55, 1); } -lean_ctor_set(x_54, 0, x_42); -lean_ctor_set(x_54, 1, x_39); -return x_54; +lean_ctor_set(x_55, 0, x_42); +lean_ctor_set(x_55, 1, x_39); +return x_55; } } else { -lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; -x_55 = lean_ctor_get(x_40, 0); -x_56 = lean_ctor_get(x_40, 1); -x_57 = lean_ctor_get(x_40, 3); -x_58 = lean_ctor_get(x_40, 4); -x_59 = lean_ctor_get(x_40, 5); +lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; +x_56 = lean_ctor_get(x_40, 0); +x_57 = lean_ctor_get(x_40, 1); +x_58 = lean_ctor_get(x_40, 3); +x_59 = lean_ctor_get(x_40, 4); +x_60 = lean_ctor_get(x_40, 5); +lean_inc(x_60); lean_inc(x_59); lean_inc(x_58); lean_inc(x_57); lean_inc(x_56); -lean_inc(x_55); lean_dec(x_40); -x_60 = lean_ctor_get(x_41, 0); -lean_inc(x_60); -x_61 = lean_ctor_get(x_41, 1); +x_61 = lean_ctor_get(x_41, 0); lean_inc(x_61); -x_62 = lean_ctor_get(x_41, 3); +x_62 = lean_ctor_get(x_41, 1); lean_inc(x_62); +x_63 = lean_ctor_get(x_41, 3); +lean_inc(x_63); +x_64 = lean_ctor_get(x_41, 4); +lean_inc(x_64); if (lean_is_exclusive(x_41)) { lean_ctor_release(x_41, 0); lean_ctor_release(x_41, 1); lean_ctor_release(x_41, 2); lean_ctor_release(x_41, 3); - x_63 = x_41; + lean_ctor_release(x_41, 4); + x_65 = x_41; } else { lean_dec_ref(x_41); - x_63 = lean_box(0); + x_65 = lean_box(0); } -if (lean_is_scalar(x_63)) { - x_64 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_65)) { + x_66 = lean_alloc_ctor(0, 5, 0); } else { - x_64 = x_63; + x_66 = x_65; } -lean_ctor_set(x_64, 0, x_60); -lean_ctor_set(x_64, 1, x_61); -lean_ctor_set(x_64, 2, x_37); -lean_ctor_set(x_64, 3, x_62); -x_65 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_65, 0, x_55); -lean_ctor_set(x_65, 1, x_56); -lean_ctor_set(x_65, 2, x_64); -lean_ctor_set(x_65, 3, x_57); -lean_ctor_set(x_65, 4, x_58); -lean_ctor_set(x_65, 5, x_59); -lean_ctor_set(x_39, 0, x_65); +lean_ctor_set(x_66, 0, x_61); +lean_ctor_set(x_66, 1, x_62); +lean_ctor_set(x_66, 2, x_37); +lean_ctor_set(x_66, 3, x_63); +lean_ctor_set(x_66, 4, x_64); +x_67 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_67, 0, x_56); +lean_ctor_set(x_67, 1, x_57); +lean_ctor_set(x_67, 2, x_66); +lean_ctor_set(x_67, 3, x_58); +lean_ctor_set(x_67, 4, x_59); +lean_ctor_set(x_67, 5, x_60); +lean_ctor_set(x_39, 0, x_67); if (lean_is_scalar(x_9)) { - x_66 = lean_alloc_ctor(1, 2, 0); + x_68 = lean_alloc_ctor(1, 2, 0); } else { - x_66 = x_9; - lean_ctor_set_tag(x_66, 1); + x_68 = x_9; + lean_ctor_set_tag(x_68, 1); } -lean_ctor_set(x_66, 0, x_42); -lean_ctor_set(x_66, 1, x_39); -return x_66; +lean_ctor_set(x_68, 0, x_42); +lean_ctor_set(x_68, 1, x_39); +return x_68; } } else { -lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; 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; -x_67 = lean_ctor_get(x_39, 1); -x_68 = lean_ctor_get(x_39, 2); -x_69 = lean_ctor_get(x_39, 3); -x_70 = lean_ctor_get(x_39, 4); -x_71 = lean_ctor_get(x_39, 5); +lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; 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; +x_69 = lean_ctor_get(x_39, 1); +x_70 = lean_ctor_get(x_39, 2); +x_71 = lean_ctor_get(x_39, 3); +x_72 = lean_ctor_get(x_39, 4); +x_73 = lean_ctor_get(x_39, 5); +lean_inc(x_73); +lean_inc(x_72); lean_inc(x_71); lean_inc(x_70); lean_inc(x_69); -lean_inc(x_68); -lean_inc(x_67); lean_dec(x_39); -x_72 = lean_ctor_get(x_40, 0); -lean_inc(x_72); -x_73 = lean_ctor_get(x_40, 1); -lean_inc(x_73); -x_74 = lean_ctor_get(x_40, 3); +x_74 = lean_ctor_get(x_40, 0); lean_inc(x_74); -x_75 = lean_ctor_get(x_40, 4); +x_75 = lean_ctor_get(x_40, 1); lean_inc(x_75); -x_76 = lean_ctor_get(x_40, 5); +x_76 = lean_ctor_get(x_40, 3); lean_inc(x_76); +x_77 = lean_ctor_get(x_40, 4); +lean_inc(x_77); +x_78 = lean_ctor_get(x_40, 5); +lean_inc(x_78); if (lean_is_exclusive(x_40)) { lean_ctor_release(x_40, 0); lean_ctor_release(x_40, 1); @@ -24880,273 +24980,288 @@ if (lean_is_exclusive(x_40)) { lean_ctor_release(x_40, 3); lean_ctor_release(x_40, 4); lean_ctor_release(x_40, 5); - x_77 = x_40; + x_79 = x_40; } else { lean_dec_ref(x_40); - x_77 = lean_box(0); + x_79 = lean_box(0); } -x_78 = lean_ctor_get(x_41, 0); -lean_inc(x_78); -x_79 = lean_ctor_get(x_41, 1); -lean_inc(x_79); -x_80 = lean_ctor_get(x_41, 3); +x_80 = lean_ctor_get(x_41, 0); lean_inc(x_80); +x_81 = lean_ctor_get(x_41, 1); +lean_inc(x_81); +x_82 = lean_ctor_get(x_41, 3); +lean_inc(x_82); +x_83 = lean_ctor_get(x_41, 4); +lean_inc(x_83); if (lean_is_exclusive(x_41)) { lean_ctor_release(x_41, 0); lean_ctor_release(x_41, 1); lean_ctor_release(x_41, 2); lean_ctor_release(x_41, 3); - x_81 = x_41; + lean_ctor_release(x_41, 4); + x_84 = x_41; } else { lean_dec_ref(x_41); - x_81 = lean_box(0); + x_84 = lean_box(0); } -if (lean_is_scalar(x_81)) { - x_82 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_84)) { + x_85 = lean_alloc_ctor(0, 5, 0); } else { - x_82 = x_81; + x_85 = x_84; } -lean_ctor_set(x_82, 0, x_78); -lean_ctor_set(x_82, 1, x_79); -lean_ctor_set(x_82, 2, x_37); -lean_ctor_set(x_82, 3, x_80); -if (lean_is_scalar(x_77)) { - x_83 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_85, 0, x_80); +lean_ctor_set(x_85, 1, x_81); +lean_ctor_set(x_85, 2, x_37); +lean_ctor_set(x_85, 3, x_82); +lean_ctor_set(x_85, 4, x_83); +if (lean_is_scalar(x_79)) { + x_86 = lean_alloc_ctor(0, 6, 0); } else { - x_83 = x_77; + x_86 = x_79; } -lean_ctor_set(x_83, 0, x_72); -lean_ctor_set(x_83, 1, x_73); -lean_ctor_set(x_83, 2, x_82); -lean_ctor_set(x_83, 3, x_74); -lean_ctor_set(x_83, 4, x_75); -lean_ctor_set(x_83, 5, x_76); -x_84 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_84, 0, x_83); -lean_ctor_set(x_84, 1, x_67); -lean_ctor_set(x_84, 2, x_68); -lean_ctor_set(x_84, 3, x_69); -lean_ctor_set(x_84, 4, x_70); -lean_ctor_set(x_84, 5, x_71); +lean_ctor_set(x_86, 0, x_74); +lean_ctor_set(x_86, 1, x_75); +lean_ctor_set(x_86, 2, x_85); +lean_ctor_set(x_86, 3, x_76); +lean_ctor_set(x_86, 4, x_77); +lean_ctor_set(x_86, 5, x_78); +x_87 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_87, 0, x_86); +lean_ctor_set(x_87, 1, x_69); +lean_ctor_set(x_87, 2, x_70); +lean_ctor_set(x_87, 3, x_71); +lean_ctor_set(x_87, 4, x_72); +lean_ctor_set(x_87, 5, x_73); if (lean_is_scalar(x_9)) { - x_85 = lean_alloc_ctor(1, 2, 0); + x_88 = lean_alloc_ctor(1, 2, 0); } else { - x_85 = x_9; - lean_ctor_set_tag(x_85, 1); + x_88 = x_9; + lean_ctor_set_tag(x_88, 1); } -lean_ctor_set(x_85, 0, x_42); -lean_ctor_set(x_85, 1, x_84); -return x_85; +lean_ctor_set(x_88, 0, x_42); +lean_ctor_set(x_88, 1, x_87); +return x_88; } } else { -lean_object* x_86; lean_object* x_87; lean_object* x_88; uint8_t x_89; -x_86 = lean_ctor_get(x_39, 0); -lean_inc(x_86); -x_87 = lean_ctor_get(x_86, 2); -lean_inc(x_87); -x_88 = lean_ctor_get(x_38, 0); -lean_inc(x_88); +lean_object* x_89; lean_object* x_90; lean_object* x_91; uint8_t x_92; +x_89 = lean_ctor_get(x_39, 0); +lean_inc(x_89); +x_90 = lean_ctor_get(x_89, 2); +lean_inc(x_90); +x_91 = lean_ctor_get(x_38, 0); +lean_inc(x_91); lean_dec(x_38); -x_89 = !lean_is_exclusive(x_39); -if (x_89 == 0) +x_92 = !lean_is_exclusive(x_39); +if (x_92 == 0) { -lean_object* x_90; uint8_t x_91; -x_90 = lean_ctor_get(x_39, 0); -lean_dec(x_90); -x_91 = !lean_is_exclusive(x_86); -if (x_91 == 0) +lean_object* x_93; uint8_t x_94; +x_93 = lean_ctor_get(x_39, 0); +lean_dec(x_93); +x_94 = !lean_is_exclusive(x_89); +if (x_94 == 0) { -lean_object* x_92; uint8_t x_93; -x_92 = lean_ctor_get(x_86, 2); -lean_dec(x_92); -x_93 = !lean_is_exclusive(x_87); -if (x_93 == 0) +lean_object* x_95; uint8_t x_96; +x_95 = lean_ctor_get(x_89, 2); +lean_dec(x_95); +x_96 = !lean_is_exclusive(x_90); +if (x_96 == 0) { -lean_object* x_94; lean_object* x_95; -x_94 = lean_ctor_get(x_87, 2); -lean_dec(x_94); -lean_ctor_set(x_87, 2, x_37); +lean_object* x_97; lean_object* x_98; +x_97 = lean_ctor_get(x_90, 2); +lean_dec(x_97); +lean_ctor_set(x_90, 2, x_37); if (lean_is_scalar(x_9)) { - x_95 = lean_alloc_ctor(0, 2, 0); + x_98 = lean_alloc_ctor(0, 2, 0); } else { - x_95 = x_9; + x_98 = x_9; } -lean_ctor_set(x_95, 0, x_88); -lean_ctor_set(x_95, 1, x_39); -return x_95; +lean_ctor_set(x_98, 0, x_91); +lean_ctor_set(x_98, 1, x_39); +return x_98; } else { -lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; -x_96 = lean_ctor_get(x_87, 0); -x_97 = lean_ctor_get(x_87, 1); -x_98 = lean_ctor_get(x_87, 3); -lean_inc(x_98); -lean_inc(x_97); -lean_inc(x_96); -lean_dec(x_87); -x_99 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_99, 0, x_96); -lean_ctor_set(x_99, 1, x_97); -lean_ctor_set(x_99, 2, x_37); -lean_ctor_set(x_99, 3, x_98); -lean_ctor_set(x_86, 2, x_99); -if (lean_is_scalar(x_9)) { - x_100 = lean_alloc_ctor(0, 2, 0); -} else { - x_100 = x_9; -} -lean_ctor_set(x_100, 0, x_88); -lean_ctor_set(x_100, 1, x_39); -return x_100; -} -} -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; -x_101 = lean_ctor_get(x_86, 0); -x_102 = lean_ctor_get(x_86, 1); -x_103 = lean_ctor_get(x_86, 3); -x_104 = lean_ctor_get(x_86, 4); -x_105 = lean_ctor_get(x_86, 5); -lean_inc(x_105); -lean_inc(x_104); -lean_inc(x_103); +lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; +x_99 = lean_ctor_get(x_90, 0); +x_100 = lean_ctor_get(x_90, 1); +x_101 = lean_ctor_get(x_90, 3); +x_102 = lean_ctor_get(x_90, 4); lean_inc(x_102); lean_inc(x_101); -lean_dec(x_86); -x_106 = lean_ctor_get(x_87, 0); -lean_inc(x_106); -x_107 = lean_ctor_get(x_87, 1); -lean_inc(x_107); -x_108 = lean_ctor_get(x_87, 3); +lean_inc(x_100); +lean_inc(x_99); +lean_dec(x_90); +x_103 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_103, 0, x_99); +lean_ctor_set(x_103, 1, x_100); +lean_ctor_set(x_103, 2, x_37); +lean_ctor_set(x_103, 3, x_101); +lean_ctor_set(x_103, 4, x_102); +lean_ctor_set(x_89, 2, x_103); +if (lean_is_scalar(x_9)) { + x_104 = lean_alloc_ctor(0, 2, 0); +} else { + x_104 = x_9; +} +lean_ctor_set(x_104, 0, x_91); +lean_ctor_set(x_104, 1, x_39); +return x_104; +} +} +else +{ +lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; +x_105 = lean_ctor_get(x_89, 0); +x_106 = lean_ctor_get(x_89, 1); +x_107 = lean_ctor_get(x_89, 3); +x_108 = lean_ctor_get(x_89, 4); +x_109 = lean_ctor_get(x_89, 5); +lean_inc(x_109); lean_inc(x_108); -if (lean_is_exclusive(x_87)) { - lean_ctor_release(x_87, 0); - lean_ctor_release(x_87, 1); - lean_ctor_release(x_87, 2); - lean_ctor_release(x_87, 3); - x_109 = x_87; -} else { - lean_dec_ref(x_87); - x_109 = lean_box(0); -} -if (lean_is_scalar(x_109)) { - x_110 = lean_alloc_ctor(0, 4, 0); -} else { - x_110 = x_109; -} -lean_ctor_set(x_110, 0, x_106); -lean_ctor_set(x_110, 1, x_107); -lean_ctor_set(x_110, 2, x_37); -lean_ctor_set(x_110, 3, x_108); -x_111 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_111, 0, x_101); -lean_ctor_set(x_111, 1, x_102); -lean_ctor_set(x_111, 2, x_110); -lean_ctor_set(x_111, 3, x_103); -lean_ctor_set(x_111, 4, x_104); -lean_ctor_set(x_111, 5, x_105); -lean_ctor_set(x_39, 0, x_111); -if (lean_is_scalar(x_9)) { - x_112 = lean_alloc_ctor(0, 2, 0); -} else { - x_112 = x_9; -} -lean_ctor_set(x_112, 0, x_88); -lean_ctor_set(x_112, 1, x_39); -return x_112; -} -} -else -{ -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; -x_113 = lean_ctor_get(x_39, 1); -x_114 = lean_ctor_get(x_39, 2); -x_115 = lean_ctor_get(x_39, 3); -x_116 = lean_ctor_get(x_39, 4); -x_117 = lean_ctor_get(x_39, 5); -lean_inc(x_117); -lean_inc(x_116); -lean_inc(x_115); -lean_inc(x_114); +lean_inc(x_107); +lean_inc(x_106); +lean_inc(x_105); +lean_dec(x_89); +x_110 = lean_ctor_get(x_90, 0); +lean_inc(x_110); +x_111 = lean_ctor_get(x_90, 1); +lean_inc(x_111); +x_112 = lean_ctor_get(x_90, 3); +lean_inc(x_112); +x_113 = lean_ctor_get(x_90, 4); lean_inc(x_113); -lean_dec(x_39); -x_118 = lean_ctor_get(x_86, 0); -lean_inc(x_118); -x_119 = lean_ctor_get(x_86, 1); -lean_inc(x_119); -x_120 = lean_ctor_get(x_86, 3); -lean_inc(x_120); -x_121 = lean_ctor_get(x_86, 4); -lean_inc(x_121); -x_122 = lean_ctor_get(x_86, 5); -lean_inc(x_122); -if (lean_is_exclusive(x_86)) { - lean_ctor_release(x_86, 0); - lean_ctor_release(x_86, 1); - lean_ctor_release(x_86, 2); - lean_ctor_release(x_86, 3); - lean_ctor_release(x_86, 4); - lean_ctor_release(x_86, 5); - x_123 = x_86; +if (lean_is_exclusive(x_90)) { + lean_ctor_release(x_90, 0); + lean_ctor_release(x_90, 1); + lean_ctor_release(x_90, 2); + lean_ctor_release(x_90, 3); + lean_ctor_release(x_90, 4); + x_114 = x_90; } else { - lean_dec_ref(x_86); - x_123 = lean_box(0); + lean_dec_ref(x_90); + x_114 = lean_box(0); } -x_124 = lean_ctor_get(x_87, 0); -lean_inc(x_124); -x_125 = lean_ctor_get(x_87, 1); -lean_inc(x_125); -x_126 = lean_ctor_get(x_87, 3); -lean_inc(x_126); -if (lean_is_exclusive(x_87)) { - lean_ctor_release(x_87, 0); - lean_ctor_release(x_87, 1); - lean_ctor_release(x_87, 2); - lean_ctor_release(x_87, 3); - x_127 = x_87; +if (lean_is_scalar(x_114)) { + x_115 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_87); - x_127 = lean_box(0); + x_115 = x_114; } -if (lean_is_scalar(x_127)) { - x_128 = lean_alloc_ctor(0, 4, 0); -} else { - x_128 = x_127; -} -lean_ctor_set(x_128, 0, x_124); -lean_ctor_set(x_128, 1, x_125); -lean_ctor_set(x_128, 2, x_37); -lean_ctor_set(x_128, 3, x_126); -if (lean_is_scalar(x_123)) { - x_129 = lean_alloc_ctor(0, 6, 0); -} else { - x_129 = x_123; -} -lean_ctor_set(x_129, 0, x_118); -lean_ctor_set(x_129, 1, x_119); -lean_ctor_set(x_129, 2, x_128); -lean_ctor_set(x_129, 3, x_120); -lean_ctor_set(x_129, 4, x_121); -lean_ctor_set(x_129, 5, x_122); -x_130 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_130, 0, x_129); -lean_ctor_set(x_130, 1, x_113); -lean_ctor_set(x_130, 2, x_114); -lean_ctor_set(x_130, 3, x_115); -lean_ctor_set(x_130, 4, x_116); -lean_ctor_set(x_130, 5, x_117); +lean_ctor_set(x_115, 0, x_110); +lean_ctor_set(x_115, 1, x_111); +lean_ctor_set(x_115, 2, x_37); +lean_ctor_set(x_115, 3, x_112); +lean_ctor_set(x_115, 4, x_113); +x_116 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_116, 0, x_105); +lean_ctor_set(x_116, 1, x_106); +lean_ctor_set(x_116, 2, x_115); +lean_ctor_set(x_116, 3, x_107); +lean_ctor_set(x_116, 4, x_108); +lean_ctor_set(x_116, 5, x_109); +lean_ctor_set(x_39, 0, x_116); if (lean_is_scalar(x_9)) { - x_131 = lean_alloc_ctor(0, 2, 0); + x_117 = lean_alloc_ctor(0, 2, 0); } else { - x_131 = x_9; + x_117 = x_9; } -lean_ctor_set(x_131, 0, x_88); -lean_ctor_set(x_131, 1, x_130); -return x_131; +lean_ctor_set(x_117, 0, x_91); +lean_ctor_set(x_117, 1, x_39); +return x_117; +} +} +else +{ +lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; 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; +x_118 = lean_ctor_get(x_39, 1); +x_119 = lean_ctor_get(x_39, 2); +x_120 = lean_ctor_get(x_39, 3); +x_121 = lean_ctor_get(x_39, 4); +x_122 = lean_ctor_get(x_39, 5); +lean_inc(x_122); +lean_inc(x_121); +lean_inc(x_120); +lean_inc(x_119); +lean_inc(x_118); +lean_dec(x_39); +x_123 = lean_ctor_get(x_89, 0); +lean_inc(x_123); +x_124 = lean_ctor_get(x_89, 1); +lean_inc(x_124); +x_125 = lean_ctor_get(x_89, 3); +lean_inc(x_125); +x_126 = lean_ctor_get(x_89, 4); +lean_inc(x_126); +x_127 = lean_ctor_get(x_89, 5); +lean_inc(x_127); +if (lean_is_exclusive(x_89)) { + lean_ctor_release(x_89, 0); + lean_ctor_release(x_89, 1); + lean_ctor_release(x_89, 2); + lean_ctor_release(x_89, 3); + lean_ctor_release(x_89, 4); + lean_ctor_release(x_89, 5); + x_128 = x_89; +} else { + lean_dec_ref(x_89); + x_128 = lean_box(0); +} +x_129 = lean_ctor_get(x_90, 0); +lean_inc(x_129); +x_130 = lean_ctor_get(x_90, 1); +lean_inc(x_130); +x_131 = lean_ctor_get(x_90, 3); +lean_inc(x_131); +x_132 = lean_ctor_get(x_90, 4); +lean_inc(x_132); +if (lean_is_exclusive(x_90)) { + lean_ctor_release(x_90, 0); + lean_ctor_release(x_90, 1); + lean_ctor_release(x_90, 2); + lean_ctor_release(x_90, 3); + lean_ctor_release(x_90, 4); + x_133 = x_90; +} else { + lean_dec_ref(x_90); + x_133 = lean_box(0); +} +if (lean_is_scalar(x_133)) { + x_134 = lean_alloc_ctor(0, 5, 0); +} else { + x_134 = x_133; +} +lean_ctor_set(x_134, 0, x_129); +lean_ctor_set(x_134, 1, x_130); +lean_ctor_set(x_134, 2, x_37); +lean_ctor_set(x_134, 3, x_131); +lean_ctor_set(x_134, 4, x_132); +if (lean_is_scalar(x_128)) { + x_135 = lean_alloc_ctor(0, 6, 0); +} else { + x_135 = x_128; +} +lean_ctor_set(x_135, 0, x_123); +lean_ctor_set(x_135, 1, x_124); +lean_ctor_set(x_135, 2, x_134); +lean_ctor_set(x_135, 3, x_125); +lean_ctor_set(x_135, 4, x_126); +lean_ctor_set(x_135, 5, x_127); +x_136 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_136, 0, x_135); +lean_ctor_set(x_136, 1, x_118); +lean_ctor_set(x_136, 2, x_119); +lean_ctor_set(x_136, 3, x_120); +lean_ctor_set(x_136, 4, x_121); +lean_ctor_set(x_136, 5, x_122); +if (lean_is_scalar(x_9)) { + x_137 = lean_alloc_ctor(0, 2, 0); +} else { + x_137 = x_9; +} +lean_ctor_set(x_137, 0, x_91); +lean_ctor_set(x_137, 1, x_136); +return x_137; } } } @@ -25155,342 +25270,350 @@ return x_131; } else { -uint8_t x_142; uint8_t x_143; uint8_t 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; uint8_t x_153; lean_object* x_154; lean_object* x_155; -x_142 = lean_ctor_get_uint8(x_3, sizeof(void*)*10); -x_143 = lean_ctor_get_uint8(x_3, sizeof(void*)*10 + 1); -x_144 = lean_ctor_get_uint8(x_3, sizeof(void*)*10 + 2); -x_145 = lean_ctor_get(x_6, 0); -x_146 = lean_ctor_get(x_6, 2); -x_147 = lean_ctor_get(x_6, 3); -x_148 = lean_ctor_get(x_6, 4); -lean_inc(x_148); -lean_inc(x_147); -lean_inc(x_146); -lean_inc(x_145); +uint8_t x_148; uint8_t x_149; uint8_t 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; uint8_t x_159; lean_object* x_160; lean_object* x_161; +x_148 = lean_ctor_get_uint8(x_3, sizeof(void*)*10); +x_149 = lean_ctor_get_uint8(x_3, sizeof(void*)*10 + 1); +x_150 = lean_ctor_get_uint8(x_3, sizeof(void*)*10 + 2); +x_151 = lean_ctor_get(x_6, 0); +x_152 = lean_ctor_get(x_6, 2); +x_153 = lean_ctor_get(x_6, 3); +x_154 = lean_ctor_get(x_6, 4); +lean_inc(x_154); +lean_inc(x_153); +lean_inc(x_152); +lean_inc(x_151); lean_dec(x_6); -x_149 = lean_ctor_get(x_7, 1); -lean_inc(x_149); -x_150 = lean_ctor_get(x_7, 4); -lean_inc(x_150); -x_151 = lean_array_get_size(x_146); -x_152 = lean_array_get_size(x_150); -x_153 = lean_nat_dec_eq(x_151, x_152); +x_155 = lean_ctor_get(x_7, 1); +lean_inc(x_155); +x_156 = lean_ctor_get(x_7, 4); +lean_inc(x_156); +x_157 = lean_array_get_size(x_152); +x_158 = lean_array_get_size(x_156); +x_159 = lean_nat_dec_eq(x_157, x_158); +lean_dec(x_158); +lean_dec(x_157); +lean_inc(x_156); +x_160 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_160, 0, x_151); +lean_ctor_set(x_160, 1, x_155); +lean_ctor_set(x_160, 2, x_156); +lean_ctor_set(x_160, 3, x_153); +lean_ctor_set(x_160, 4, x_154); +x_161 = lean_alloc_ctor(0, 10, 3); +lean_ctor_set(x_161, 0, x_160); +lean_ctor_set(x_161, 1, x_10); +lean_ctor_set(x_161, 2, x_11); +lean_ctor_set(x_161, 3, x_12); +lean_ctor_set(x_161, 4, x_13); +lean_ctor_set(x_161, 5, x_14); +lean_ctor_set(x_161, 6, x_15); +lean_ctor_set(x_161, 7, x_16); +lean_ctor_set(x_161, 8, x_17); +lean_ctor_set(x_161, 9, x_18); +lean_ctor_set_uint8(x_161, sizeof(void*)*10, x_148); +lean_ctor_set_uint8(x_161, sizeof(void*)*10 + 1, x_149); +lean_ctor_set_uint8(x_161, sizeof(void*)*10 + 2, x_150); +if (x_159 == 0) +{ +lean_object* x_162; +lean_dec(x_156); lean_dec(x_152); -lean_dec(x_151); -lean_inc(x_150); -x_154 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_154, 0, x_145); -lean_ctor_set(x_154, 1, x_149); -lean_ctor_set(x_154, 2, x_150); -lean_ctor_set(x_154, 3, x_147); -lean_ctor_set(x_154, 4, x_148); -x_155 = lean_alloc_ctor(0, 10, 3); -lean_ctor_set(x_155, 0, x_154); -lean_ctor_set(x_155, 1, x_10); -lean_ctor_set(x_155, 2, x_11); -lean_ctor_set(x_155, 3, x_12); -lean_ctor_set(x_155, 4, x_13); -lean_ctor_set(x_155, 5, x_14); -lean_ctor_set(x_155, 6, x_15); -lean_ctor_set(x_155, 7, x_16); -lean_ctor_set(x_155, 8, x_17); -lean_ctor_set(x_155, 9, x_18); -lean_ctor_set_uint8(x_155, sizeof(void*)*10, x_142); -lean_ctor_set_uint8(x_155, sizeof(void*)*10 + 1, x_143); -lean_ctor_set_uint8(x_155, sizeof(void*)*10 + 2, x_144); -if (x_153 == 0) -{ -lean_object* x_156; -lean_dec(x_150); -lean_dec(x_146); lean_dec(x_9); lean_dec(x_7); lean_dec(x_3); -x_156 = lean_apply_2(x_2, x_155, x_8); -return x_156; +x_162 = lean_apply_2(x_2, x_161, x_8); +return x_162; } else { -lean_object* x_157; uint8_t x_158; -x_157 = lean_unsigned_to_nat(0u); -x_158 = l_Array_isEqvAux___main___at_Lean_Elab_Term_withMVarContext___spec__1(x_3, x_7, lean_box(0), x_146, x_150, x_157); -lean_dec(x_150); -lean_dec(x_146); +lean_object* x_163; uint8_t x_164; +x_163 = lean_unsigned_to_nat(0u); +x_164 = l_Array_isEqvAux___main___at_Lean_Elab_Term_withMVarContext___spec__1(x_3, x_7, lean_box(0), x_152, x_156, x_163); +lean_dec(x_156); +lean_dec(x_152); lean_dec(x_7); lean_dec(x_3); -if (x_158 == 0) +if (x_164 == 0) { -lean_object* x_159; +lean_object* x_165; lean_dec(x_9); -x_159 = lean_apply_2(x_2, x_155, x_8); -return x_159; +x_165 = lean_apply_2(x_2, x_161, x_8); +return x_165; } else { -lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_212; lean_object* x_213; lean_object* x_214; -x_160 = lean_ctor_get(x_8, 0); -lean_inc(x_160); -x_161 = lean_ctor_get(x_160, 2); -lean_inc(x_161); -lean_dec(x_160); -x_162 = lean_ctor_get(x_161, 2); -lean_inc(x_162); -lean_dec(x_161); -x_212 = l_Lean_Elab_Term_resetSynthInstanceCache___rarg(x_8); -x_213 = lean_ctor_get(x_212, 1); -lean_inc(x_213); -lean_dec(x_212); -x_214 = lean_apply_2(x_2, x_155, x_213); -if (lean_obj_tag(x_214) == 0) -{ -lean_object* x_215; lean_object* x_216; lean_object* x_217; -x_215 = lean_ctor_get(x_214, 0); -lean_inc(x_215); -x_216 = lean_ctor_get(x_214, 1); -lean_inc(x_216); -lean_dec(x_214); -x_217 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_217, 0, x_215); -x_163 = x_217; -x_164 = x_216; -goto block_211; -} -else -{ -lean_object* x_218; lean_object* x_219; lean_object* x_220; -x_218 = lean_ctor_get(x_214, 0); -lean_inc(x_218); -x_219 = lean_ctor_get(x_214, 1); -lean_inc(x_219); -lean_dec(x_214); -x_220 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_220, 0, x_218); -x_163 = x_220; -x_164 = x_219; -goto block_211; -} -block_211: -{ -if (lean_obj_tag(x_163) == 0) -{ -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_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; -x_165 = lean_ctor_get(x_164, 0); -lean_inc(x_165); -x_166 = lean_ctor_get(x_165, 2); +lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_220; lean_object* x_221; lean_object* x_222; +x_166 = lean_ctor_get(x_8, 0); lean_inc(x_166); -x_167 = lean_ctor_get(x_163, 0); +x_167 = lean_ctor_get(x_166, 2); lean_inc(x_167); -lean_dec(x_163); -x_168 = lean_ctor_get(x_164, 1); +lean_dec(x_166); +x_168 = lean_ctor_get(x_167, 2); lean_inc(x_168); -x_169 = lean_ctor_get(x_164, 2); -lean_inc(x_169); -x_170 = lean_ctor_get(x_164, 3); -lean_inc(x_170); -x_171 = lean_ctor_get(x_164, 4); -lean_inc(x_171); -x_172 = lean_ctor_get(x_164, 5); -lean_inc(x_172); -if (lean_is_exclusive(x_164)) { - lean_ctor_release(x_164, 0); - lean_ctor_release(x_164, 1); - lean_ctor_release(x_164, 2); - lean_ctor_release(x_164, 3); - lean_ctor_release(x_164, 4); - lean_ctor_release(x_164, 5); - x_173 = x_164; -} else { - lean_dec_ref(x_164); - x_173 = lean_box(0); +lean_dec(x_167); +x_220 = l_Lean_Elab_Term_resetSynthInstanceCache___rarg(x_8); +x_221 = lean_ctor_get(x_220, 1); +lean_inc(x_221); +lean_dec(x_220); +x_222 = lean_apply_2(x_2, x_161, x_221); +if (lean_obj_tag(x_222) == 0) +{ +lean_object* x_223; lean_object* x_224; lean_object* x_225; +x_223 = lean_ctor_get(x_222, 0); +lean_inc(x_223); +x_224 = lean_ctor_get(x_222, 1); +lean_inc(x_224); +lean_dec(x_222); +x_225 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_225, 0, x_223); +x_169 = x_225; +x_170 = x_224; +goto block_219; } -x_174 = lean_ctor_get(x_165, 0); +else +{ +lean_object* x_226; lean_object* x_227; lean_object* x_228; +x_226 = lean_ctor_get(x_222, 0); +lean_inc(x_226); +x_227 = lean_ctor_get(x_222, 1); +lean_inc(x_227); +lean_dec(x_222); +x_228 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_228, 0, x_226); +x_169 = x_228; +x_170 = x_227; +goto block_219; +} +block_219: +{ +if (lean_obj_tag(x_169) == 0) +{ +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; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; +x_171 = lean_ctor_get(x_170, 0); +lean_inc(x_171); +x_172 = lean_ctor_get(x_171, 2); +lean_inc(x_172); +x_173 = lean_ctor_get(x_169, 0); +lean_inc(x_173); +lean_dec(x_169); +x_174 = lean_ctor_get(x_170, 1); lean_inc(x_174); -x_175 = lean_ctor_get(x_165, 1); +x_175 = lean_ctor_get(x_170, 2); lean_inc(x_175); -x_176 = lean_ctor_get(x_165, 3); +x_176 = lean_ctor_get(x_170, 3); lean_inc(x_176); -x_177 = lean_ctor_get(x_165, 4); +x_177 = lean_ctor_get(x_170, 4); lean_inc(x_177); -x_178 = lean_ctor_get(x_165, 5); +x_178 = lean_ctor_get(x_170, 5); lean_inc(x_178); -if (lean_is_exclusive(x_165)) { - lean_ctor_release(x_165, 0); - lean_ctor_release(x_165, 1); - lean_ctor_release(x_165, 2); - lean_ctor_release(x_165, 3); - lean_ctor_release(x_165, 4); - lean_ctor_release(x_165, 5); - x_179 = x_165; +if (lean_is_exclusive(x_170)) { + lean_ctor_release(x_170, 0); + lean_ctor_release(x_170, 1); + lean_ctor_release(x_170, 2); + lean_ctor_release(x_170, 3); + lean_ctor_release(x_170, 4); + lean_ctor_release(x_170, 5); + x_179 = x_170; } else { - lean_dec_ref(x_165); + lean_dec_ref(x_170); x_179 = lean_box(0); } -x_180 = lean_ctor_get(x_166, 0); +x_180 = lean_ctor_get(x_171, 0); lean_inc(x_180); -x_181 = lean_ctor_get(x_166, 1); +x_181 = lean_ctor_get(x_171, 1); lean_inc(x_181); -x_182 = lean_ctor_get(x_166, 3); +x_182 = lean_ctor_get(x_171, 3); lean_inc(x_182); -if (lean_is_exclusive(x_166)) { - lean_ctor_release(x_166, 0); - lean_ctor_release(x_166, 1); - lean_ctor_release(x_166, 2); - lean_ctor_release(x_166, 3); - x_183 = x_166; +x_183 = lean_ctor_get(x_171, 4); +lean_inc(x_183); +x_184 = lean_ctor_get(x_171, 5); +lean_inc(x_184); +if (lean_is_exclusive(x_171)) { + lean_ctor_release(x_171, 0); + lean_ctor_release(x_171, 1); + lean_ctor_release(x_171, 2); + lean_ctor_release(x_171, 3); + lean_ctor_release(x_171, 4); + lean_ctor_release(x_171, 5); + x_185 = x_171; } else { - lean_dec_ref(x_166); - x_183 = lean_box(0); + lean_dec_ref(x_171); + x_185 = lean_box(0); } -if (lean_is_scalar(x_183)) { - x_184 = lean_alloc_ctor(0, 4, 0); +x_186 = lean_ctor_get(x_172, 0); +lean_inc(x_186); +x_187 = lean_ctor_get(x_172, 1); +lean_inc(x_187); +x_188 = lean_ctor_get(x_172, 3); +lean_inc(x_188); +x_189 = lean_ctor_get(x_172, 4); +lean_inc(x_189); +if (lean_is_exclusive(x_172)) { + lean_ctor_release(x_172, 0); + lean_ctor_release(x_172, 1); + lean_ctor_release(x_172, 2); + lean_ctor_release(x_172, 3); + lean_ctor_release(x_172, 4); + x_190 = x_172; } else { - x_184 = x_183; + lean_dec_ref(x_172); + x_190 = lean_box(0); } -lean_ctor_set(x_184, 0, x_180); -lean_ctor_set(x_184, 1, x_181); -lean_ctor_set(x_184, 2, x_162); -lean_ctor_set(x_184, 3, x_182); +if (lean_is_scalar(x_190)) { + x_191 = lean_alloc_ctor(0, 5, 0); +} else { + x_191 = x_190; +} +lean_ctor_set(x_191, 0, x_186); +lean_ctor_set(x_191, 1, x_187); +lean_ctor_set(x_191, 2, x_168); +lean_ctor_set(x_191, 3, x_188); +lean_ctor_set(x_191, 4, x_189); +if (lean_is_scalar(x_185)) { + x_192 = lean_alloc_ctor(0, 6, 0); +} else { + x_192 = x_185; +} +lean_ctor_set(x_192, 0, x_180); +lean_ctor_set(x_192, 1, x_181); +lean_ctor_set(x_192, 2, x_191); +lean_ctor_set(x_192, 3, x_182); +lean_ctor_set(x_192, 4, x_183); +lean_ctor_set(x_192, 5, x_184); if (lean_is_scalar(x_179)) { - x_185 = lean_alloc_ctor(0, 6, 0); + x_193 = lean_alloc_ctor(0, 6, 0); } else { - x_185 = x_179; + x_193 = x_179; } -lean_ctor_set(x_185, 0, x_174); -lean_ctor_set(x_185, 1, x_175); -lean_ctor_set(x_185, 2, x_184); -lean_ctor_set(x_185, 3, x_176); -lean_ctor_set(x_185, 4, x_177); -lean_ctor_set(x_185, 5, x_178); -if (lean_is_scalar(x_173)) { - x_186 = lean_alloc_ctor(0, 6, 0); -} else { - x_186 = x_173; -} -lean_ctor_set(x_186, 0, x_185); -lean_ctor_set(x_186, 1, x_168); -lean_ctor_set(x_186, 2, x_169); -lean_ctor_set(x_186, 3, x_170); -lean_ctor_set(x_186, 4, x_171); -lean_ctor_set(x_186, 5, x_172); +lean_ctor_set(x_193, 0, x_192); +lean_ctor_set(x_193, 1, x_174); +lean_ctor_set(x_193, 2, x_175); +lean_ctor_set(x_193, 3, x_176); +lean_ctor_set(x_193, 4, x_177); +lean_ctor_set(x_193, 5, x_178); if (lean_is_scalar(x_9)) { - x_187 = lean_alloc_ctor(1, 2, 0); + x_194 = lean_alloc_ctor(1, 2, 0); } else { - x_187 = x_9; - lean_ctor_set_tag(x_187, 1); + x_194 = x_9; + lean_ctor_set_tag(x_194, 1); } -lean_ctor_set(x_187, 0, x_167); -lean_ctor_set(x_187, 1, x_186); -return x_187; +lean_ctor_set(x_194, 0, x_173); +lean_ctor_set(x_194, 1, x_193); +return x_194; } else { -lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; -x_188 = lean_ctor_get(x_164, 0); -lean_inc(x_188); -x_189 = lean_ctor_get(x_188, 2); -lean_inc(x_189); -x_190 = lean_ctor_get(x_163, 0); -lean_inc(x_190); -lean_dec(x_163); -x_191 = lean_ctor_get(x_164, 1); -lean_inc(x_191); -x_192 = lean_ctor_get(x_164, 2); -lean_inc(x_192); -x_193 = lean_ctor_get(x_164, 3); -lean_inc(x_193); -x_194 = lean_ctor_get(x_164, 4); -lean_inc(x_194); -x_195 = lean_ctor_get(x_164, 5); +lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; +x_195 = lean_ctor_get(x_170, 0); lean_inc(x_195); -if (lean_is_exclusive(x_164)) { - lean_ctor_release(x_164, 0); - lean_ctor_release(x_164, 1); - lean_ctor_release(x_164, 2); - lean_ctor_release(x_164, 3); - lean_ctor_release(x_164, 4); - lean_ctor_release(x_164, 5); - x_196 = x_164; -} else { - lean_dec_ref(x_164); - x_196 = lean_box(0); -} -x_197 = lean_ctor_get(x_188, 0); +x_196 = lean_ctor_get(x_195, 2); +lean_inc(x_196); +x_197 = lean_ctor_get(x_169, 0); lean_inc(x_197); -x_198 = lean_ctor_get(x_188, 1); +lean_dec(x_169); +x_198 = lean_ctor_get(x_170, 1); lean_inc(x_198); -x_199 = lean_ctor_get(x_188, 3); +x_199 = lean_ctor_get(x_170, 2); lean_inc(x_199); -x_200 = lean_ctor_get(x_188, 4); +x_200 = lean_ctor_get(x_170, 3); lean_inc(x_200); -x_201 = lean_ctor_get(x_188, 5); +x_201 = lean_ctor_get(x_170, 4); lean_inc(x_201); -if (lean_is_exclusive(x_188)) { - lean_ctor_release(x_188, 0); - lean_ctor_release(x_188, 1); - lean_ctor_release(x_188, 2); - lean_ctor_release(x_188, 3); - lean_ctor_release(x_188, 4); - lean_ctor_release(x_188, 5); - x_202 = x_188; +x_202 = lean_ctor_get(x_170, 5); +lean_inc(x_202); +if (lean_is_exclusive(x_170)) { + lean_ctor_release(x_170, 0); + lean_ctor_release(x_170, 1); + lean_ctor_release(x_170, 2); + lean_ctor_release(x_170, 3); + lean_ctor_release(x_170, 4); + lean_ctor_release(x_170, 5); + x_203 = x_170; } else { - lean_dec_ref(x_188); - x_202 = lean_box(0); + lean_dec_ref(x_170); + x_203 = lean_box(0); } -x_203 = lean_ctor_get(x_189, 0); -lean_inc(x_203); -x_204 = lean_ctor_get(x_189, 1); +x_204 = lean_ctor_get(x_195, 0); lean_inc(x_204); -x_205 = lean_ctor_get(x_189, 3); +x_205 = lean_ctor_get(x_195, 1); lean_inc(x_205); -if (lean_is_exclusive(x_189)) { - lean_ctor_release(x_189, 0); - lean_ctor_release(x_189, 1); - lean_ctor_release(x_189, 2); - lean_ctor_release(x_189, 3); - x_206 = x_189; +x_206 = lean_ctor_get(x_195, 3); +lean_inc(x_206); +x_207 = lean_ctor_get(x_195, 4); +lean_inc(x_207); +x_208 = lean_ctor_get(x_195, 5); +lean_inc(x_208); +if (lean_is_exclusive(x_195)) { + lean_ctor_release(x_195, 0); + lean_ctor_release(x_195, 1); + lean_ctor_release(x_195, 2); + lean_ctor_release(x_195, 3); + lean_ctor_release(x_195, 4); + lean_ctor_release(x_195, 5); + x_209 = x_195; } else { - lean_dec_ref(x_189); - x_206 = lean_box(0); + lean_dec_ref(x_195); + x_209 = lean_box(0); } -if (lean_is_scalar(x_206)) { - x_207 = lean_alloc_ctor(0, 4, 0); +x_210 = lean_ctor_get(x_196, 0); +lean_inc(x_210); +x_211 = lean_ctor_get(x_196, 1); +lean_inc(x_211); +x_212 = lean_ctor_get(x_196, 3); +lean_inc(x_212); +x_213 = lean_ctor_get(x_196, 4); +lean_inc(x_213); +if (lean_is_exclusive(x_196)) { + lean_ctor_release(x_196, 0); + lean_ctor_release(x_196, 1); + lean_ctor_release(x_196, 2); + lean_ctor_release(x_196, 3); + lean_ctor_release(x_196, 4); + x_214 = x_196; } else { - x_207 = x_206; + lean_dec_ref(x_196); + x_214 = lean_box(0); } -lean_ctor_set(x_207, 0, x_203); -lean_ctor_set(x_207, 1, x_204); -lean_ctor_set(x_207, 2, x_162); -lean_ctor_set(x_207, 3, x_205); -if (lean_is_scalar(x_202)) { - x_208 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_214)) { + x_215 = lean_alloc_ctor(0, 5, 0); } else { - x_208 = x_202; + x_215 = x_214; } -lean_ctor_set(x_208, 0, x_197); -lean_ctor_set(x_208, 1, x_198); -lean_ctor_set(x_208, 2, x_207); -lean_ctor_set(x_208, 3, x_199); -lean_ctor_set(x_208, 4, x_200); -lean_ctor_set(x_208, 5, x_201); -if (lean_is_scalar(x_196)) { - x_209 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_215, 0, x_210); +lean_ctor_set(x_215, 1, x_211); +lean_ctor_set(x_215, 2, x_168); +lean_ctor_set(x_215, 3, x_212); +lean_ctor_set(x_215, 4, x_213); +if (lean_is_scalar(x_209)) { + x_216 = lean_alloc_ctor(0, 6, 0); } else { - x_209 = x_196; + x_216 = x_209; } -lean_ctor_set(x_209, 0, x_208); -lean_ctor_set(x_209, 1, x_191); -lean_ctor_set(x_209, 2, x_192); -lean_ctor_set(x_209, 3, x_193); -lean_ctor_set(x_209, 4, x_194); -lean_ctor_set(x_209, 5, x_195); +lean_ctor_set(x_216, 0, x_204); +lean_ctor_set(x_216, 1, x_205); +lean_ctor_set(x_216, 2, x_215); +lean_ctor_set(x_216, 3, x_206); +lean_ctor_set(x_216, 4, x_207); +lean_ctor_set(x_216, 5, x_208); +if (lean_is_scalar(x_203)) { + x_217 = lean_alloc_ctor(0, 6, 0); +} else { + x_217 = x_203; +} +lean_ctor_set(x_217, 0, x_216); +lean_ctor_set(x_217, 1, x_198); +lean_ctor_set(x_217, 2, x_199); +lean_ctor_set(x_217, 3, x_200); +lean_ctor_set(x_217, 4, x_201); +lean_ctor_set(x_217, 5, x_202); if (lean_is_scalar(x_9)) { - x_210 = lean_alloc_ctor(0, 2, 0); + x_218 = lean_alloc_ctor(0, 2, 0); } else { - x_210 = x_9; + x_218 = x_9; } -lean_ctor_set(x_210, 0, x_190); -lean_ctor_set(x_210, 1, x_209); -return x_210; +lean_ctor_set(x_218, 0, x_197); +lean_ctor_set(x_218, 1, x_217); +return x_218; } } } @@ -26402,37 +26525,46 @@ return x_23; } else { -lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; uint8_t x_28; +lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; uint8_t x_32; lean_dec(x_12); x_24 = lean_ctor_get(x_20, 0); lean_inc(x_24); lean_dec(x_20); -x_25 = lean_ctor_get(x_24, 0); +x_25 = lean_ctor_get(x_24, 1); lean_inc(x_25); -x_26 = lean_ctor_get(x_24, 1); +x_26 = lean_ctor_get(x_24, 0); lean_inc(x_26); lean_dec(x_24); -x_27 = l_Lean_Elab_Term_setEnv(x_26, x_6, x_19); -lean_dec(x_6); -x_28 = !lean_is_exclusive(x_27); -if (x_28 == 0) -{ -lean_object* x_29; -x_29 = lean_ctor_get(x_27, 0); +x_27 = lean_ctor_get(x_25, 0); +lean_inc(x_27); +x_28 = lean_ctor_get(x_25, 1); +lean_inc(x_28); +lean_dec(x_25); +x_29 = l_Lean_Elab_Term_setEnv(x_27, x_6, x_19); +x_30 = lean_ctor_get(x_29, 1); +lean_inc(x_30); lean_dec(x_29); -lean_ctor_set(x_27, 0, x_25); -return x_27; +x_31 = l_Lean_Elab_Term_setMCtx(x_28, x_6, x_30); +lean_dec(x_6); +x_32 = !lean_is_exclusive(x_31); +if (x_32 == 0) +{ +lean_object* x_33; +x_33 = lean_ctor_get(x_31, 0); +lean_dec(x_33); +lean_ctor_set(x_31, 0, x_26); +return x_31; } else { -lean_object* x_30; lean_object* x_31; -x_30 = lean_ctor_get(x_27, 1); -lean_inc(x_30); -lean_dec(x_27); -x_31 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_31, 0, x_25); -lean_ctor_set(x_31, 1, x_30); -return x_31; +lean_object* x_34; lean_object* x_35; +x_34 = lean_ctor_get(x_31, 1); +lean_inc(x_34); +lean_dec(x_31); +x_35 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_35, 0, x_26); +lean_ctor_set(x_35, 1, x_34); +return x_35; } } } diff --git a/stage0/stdlib/Lean/Expr.c b/stage0/stdlib/Lean/Expr.c index f25d24cb31..c95addfa0a 100644 --- a/stage0/stdlib/Lean/Expr.c +++ b/stage0/stdlib/Lean/Expr.c @@ -6885,10 +6885,12 @@ return x_4; lean_object* l_Lean_Expr_replaceFVarId(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { -lean_object* x_4; lean_object* x_5; +lean_object* x_4; lean_object* x_5; lean_object* x_6; x_4 = l_Lean_mkFVar(x_2); -x_5 = l_Lean_Expr_replaceFVar(x_1, x_4, x_3); -return x_5; +x_5 = l_Lean_mkFVar(x_3); +x_6 = l_Lean_Expr_replaceFVar(x_1, x_4, x_5); +lean_dec(x_5); +return x_6; } } lean_object* l_Lean_Expr_replaceFVarId___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { @@ -6896,7 +6898,6 @@ _start: { lean_object* x_4; x_4 = l_Lean_Expr_replaceFVarId(x_1, x_2, x_3); -lean_dec(x_3); lean_dec(x_1); return x_4; } diff --git a/stage0/stdlib/Lean/Meta/Basic.c b/stage0/stdlib/Lean/Meta/Basic.c index 814a0b78e8..d502f2353a 100644 --- a/stage0/stdlib/Lean/Meta/Basic.c +++ b/stage0/stdlib/Lean/Meta/Basic.c @@ -90,6 +90,7 @@ lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTeles lean_object* lean_dbg_trace(lean_object*, lean_object*); lean_object* lean_io_mk_ref(lean_object*, lean_object*); lean_object* l_Lean_Meta_forallTelescope(lean_object*); +lean_object* l_Lean_Meta_setMCtx___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__3___rarg___lambda__1(lean_object*, lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_ReaderT_bind___at_Lean_Meta_isClassExpensive___main___spec__4___rarg(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_io_ref_get(lean_object*, lean_object*); @@ -193,6 +194,7 @@ lean_object* l___private_Lean_Meta_Basic_4__forallTelescopeReducingAuxAux___rarg lean_object* l___private_Lean_Meta_Basic_4__forallTelescopeReducingAuxAux___main___rarg___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Meta_Basic_2__getTraceState(lean_object*); uint8_t l_Lean_Meta_InfoCacheKey_HasBeq(lean_object*, lean_object*); +lean_object* l_Lean_Meta_throwOther___rarg(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_MetavarContext_instantiateLevelMVars___main(lean_object*, lean_object*); lean_object* l_Lean_Meta_mkWHNFRef___lambda__1___closed__2; lean_object* l_Lean_Meta_mkInferTypeRef___lambda__1___closed__2; @@ -206,6 +208,7 @@ lean_object* l___private_Lean_Meta_Basic_4__forallTelescopeReducingAuxAux___main lean_object* l_Lean_Expr_headBeta(lean_object*); lean_object* l_Lean_Meta_mkMetaExtension___closed__2; lean_object* l___private_Lean_Meta_Basic_7__forallMetaTelescopeReducingAux___main(uint8_t, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_throwOther___rarg___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_mkMetaExtension___closed__1; lean_object* l_Lean_Meta_getOptions___boxed(lean_object*, lean_object*); lean_object* l_Lean_Meta_mkInferTypeRef___lambda__1___boxed(lean_object*, lean_object*, lean_object*); @@ -398,6 +401,7 @@ lean_object* l_Std_PersistentHashMap_empty___at_Lean_Meta_run___spec__1___closed lean_object* lean_metavar_ctx_find_decl(lean_object*, lean_object*); lean_object* l_Lean_Meta_dbgTrace(lean_object*); lean_object* l_Lean_Meta_mkFreshId(lean_object*); +lean_object* l_Lean_Meta_throwOther(lean_object*); lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__3___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_TransparencyMode_beq___boxed(lean_object*, lean_object*); lean_object* lean_get_stdout(lean_object*); @@ -473,6 +477,7 @@ lean_object* l_Lean_Meta_getParamNames(lean_object*, lean_object*, lean_object*) lean_object* l_Lean_Meta_mkFreshLevelMVarId___boxed(lean_object*); lean_object* l___private_Lean_Meta_Basic_6__lambdaTelescopeAux(lean_object*); lean_object* l___private_Lean_Meta_Basic_2__getTraceState___rarg(lean_object*); +lean_object* l_Lean_Meta_setMCtx(lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Meta_Basic_3__liftMkBindingM___rarg(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_mkInferTypeRef___closed__1; lean_object* l_IO_runMeta___rarg(lean_object*, lean_object*, lean_object*, uint8_t, lean_object*); @@ -1145,6 +1150,61 @@ lean_dec(x_1); return x_2; } } +lean_object* l_Lean_Meta_setMCtx(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +uint8_t x_4; +x_4 = !lean_is_exclusive(x_3); +if (x_4 == 0) +{ +lean_object* x_5; lean_object* x_6; lean_object* x_7; +x_5 = lean_ctor_get(x_3, 1); +lean_dec(x_5); +lean_ctor_set(x_3, 1, x_1); +x_6 = lean_box(0); +x_7 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_7, 0, x_6); +lean_ctor_set(x_7, 1, x_3); +return x_7; +} +else +{ +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; +x_8 = lean_ctor_get(x_3, 0); +x_9 = lean_ctor_get(x_3, 2); +x_10 = lean_ctor_get(x_3, 3); +x_11 = lean_ctor_get(x_3, 4); +x_12 = lean_ctor_get(x_3, 5); +lean_inc(x_12); +lean_inc(x_11); +lean_inc(x_10); +lean_inc(x_9); +lean_inc(x_8); +lean_dec(x_3); +x_13 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_13, 0, x_8); +lean_ctor_set(x_13, 1, x_1); +lean_ctor_set(x_13, 2, x_9); +lean_ctor_set(x_13, 3, x_10); +lean_ctor_set(x_13, 4, x_11); +lean_ctor_set(x_13, 5, x_12); +x_14 = lean_box(0); +x_15 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_15, 0, x_14); +lean_ctor_set(x_15, 1, x_13); +return x_15; +} +} +} +lean_object* l_Lean_Meta_setMCtx___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; +x_4 = l_Lean_Meta_setMCtx(x_1, x_2, x_3); +lean_dec(x_2); +return x_4; +} +} lean_object* l_Lean_Meta_getEnv___rarg(lean_object* x_1) { _start: { @@ -3006,6 +3066,52 @@ lean_dec(x_2); return x_4; } } +lean_object* l_Lean_Meta_throwOther___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; lean_object* x_5; lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; +x_4 = lean_ctor_get(x_3, 0); +lean_inc(x_4); +x_5 = lean_ctor_get(x_3, 1); +lean_inc(x_5); +x_6 = lean_ctor_get(x_2, 1); +x_7 = lean_ctor_get(x_2, 0); +x_8 = lean_ctor_get(x_7, 0); +lean_inc(x_8); +lean_inc(x_6); +x_9 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_9, 0, x_4); +lean_ctor_set(x_9, 1, x_5); +lean_ctor_set(x_9, 2, x_6); +lean_ctor_set(x_9, 3, x_8); +x_10 = lean_alloc_ctor(6, 2, 0); +lean_ctor_set(x_10, 0, x_9); +lean_ctor_set(x_10, 1, x_1); +x_11 = lean_alloc_ctor(22, 1, 0); +lean_ctor_set(x_11, 0, x_10); +x_12 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_12, 0, x_11); +lean_ctor_set(x_12, 1, x_3); +return x_12; +} +} +lean_object* l_Lean_Meta_throwOther(lean_object* x_1) { +_start: +{ +lean_object* x_2; +x_2 = lean_alloc_closure((void*)(l_Lean_Meta_throwOther___rarg___boxed), 3, 0); +return x_2; +} +} +lean_object* l_Lean_Meta_throwOther___rarg___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; +x_4 = l_Lean_Meta_throwOther___rarg(x_1, x_2, x_3); +lean_dec(x_2); +return x_4; +} +} lean_object* l_Lean_Meta_throwBug___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { @@ -6971,40 +7077,40 @@ x_5 = lean_ctor_get(x_3, 2); x_6 = !lean_is_exclusive(x_5); if (x_6 == 0) { -lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_59; lean_object* x_60; +lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_63; lean_object* x_64; x_7 = lean_ctor_get(x_5, 2); -x_59 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_5, 2, x_59); -x_60 = lean_apply_2(x_1, x_2, x_3); -if (lean_obj_tag(x_60) == 0) +x_63 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_5, 2, x_63); +x_64 = lean_apply_2(x_1, x_2, x_3); +if (lean_obj_tag(x_64) == 0) { -lean_object* x_61; lean_object* x_62; lean_object* x_63; -x_61 = lean_ctor_get(x_60, 0); -lean_inc(x_61); -x_62 = lean_ctor_get(x_60, 1); -lean_inc(x_62); -lean_dec(x_60); -x_63 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_63, 0, x_61); -x_8 = x_63; -x_9 = x_62; -goto block_58; +lean_object* x_65; lean_object* x_66; lean_object* x_67; +x_65 = lean_ctor_get(x_64, 0); +lean_inc(x_65); +x_66 = lean_ctor_get(x_64, 1); +lean_inc(x_66); +lean_dec(x_64); +x_67 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_67, 0, x_65); +x_8 = x_67; +x_9 = x_66; +goto block_62; } else { -lean_object* x_64; lean_object* x_65; lean_object* x_66; -x_64 = lean_ctor_get(x_60, 0); -lean_inc(x_64); -x_65 = lean_ctor_get(x_60, 1); -lean_inc(x_65); -lean_dec(x_60); -x_66 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_66, 0, x_64); -x_8 = x_66; -x_9 = x_65; -goto block_58; +lean_object* x_68; lean_object* x_69; lean_object* x_70; +x_68 = lean_ctor_get(x_64, 0); +lean_inc(x_68); +x_69 = lean_ctor_get(x_64, 1); +lean_inc(x_69); +lean_dec(x_64); +x_70 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_70, 0, x_68); +x_8 = x_70; +x_9 = x_69; +goto block_62; } -block_58: +block_62: { if (lean_obj_tag(x_8) == 0) { @@ -7034,598 +7140,635 @@ return x_16; } else { -lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; +lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; x_17 = lean_ctor_get(x_10, 0); x_18 = lean_ctor_get(x_10, 1); x_19 = lean_ctor_get(x_10, 3); +x_20 = lean_ctor_get(x_10, 4); +lean_inc(x_20); lean_inc(x_19); lean_inc(x_18); lean_inc(x_17); lean_dec(x_10); -x_20 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_20, 0, x_17); -lean_ctor_set(x_20, 1, x_18); -lean_ctor_set(x_20, 2, x_7); -lean_ctor_set(x_20, 3, x_19); -lean_ctor_set(x_9, 2, x_20); -x_21 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_21, 0, x_11); -lean_ctor_set(x_21, 1, x_9); -return x_21; +x_21 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_21, 0, x_17); +lean_ctor_set(x_21, 1, x_18); +lean_ctor_set(x_21, 2, x_7); +lean_ctor_set(x_21, 3, x_19); +lean_ctor_set(x_21, 4, x_20); +lean_ctor_set(x_9, 2, x_21); +x_22 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_22, 0, x_11); +lean_ctor_set(x_22, 1, x_9); +return x_22; } } else { -lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; -x_22 = lean_ctor_get(x_9, 0); -x_23 = lean_ctor_get(x_9, 1); -x_24 = lean_ctor_get(x_9, 3); -x_25 = lean_ctor_get(x_9, 4); -x_26 = lean_ctor_get(x_9, 5); +lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; +x_23 = lean_ctor_get(x_9, 0); +x_24 = lean_ctor_get(x_9, 1); +x_25 = lean_ctor_get(x_9, 3); +x_26 = lean_ctor_get(x_9, 4); +x_27 = lean_ctor_get(x_9, 5); +lean_inc(x_27); lean_inc(x_26); lean_inc(x_25); lean_inc(x_24); lean_inc(x_23); -lean_inc(x_22); lean_dec(x_9); -x_27 = lean_ctor_get(x_10, 0); -lean_inc(x_27); -x_28 = lean_ctor_get(x_10, 1); +x_28 = lean_ctor_get(x_10, 0); lean_inc(x_28); -x_29 = lean_ctor_get(x_10, 3); +x_29 = lean_ctor_get(x_10, 1); lean_inc(x_29); +x_30 = lean_ctor_get(x_10, 3); +lean_inc(x_30); +x_31 = lean_ctor_get(x_10, 4); +lean_inc(x_31); if (lean_is_exclusive(x_10)) { lean_ctor_release(x_10, 0); lean_ctor_release(x_10, 1); lean_ctor_release(x_10, 2); lean_ctor_release(x_10, 3); - x_30 = x_10; + lean_ctor_release(x_10, 4); + x_32 = x_10; } else { lean_dec_ref(x_10); - x_30 = lean_box(0); + x_32 = lean_box(0); } -if (lean_is_scalar(x_30)) { - x_31 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_32)) { + x_33 = lean_alloc_ctor(0, 5, 0); } else { - x_31 = x_30; + x_33 = x_32; } -lean_ctor_set(x_31, 0, x_27); -lean_ctor_set(x_31, 1, x_28); -lean_ctor_set(x_31, 2, x_7); -lean_ctor_set(x_31, 3, x_29); -x_32 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_32, 0, x_22); -lean_ctor_set(x_32, 1, x_23); -lean_ctor_set(x_32, 2, x_31); -lean_ctor_set(x_32, 3, x_24); -lean_ctor_set(x_32, 4, x_25); -lean_ctor_set(x_32, 5, x_26); -x_33 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_33, 0, x_11); -lean_ctor_set(x_33, 1, x_32); -return x_33; +lean_ctor_set(x_33, 0, x_28); +lean_ctor_set(x_33, 1, x_29); +lean_ctor_set(x_33, 2, x_7); +lean_ctor_set(x_33, 3, x_30); +lean_ctor_set(x_33, 4, x_31); +x_34 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_34, 0, x_23); +lean_ctor_set(x_34, 1, x_24); +lean_ctor_set(x_34, 2, x_33); +lean_ctor_set(x_34, 3, x_25); +lean_ctor_set(x_34, 4, x_26); +lean_ctor_set(x_34, 5, x_27); +x_35 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_35, 0, x_11); +lean_ctor_set(x_35, 1, x_34); +return x_35; } } else { -lean_object* x_34; lean_object* x_35; uint8_t x_36; -x_34 = lean_ctor_get(x_9, 2); -lean_inc(x_34); -x_35 = lean_ctor_get(x_8, 0); -lean_inc(x_35); +lean_object* x_36; lean_object* x_37; uint8_t x_38; +x_36 = lean_ctor_get(x_9, 2); +lean_inc(x_36); +x_37 = lean_ctor_get(x_8, 0); +lean_inc(x_37); lean_dec(x_8); -x_36 = !lean_is_exclusive(x_9); -if (x_36 == 0) -{ -lean_object* x_37; uint8_t x_38; -x_37 = lean_ctor_get(x_9, 2); -lean_dec(x_37); -x_38 = !lean_is_exclusive(x_34); +x_38 = !lean_is_exclusive(x_9); if (x_38 == 0) { -lean_object* x_39; lean_object* x_40; -x_39 = lean_ctor_get(x_34, 2); +lean_object* x_39; uint8_t x_40; +x_39 = lean_ctor_get(x_9, 2); lean_dec(x_39); -lean_ctor_set(x_34, 2, x_7); -x_40 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_40, 0, x_35); -lean_ctor_set(x_40, 1, x_9); -return x_40; +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, 2); +lean_dec(x_41); +lean_ctor_set(x_36, 2, x_7); +x_42 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_42, 0, x_37); +lean_ctor_set(x_42, 1, x_9); +return x_42; } else { -lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; -x_41 = lean_ctor_get(x_34, 0); -x_42 = lean_ctor_get(x_34, 1); -x_43 = lean_ctor_get(x_34, 3); +lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; +x_43 = lean_ctor_get(x_36, 0); +x_44 = lean_ctor_get(x_36, 1); +x_45 = lean_ctor_get(x_36, 3); +x_46 = lean_ctor_get(x_36, 4); +lean_inc(x_46); +lean_inc(x_45); +lean_inc(x_44); lean_inc(x_43); -lean_inc(x_42); -lean_inc(x_41); -lean_dec(x_34); -x_44 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_44, 0, x_41); -lean_ctor_set(x_44, 1, x_42); -lean_ctor_set(x_44, 2, x_7); -lean_ctor_set(x_44, 3, x_43); -lean_ctor_set(x_9, 2, x_44); -x_45 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_45, 0, x_35); -lean_ctor_set(x_45, 1, x_9); -return x_45; +lean_dec(x_36); +x_47 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_47, 0, x_43); +lean_ctor_set(x_47, 1, x_44); +lean_ctor_set(x_47, 2, x_7); +lean_ctor_set(x_47, 3, x_45); +lean_ctor_set(x_47, 4, x_46); +lean_ctor_set(x_9, 2, x_47); +x_48 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_48, 0, x_37); +lean_ctor_set(x_48, 1, x_9); +return x_48; } } 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; -x_46 = lean_ctor_get(x_9, 0); -x_47 = lean_ctor_get(x_9, 1); -x_48 = lean_ctor_get(x_9, 3); -x_49 = lean_ctor_get(x_9, 4); -x_50 = lean_ctor_get(x_9, 5); +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; +x_49 = lean_ctor_get(x_9, 0); +x_50 = lean_ctor_get(x_9, 1); +x_51 = lean_ctor_get(x_9, 3); +x_52 = lean_ctor_get(x_9, 4); +x_53 = lean_ctor_get(x_9, 5); +lean_inc(x_53); +lean_inc(x_52); +lean_inc(x_51); lean_inc(x_50); lean_inc(x_49); -lean_inc(x_48); -lean_inc(x_47); -lean_inc(x_46); lean_dec(x_9); -x_51 = lean_ctor_get(x_34, 0); -lean_inc(x_51); -x_52 = lean_ctor_get(x_34, 1); -lean_inc(x_52); -x_53 = lean_ctor_get(x_34, 3); -lean_inc(x_53); -if (lean_is_exclusive(x_34)) { - lean_ctor_release(x_34, 0); - lean_ctor_release(x_34, 1); - lean_ctor_release(x_34, 2); - lean_ctor_release(x_34, 3); - x_54 = x_34; +x_54 = lean_ctor_get(x_36, 0); +lean_inc(x_54); +x_55 = lean_ctor_get(x_36, 1); +lean_inc(x_55); +x_56 = lean_ctor_get(x_36, 3); +lean_inc(x_56); +x_57 = lean_ctor_get(x_36, 4); +lean_inc(x_57); +if (lean_is_exclusive(x_36)) { + lean_ctor_release(x_36, 0); + lean_ctor_release(x_36, 1); + lean_ctor_release(x_36, 2); + lean_ctor_release(x_36, 3); + lean_ctor_release(x_36, 4); + x_58 = x_36; } else { - lean_dec_ref(x_34); - x_54 = lean_box(0); + lean_dec_ref(x_36); + x_58 = lean_box(0); } -if (lean_is_scalar(x_54)) { - x_55 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_58)) { + x_59 = lean_alloc_ctor(0, 5, 0); } else { - x_55 = x_54; + x_59 = x_58; } -lean_ctor_set(x_55, 0, x_51); -lean_ctor_set(x_55, 1, x_52); -lean_ctor_set(x_55, 2, x_7); -lean_ctor_set(x_55, 3, x_53); -x_56 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_56, 0, x_46); -lean_ctor_set(x_56, 1, x_47); -lean_ctor_set(x_56, 2, x_55); -lean_ctor_set(x_56, 3, x_48); -lean_ctor_set(x_56, 4, x_49); -lean_ctor_set(x_56, 5, x_50); -x_57 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_57, 0, x_35); -lean_ctor_set(x_57, 1, x_56); -return x_57; +lean_ctor_set(x_59, 0, x_54); +lean_ctor_set(x_59, 1, x_55); +lean_ctor_set(x_59, 2, x_7); +lean_ctor_set(x_59, 3, x_56); +lean_ctor_set(x_59, 4, x_57); +x_60 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_60, 0, x_49); +lean_ctor_set(x_60, 1, x_50); +lean_ctor_set(x_60, 2, x_59); +lean_ctor_set(x_60, 3, x_51); +lean_ctor_set(x_60, 4, x_52); +lean_ctor_set(x_60, 5, x_53); +x_61 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_61, 0, x_37); +lean_ctor_set(x_61, 1, x_60); +return x_61; } } } } 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_104; lean_object* x_105; lean_object* x_106; -x_67 = lean_ctor_get(x_5, 0); -x_68 = lean_ctor_get(x_5, 1); -x_69 = lean_ctor_get(x_5, 2); -x_70 = lean_ctor_get(x_5, 3); -lean_inc(x_70); -lean_inc(x_69); -lean_inc(x_68); -lean_inc(x_67); -lean_dec(x_5); -x_104 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_105 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_105, 0, x_67); -lean_ctor_set(x_105, 1, x_68); -lean_ctor_set(x_105, 2, x_104); -lean_ctor_set(x_105, 3, x_70); -lean_ctor_set(x_3, 2, x_105); -x_106 = lean_apply_2(x_1, x_2, x_3); -if (lean_obj_tag(x_106) == 0) -{ -lean_object* x_107; lean_object* x_108; lean_object* x_109; -x_107 = lean_ctor_get(x_106, 0); -lean_inc(x_107); -x_108 = lean_ctor_get(x_106, 1); -lean_inc(x_108); -lean_dec(x_106); -x_109 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_109, 0, x_107); -x_71 = x_109; -x_72 = x_108; -goto block_103; -} -else -{ -lean_object* x_110; lean_object* x_111; lean_object* x_112; -x_110 = lean_ctor_get(x_106, 0); -lean_inc(x_110); -x_111 = lean_ctor_get(x_106, 1); -lean_inc(x_111); -lean_dec(x_106); -x_112 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_112, 0, x_110); -x_71 = x_112; -x_72 = x_111; -goto block_103; -} -block_103: -{ -if (lean_obj_tag(x_71) == 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; -x_73 = lean_ctor_get(x_72, 2); -lean_inc(x_73); -x_74 = lean_ctor_get(x_71, 0); -lean_inc(x_74); -lean_dec(x_71); -x_75 = lean_ctor_get(x_72, 0); +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_111; lean_object* x_112; lean_object* x_113; +x_71 = lean_ctor_get(x_5, 0); +x_72 = lean_ctor_get(x_5, 1); +x_73 = lean_ctor_get(x_5, 2); +x_74 = lean_ctor_get(x_5, 3); +x_75 = lean_ctor_get(x_5, 4); lean_inc(x_75); -x_76 = lean_ctor_get(x_72, 1); -lean_inc(x_76); -x_77 = lean_ctor_get(x_72, 3); -lean_inc(x_77); -x_78 = lean_ctor_get(x_72, 4); -lean_inc(x_78); -x_79 = lean_ctor_get(x_72, 5); -lean_inc(x_79); -if (lean_is_exclusive(x_72)) { - lean_ctor_release(x_72, 0); - lean_ctor_release(x_72, 1); - lean_ctor_release(x_72, 2); - lean_ctor_release(x_72, 3); - lean_ctor_release(x_72, 4); - lean_ctor_release(x_72, 5); - x_80 = x_72; -} else { - lean_dec_ref(x_72); - x_80 = lean_box(0); -} -x_81 = lean_ctor_get(x_73, 0); -lean_inc(x_81); -x_82 = lean_ctor_get(x_73, 1); -lean_inc(x_82); -x_83 = lean_ctor_get(x_73, 3); -lean_inc(x_83); -if (lean_is_exclusive(x_73)) { - lean_ctor_release(x_73, 0); - lean_ctor_release(x_73, 1); - lean_ctor_release(x_73, 2); - lean_ctor_release(x_73, 3); - x_84 = x_73; -} else { - lean_dec_ref(x_73); - x_84 = lean_box(0); -} -if (lean_is_scalar(x_84)) { - x_85 = lean_alloc_ctor(0, 4, 0); -} else { - x_85 = x_84; -} -lean_ctor_set(x_85, 0, x_81); -lean_ctor_set(x_85, 1, x_82); -lean_ctor_set(x_85, 2, x_69); -lean_ctor_set(x_85, 3, x_83); -if (lean_is_scalar(x_80)) { - x_86 = lean_alloc_ctor(0, 6, 0); -} else { - x_86 = x_80; -} -lean_ctor_set(x_86, 0, x_75); -lean_ctor_set(x_86, 1, x_76); -lean_ctor_set(x_86, 2, x_85); -lean_ctor_set(x_86, 3, x_77); -lean_ctor_set(x_86, 4, x_78); -lean_ctor_set(x_86, 5, x_79); -x_87 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_87, 0, x_74); -lean_ctor_set(x_87, 1, x_86); -return x_87; -} -else +lean_inc(x_74); +lean_inc(x_73); +lean_inc(x_72); +lean_inc(x_71); +lean_dec(x_5); +x_111 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_112 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_112, 0, x_71); +lean_ctor_set(x_112, 1, x_72); +lean_ctor_set(x_112, 2, x_111); +lean_ctor_set(x_112, 3, x_74); +lean_ctor_set(x_112, 4, x_75); +lean_ctor_set(x_3, 2, x_112); +x_113 = lean_apply_2(x_1, x_2, x_3); +if (lean_obj_tag(x_113) == 0) { -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; -x_88 = lean_ctor_get(x_72, 2); -lean_inc(x_88); -x_89 = lean_ctor_get(x_71, 0); -lean_inc(x_89); -lean_dec(x_71); -x_90 = lean_ctor_get(x_72, 0); -lean_inc(x_90); -x_91 = lean_ctor_get(x_72, 1); -lean_inc(x_91); -x_92 = lean_ctor_get(x_72, 3); -lean_inc(x_92); -x_93 = lean_ctor_get(x_72, 4); -lean_inc(x_93); -x_94 = lean_ctor_get(x_72, 5); -lean_inc(x_94); -if (lean_is_exclusive(x_72)) { - lean_ctor_release(x_72, 0); - lean_ctor_release(x_72, 1); - lean_ctor_release(x_72, 2); - lean_ctor_release(x_72, 3); - lean_ctor_release(x_72, 4); - lean_ctor_release(x_72, 5); - x_95 = x_72; -} else { - lean_dec_ref(x_72); - x_95 = lean_box(0); -} -x_96 = lean_ctor_get(x_88, 0); -lean_inc(x_96); -x_97 = lean_ctor_get(x_88, 1); -lean_inc(x_97); -x_98 = lean_ctor_get(x_88, 3); -lean_inc(x_98); -if (lean_is_exclusive(x_88)) { - lean_ctor_release(x_88, 0); - lean_ctor_release(x_88, 1); - lean_ctor_release(x_88, 2); - lean_ctor_release(x_88, 3); - x_99 = x_88; -} else { - lean_dec_ref(x_88); - x_99 = lean_box(0); -} -if (lean_is_scalar(x_99)) { - x_100 = lean_alloc_ctor(0, 4, 0); -} else { - x_100 = x_99; -} -lean_ctor_set(x_100, 0, x_96); -lean_ctor_set(x_100, 1, x_97); -lean_ctor_set(x_100, 2, x_69); -lean_ctor_set(x_100, 3, x_98); -if (lean_is_scalar(x_95)) { - x_101 = lean_alloc_ctor(0, 6, 0); -} else { - x_101 = x_95; -} -lean_ctor_set(x_101, 0, x_90); -lean_ctor_set(x_101, 1, x_91); -lean_ctor_set(x_101, 2, x_100); -lean_ctor_set(x_101, 3, x_92); -lean_ctor_set(x_101, 4, x_93); -lean_ctor_set(x_101, 5, x_94); -x_102 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_102, 0, x_89); -lean_ctor_set(x_102, 1, x_101); -return x_102; -} -} -} -} -else -{ -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_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; -x_113 = lean_ctor_get(x_3, 2); -x_114 = lean_ctor_get(x_3, 0); -x_115 = lean_ctor_get(x_3, 1); -x_116 = lean_ctor_get(x_3, 3); -x_117 = lean_ctor_get(x_3, 4); -x_118 = lean_ctor_get(x_3, 5); -lean_inc(x_118); -lean_inc(x_117); -lean_inc(x_116); -lean_inc(x_113); -lean_inc(x_115); +lean_object* x_114; lean_object* x_115; lean_object* x_116; +x_114 = lean_ctor_get(x_113, 0); lean_inc(x_114); -lean_dec(x_3); -x_119 = lean_ctor_get(x_113, 0); -lean_inc(x_119); -x_120 = lean_ctor_get(x_113, 1); +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_114); +x_76 = x_116; +x_77 = x_115; +goto block_110; +} +else +{ +lean_object* x_117; lean_object* x_118; lean_object* x_119; +x_117 = lean_ctor_get(x_113, 0); +lean_inc(x_117); +x_118 = lean_ctor_get(x_113, 1); +lean_inc(x_118); +lean_dec(x_113); +x_119 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_119, 0, x_117); +x_76 = x_119; +x_77 = x_118; +goto block_110; +} +block_110: +{ +if (lean_obj_tag(x_76) == 0) +{ +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; +x_78 = lean_ctor_get(x_77, 2); +lean_inc(x_78); +x_79 = lean_ctor_get(x_76, 0); +lean_inc(x_79); +lean_dec(x_76); +x_80 = lean_ctor_get(x_77, 0); +lean_inc(x_80); +x_81 = lean_ctor_get(x_77, 1); +lean_inc(x_81); +x_82 = lean_ctor_get(x_77, 3); +lean_inc(x_82); +x_83 = lean_ctor_get(x_77, 4); +lean_inc(x_83); +x_84 = lean_ctor_get(x_77, 5); +lean_inc(x_84); +if (lean_is_exclusive(x_77)) { + lean_ctor_release(x_77, 0); + lean_ctor_release(x_77, 1); + lean_ctor_release(x_77, 2); + lean_ctor_release(x_77, 3); + lean_ctor_release(x_77, 4); + lean_ctor_release(x_77, 5); + x_85 = x_77; +} else { + lean_dec_ref(x_77); + x_85 = lean_box(0); +} +x_86 = lean_ctor_get(x_78, 0); +lean_inc(x_86); +x_87 = lean_ctor_get(x_78, 1); +lean_inc(x_87); +x_88 = lean_ctor_get(x_78, 3); +lean_inc(x_88); +x_89 = lean_ctor_get(x_78, 4); +lean_inc(x_89); +if (lean_is_exclusive(x_78)) { + lean_ctor_release(x_78, 0); + lean_ctor_release(x_78, 1); + lean_ctor_release(x_78, 2); + lean_ctor_release(x_78, 3); + lean_ctor_release(x_78, 4); + x_90 = x_78; +} else { + lean_dec_ref(x_78); + x_90 = lean_box(0); +} +if (lean_is_scalar(x_90)) { + x_91 = lean_alloc_ctor(0, 5, 0); +} else { + x_91 = x_90; +} +lean_ctor_set(x_91, 0, x_86); +lean_ctor_set(x_91, 1, x_87); +lean_ctor_set(x_91, 2, x_73); +lean_ctor_set(x_91, 3, x_88); +lean_ctor_set(x_91, 4, x_89); +if (lean_is_scalar(x_85)) { + x_92 = lean_alloc_ctor(0, 6, 0); +} else { + x_92 = x_85; +} +lean_ctor_set(x_92, 0, x_80); +lean_ctor_set(x_92, 1, x_81); +lean_ctor_set(x_92, 2, x_91); +lean_ctor_set(x_92, 3, x_82); +lean_ctor_set(x_92, 4, x_83); +lean_ctor_set(x_92, 5, x_84); +x_93 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_93, 0, x_79); +lean_ctor_set(x_93, 1, x_92); +return x_93; +} +else +{ +lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; +x_94 = lean_ctor_get(x_77, 2); +lean_inc(x_94); +x_95 = lean_ctor_get(x_76, 0); +lean_inc(x_95); +lean_dec(x_76); +x_96 = lean_ctor_get(x_77, 0); +lean_inc(x_96); +x_97 = lean_ctor_get(x_77, 1); +lean_inc(x_97); +x_98 = lean_ctor_get(x_77, 3); +lean_inc(x_98); +x_99 = lean_ctor_get(x_77, 4); +lean_inc(x_99); +x_100 = lean_ctor_get(x_77, 5); +lean_inc(x_100); +if (lean_is_exclusive(x_77)) { + lean_ctor_release(x_77, 0); + lean_ctor_release(x_77, 1); + lean_ctor_release(x_77, 2); + lean_ctor_release(x_77, 3); + lean_ctor_release(x_77, 4); + lean_ctor_release(x_77, 5); + x_101 = x_77; +} else { + lean_dec_ref(x_77); + x_101 = lean_box(0); +} +x_102 = lean_ctor_get(x_94, 0); +lean_inc(x_102); +x_103 = lean_ctor_get(x_94, 1); +lean_inc(x_103); +x_104 = lean_ctor_get(x_94, 3); +lean_inc(x_104); +x_105 = lean_ctor_get(x_94, 4); +lean_inc(x_105); +if (lean_is_exclusive(x_94)) { + lean_ctor_release(x_94, 0); + lean_ctor_release(x_94, 1); + lean_ctor_release(x_94, 2); + lean_ctor_release(x_94, 3); + lean_ctor_release(x_94, 4); + x_106 = x_94; +} else { + lean_dec_ref(x_94); + x_106 = lean_box(0); +} +if (lean_is_scalar(x_106)) { + x_107 = lean_alloc_ctor(0, 5, 0); +} else { + x_107 = x_106; +} +lean_ctor_set(x_107, 0, x_102); +lean_ctor_set(x_107, 1, x_103); +lean_ctor_set(x_107, 2, x_73); +lean_ctor_set(x_107, 3, x_104); +lean_ctor_set(x_107, 4, x_105); +if (lean_is_scalar(x_101)) { + x_108 = lean_alloc_ctor(0, 6, 0); +} else { + x_108 = x_101; +} +lean_ctor_set(x_108, 0, x_96); +lean_ctor_set(x_108, 1, x_97); +lean_ctor_set(x_108, 2, x_107); +lean_ctor_set(x_108, 3, x_98); +lean_ctor_set(x_108, 4, x_99); +lean_ctor_set(x_108, 5, x_100); +x_109 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_109, 0, x_95); +lean_ctor_set(x_109, 1, x_108); +return x_109; +} +} +} +} +else +{ +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_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; +x_120 = lean_ctor_get(x_3, 2); +x_121 = lean_ctor_get(x_3, 0); +x_122 = lean_ctor_get(x_3, 1); +x_123 = lean_ctor_get(x_3, 3); +x_124 = lean_ctor_get(x_3, 4); +x_125 = lean_ctor_get(x_3, 5); +lean_inc(x_125); +lean_inc(x_124); +lean_inc(x_123); lean_inc(x_120); -x_121 = lean_ctor_get(x_113, 2); -lean_inc(x_121); -x_122 = lean_ctor_get(x_113, 3); lean_inc(x_122); -if (lean_is_exclusive(x_113)) { - lean_ctor_release(x_113, 0); - lean_ctor_release(x_113, 1); - lean_ctor_release(x_113, 2); - lean_ctor_release(x_113, 3); - x_123 = x_113; -} else { - lean_dec_ref(x_113); - x_123 = lean_box(0); -} -x_157 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_123)) { - x_158 = lean_alloc_ctor(0, 4, 0); -} else { - x_158 = x_123; -} -lean_ctor_set(x_158, 0, x_119); -lean_ctor_set(x_158, 1, x_120); -lean_ctor_set(x_158, 2, x_157); -lean_ctor_set(x_158, 3, x_122); -x_159 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_159, 0, x_114); -lean_ctor_set(x_159, 1, x_115); -lean_ctor_set(x_159, 2, x_158); -lean_ctor_set(x_159, 3, x_116); -lean_ctor_set(x_159, 4, x_117); -lean_ctor_set(x_159, 5, x_118); -x_160 = lean_apply_2(x_1, x_2, x_159); -if (lean_obj_tag(x_160) == 0) -{ -lean_object* x_161; lean_object* x_162; lean_object* x_163; -x_161 = lean_ctor_get(x_160, 0); -lean_inc(x_161); -x_162 = lean_ctor_get(x_160, 1); -lean_inc(x_162); -lean_dec(x_160); -x_163 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_163, 0, x_161); -x_124 = x_163; -x_125 = x_162; -goto block_156; -} -else -{ -lean_object* x_164; lean_object* x_165; lean_object* x_166; -x_164 = lean_ctor_get(x_160, 0); -lean_inc(x_164); -x_165 = lean_ctor_get(x_160, 1); -lean_inc(x_165); -lean_dec(x_160); -x_166 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_166, 0, x_164); -x_124 = x_166; -x_125 = x_165; -goto block_156; -} -block_156: -{ -if (lean_obj_tag(x_124) == 0) -{ -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; -x_126 = lean_ctor_get(x_125, 2); +lean_inc(x_121); +lean_dec(x_3); +x_126 = lean_ctor_get(x_120, 0); lean_inc(x_126); -x_127 = lean_ctor_get(x_124, 0); +x_127 = lean_ctor_get(x_120, 1); lean_inc(x_127); -lean_dec(x_124); -x_128 = lean_ctor_get(x_125, 0); +x_128 = lean_ctor_get(x_120, 2); lean_inc(x_128); -x_129 = lean_ctor_get(x_125, 1); +x_129 = lean_ctor_get(x_120, 3); lean_inc(x_129); -x_130 = lean_ctor_get(x_125, 3); +x_130 = lean_ctor_get(x_120, 4); lean_inc(x_130); -x_131 = lean_ctor_get(x_125, 4); -lean_inc(x_131); -x_132 = lean_ctor_get(x_125, 5); -lean_inc(x_132); -if (lean_is_exclusive(x_125)) { - lean_ctor_release(x_125, 0); - lean_ctor_release(x_125, 1); - lean_ctor_release(x_125, 2); - lean_ctor_release(x_125, 3); - lean_ctor_release(x_125, 4); - lean_ctor_release(x_125, 5); - x_133 = x_125; +if (lean_is_exclusive(x_120)) { + lean_ctor_release(x_120, 0); + lean_ctor_release(x_120, 1); + lean_ctor_release(x_120, 2); + lean_ctor_release(x_120, 3); + lean_ctor_release(x_120, 4); + x_131 = x_120; } else { - lean_dec_ref(x_125); - x_133 = lean_box(0); + lean_dec_ref(x_120); + x_131 = lean_box(0); } -x_134 = lean_ctor_get(x_126, 0); -lean_inc(x_134); -x_135 = lean_ctor_get(x_126, 1); -lean_inc(x_135); -x_136 = lean_ctor_get(x_126, 3); -lean_inc(x_136); -if (lean_is_exclusive(x_126)) { - lean_ctor_release(x_126, 0); - lean_ctor_release(x_126, 1); - lean_ctor_release(x_126, 2); - lean_ctor_release(x_126, 3); - x_137 = x_126; +x_167 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_131)) { + x_168 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_126); - x_137 = lean_box(0); + x_168 = x_131; } -if (lean_is_scalar(x_137)) { - x_138 = lean_alloc_ctor(0, 4, 0); -} else { - x_138 = x_137; -} -lean_ctor_set(x_138, 0, x_134); -lean_ctor_set(x_138, 1, x_135); -lean_ctor_set(x_138, 2, x_121); -lean_ctor_set(x_138, 3, x_136); -if (lean_is_scalar(x_133)) { - x_139 = lean_alloc_ctor(0, 6, 0); -} else { - x_139 = x_133; -} -lean_ctor_set(x_139, 0, x_128); -lean_ctor_set(x_139, 1, x_129); -lean_ctor_set(x_139, 2, x_138); -lean_ctor_set(x_139, 3, x_130); -lean_ctor_set(x_139, 4, x_131); -lean_ctor_set(x_139, 5, x_132); -x_140 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_140, 0, x_127); -lean_ctor_set(x_140, 1, x_139); -return x_140; +lean_ctor_set(x_168, 0, x_126); +lean_ctor_set(x_168, 1, x_127); +lean_ctor_set(x_168, 2, x_167); +lean_ctor_set(x_168, 3, x_129); +lean_ctor_set(x_168, 4, x_130); +x_169 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_169, 0, x_121); +lean_ctor_set(x_169, 1, x_122); +lean_ctor_set(x_169, 2, x_168); +lean_ctor_set(x_169, 3, x_123); +lean_ctor_set(x_169, 4, x_124); +lean_ctor_set(x_169, 5, x_125); +x_170 = lean_apply_2(x_1, x_2, x_169); +if (lean_obj_tag(x_170) == 0) +{ +lean_object* x_171; lean_object* x_172; lean_object* x_173; +x_171 = lean_ctor_get(x_170, 0); +lean_inc(x_171); +x_172 = lean_ctor_get(x_170, 1); +lean_inc(x_172); +lean_dec(x_170); +x_173 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_173, 0, x_171); +x_132 = x_173; +x_133 = x_172; +goto block_166; } else { -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; -x_141 = lean_ctor_get(x_125, 2); -lean_inc(x_141); -x_142 = lean_ctor_get(x_124, 0); +lean_object* x_174; lean_object* x_175; lean_object* x_176; +x_174 = lean_ctor_get(x_170, 0); +lean_inc(x_174); +x_175 = lean_ctor_get(x_170, 1); +lean_inc(x_175); +lean_dec(x_170); +x_176 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_176, 0, x_174); +x_132 = x_176; +x_133 = x_175; +goto block_166; +} +block_166: +{ +if (lean_obj_tag(x_132) == 0) +{ +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; +x_134 = lean_ctor_get(x_133, 2); +lean_inc(x_134); +x_135 = lean_ctor_get(x_132, 0); +lean_inc(x_135); +lean_dec(x_132); +x_136 = lean_ctor_get(x_133, 0); +lean_inc(x_136); +x_137 = lean_ctor_get(x_133, 1); +lean_inc(x_137); +x_138 = lean_ctor_get(x_133, 3); +lean_inc(x_138); +x_139 = lean_ctor_get(x_133, 4); +lean_inc(x_139); +x_140 = lean_ctor_get(x_133, 5); +lean_inc(x_140); +if (lean_is_exclusive(x_133)) { + lean_ctor_release(x_133, 0); + lean_ctor_release(x_133, 1); + lean_ctor_release(x_133, 2); + lean_ctor_release(x_133, 3); + lean_ctor_release(x_133, 4); + lean_ctor_release(x_133, 5); + x_141 = x_133; +} else { + lean_dec_ref(x_133); + x_141 = lean_box(0); +} +x_142 = lean_ctor_get(x_134, 0); lean_inc(x_142); -lean_dec(x_124); -x_143 = lean_ctor_get(x_125, 0); +x_143 = lean_ctor_get(x_134, 1); lean_inc(x_143); -x_144 = lean_ctor_get(x_125, 1); +x_144 = lean_ctor_get(x_134, 3); lean_inc(x_144); -x_145 = lean_ctor_get(x_125, 3); +x_145 = lean_ctor_get(x_134, 4); lean_inc(x_145); -x_146 = lean_ctor_get(x_125, 4); -lean_inc(x_146); -x_147 = lean_ctor_get(x_125, 5); -lean_inc(x_147); -if (lean_is_exclusive(x_125)) { - lean_ctor_release(x_125, 0); - lean_ctor_release(x_125, 1); - lean_ctor_release(x_125, 2); - lean_ctor_release(x_125, 3); - lean_ctor_release(x_125, 4); - lean_ctor_release(x_125, 5); - x_148 = x_125; +if (lean_is_exclusive(x_134)) { + lean_ctor_release(x_134, 0); + lean_ctor_release(x_134, 1); + lean_ctor_release(x_134, 2); + lean_ctor_release(x_134, 3); + lean_ctor_release(x_134, 4); + x_146 = x_134; } else { - lean_dec_ref(x_125); - x_148 = lean_box(0); + lean_dec_ref(x_134); + x_146 = lean_box(0); } -x_149 = lean_ctor_get(x_141, 0); -lean_inc(x_149); -x_150 = lean_ctor_get(x_141, 1); +if (lean_is_scalar(x_146)) { + x_147 = lean_alloc_ctor(0, 5, 0); +} else { + x_147 = x_146; +} +lean_ctor_set(x_147, 0, x_142); +lean_ctor_set(x_147, 1, x_143); +lean_ctor_set(x_147, 2, x_128); +lean_ctor_set(x_147, 3, x_144); +lean_ctor_set(x_147, 4, x_145); +if (lean_is_scalar(x_141)) { + x_148 = lean_alloc_ctor(0, 6, 0); +} else { + x_148 = x_141; +} +lean_ctor_set(x_148, 0, x_136); +lean_ctor_set(x_148, 1, x_137); +lean_ctor_set(x_148, 2, x_147); +lean_ctor_set(x_148, 3, x_138); +lean_ctor_set(x_148, 4, x_139); +lean_ctor_set(x_148, 5, x_140); +x_149 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_149, 0, x_135); +lean_ctor_set(x_149, 1, x_148); +return x_149; +} +else +{ +lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; +x_150 = lean_ctor_get(x_133, 2); lean_inc(x_150); -x_151 = lean_ctor_get(x_141, 3); +x_151 = lean_ctor_get(x_132, 0); lean_inc(x_151); -if (lean_is_exclusive(x_141)) { - lean_ctor_release(x_141, 0); - lean_ctor_release(x_141, 1); - lean_ctor_release(x_141, 2); - lean_ctor_release(x_141, 3); - x_152 = x_141; +lean_dec(x_132); +x_152 = lean_ctor_get(x_133, 0); +lean_inc(x_152); +x_153 = lean_ctor_get(x_133, 1); +lean_inc(x_153); +x_154 = lean_ctor_get(x_133, 3); +lean_inc(x_154); +x_155 = lean_ctor_get(x_133, 4); +lean_inc(x_155); +x_156 = lean_ctor_get(x_133, 5); +lean_inc(x_156); +if (lean_is_exclusive(x_133)) { + lean_ctor_release(x_133, 0); + lean_ctor_release(x_133, 1); + lean_ctor_release(x_133, 2); + lean_ctor_release(x_133, 3); + lean_ctor_release(x_133, 4); + lean_ctor_release(x_133, 5); + x_157 = x_133; } else { - lean_dec_ref(x_141); - x_152 = lean_box(0); + lean_dec_ref(x_133); + x_157 = lean_box(0); } -if (lean_is_scalar(x_152)) { - x_153 = lean_alloc_ctor(0, 4, 0); +x_158 = lean_ctor_get(x_150, 0); +lean_inc(x_158); +x_159 = lean_ctor_get(x_150, 1); +lean_inc(x_159); +x_160 = lean_ctor_get(x_150, 3); +lean_inc(x_160); +x_161 = lean_ctor_get(x_150, 4); +lean_inc(x_161); +if (lean_is_exclusive(x_150)) { + lean_ctor_release(x_150, 0); + lean_ctor_release(x_150, 1); + lean_ctor_release(x_150, 2); + lean_ctor_release(x_150, 3); + lean_ctor_release(x_150, 4); + x_162 = x_150; } else { - x_153 = x_152; + lean_dec_ref(x_150); + x_162 = lean_box(0); } -lean_ctor_set(x_153, 0, x_149); -lean_ctor_set(x_153, 1, x_150); -lean_ctor_set(x_153, 2, x_121); -lean_ctor_set(x_153, 3, x_151); -if (lean_is_scalar(x_148)) { - x_154 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_162)) { + x_163 = lean_alloc_ctor(0, 5, 0); } else { - x_154 = x_148; + x_163 = x_162; } -lean_ctor_set(x_154, 0, x_143); -lean_ctor_set(x_154, 1, x_144); -lean_ctor_set(x_154, 2, x_153); -lean_ctor_set(x_154, 3, x_145); -lean_ctor_set(x_154, 4, x_146); -lean_ctor_set(x_154, 5, x_147); -x_155 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_155, 0, x_142); -lean_ctor_set(x_155, 1, x_154); -return x_155; +lean_ctor_set(x_163, 0, x_158); +lean_ctor_set(x_163, 1, x_159); +lean_ctor_set(x_163, 2, x_128); +lean_ctor_set(x_163, 3, x_160); +lean_ctor_set(x_163, 4, x_161); +if (lean_is_scalar(x_157)) { + x_164 = lean_alloc_ctor(0, 6, 0); +} else { + x_164 = x_157; +} +lean_ctor_set(x_164, 0, x_152); +lean_ctor_set(x_164, 1, x_153); +lean_ctor_set(x_164, 2, x_163); +lean_ctor_set(x_164, 3, x_154); +lean_ctor_set(x_164, 4, x_155); +lean_ctor_set(x_164, 5, x_156); +x_165 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_165, 0, x_151); +lean_ctor_set(x_165, 1, x_164); +return x_165; } } } @@ -7651,105 +7794,105 @@ x_7 = lean_ctor_get(x_5, 2); x_8 = !lean_is_exclusive(x_7); if (x_8 == 0) { -lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_61; uint8_t x_62; +lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_65; uint8_t x_66; x_9 = lean_ctor_get(x_7, 2); -x_61 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_7, 2, x_61); -x_62 = !lean_is_exclusive(x_4); -if (x_62 == 0) +x_65 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_7, 2, x_65); +x_66 = !lean_is_exclusive(x_4); +if (x_66 == 0) { -lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; -x_63 = lean_ctor_get(x_4, 2); -x_64 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_64, 0, x_1); -lean_ctor_set(x_64, 1, x_2); -x_65 = lean_array_push(x_63, x_64); -lean_ctor_set(x_4, 2, x_65); -x_66 = lean_apply_2(x_3, x_4, x_5); -if (lean_obj_tag(x_66) == 0) +lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; +x_67 = lean_ctor_get(x_4, 2); +x_68 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_68, 0, x_1); +lean_ctor_set(x_68, 1, x_2); +x_69 = lean_array_push(x_67, x_68); +lean_ctor_set(x_4, 2, x_69); +x_70 = lean_apply_2(x_3, x_4, x_5); +if (lean_obj_tag(x_70) == 0) { -lean_object* x_67; lean_object* x_68; lean_object* x_69; -x_67 = lean_ctor_get(x_66, 0); -lean_inc(x_67); -x_68 = lean_ctor_get(x_66, 1); -lean_inc(x_68); -lean_dec(x_66); -x_69 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_69, 0, x_67); -x_10 = x_69; -x_11 = x_68; -goto block_60; -} -else -{ -lean_object* x_70; lean_object* x_71; lean_object* x_72; -x_70 = lean_ctor_get(x_66, 0); -lean_inc(x_70); -x_71 = lean_ctor_get(x_66, 1); +lean_object* x_71; lean_object* x_72; lean_object* x_73; +x_71 = lean_ctor_get(x_70, 0); lean_inc(x_71); -lean_dec(x_66); -x_72 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_72, 0, x_70); -x_10 = x_72; -x_11 = x_71; -goto block_60; -} +x_72 = lean_ctor_get(x_70, 1); +lean_inc(x_72); +lean_dec(x_70); +x_73 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_73, 0, x_71); +x_10 = x_73; +x_11 = x_72; +goto block_64; } else { -lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; -x_73 = lean_ctor_get(x_4, 0); -x_74 = lean_ctor_get(x_4, 1); -x_75 = lean_ctor_get(x_4, 2); -x_76 = lean_ctor_get(x_4, 3); -x_77 = lean_ctor_get(x_4, 4); -lean_inc(x_77); -lean_inc(x_76); -lean_inc(x_75); +lean_object* x_74; lean_object* x_75; lean_object* x_76; +x_74 = lean_ctor_get(x_70, 0); lean_inc(x_74); -lean_inc(x_73); -lean_dec(x_4); -x_78 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_78, 0, x_1); -lean_ctor_set(x_78, 1, x_2); -x_79 = lean_array_push(x_75, x_78); -x_80 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_80, 0, x_73); -lean_ctor_set(x_80, 1, x_74); -lean_ctor_set(x_80, 2, x_79); -lean_ctor_set(x_80, 3, x_76); -lean_ctor_set(x_80, 4, x_77); -x_81 = lean_apply_2(x_3, x_80, x_5); -if (lean_obj_tag(x_81) == 0) -{ -lean_object* x_82; lean_object* x_83; lean_object* x_84; -x_82 = lean_ctor_get(x_81, 0); -lean_inc(x_82); -x_83 = lean_ctor_get(x_81, 1); -lean_inc(x_83); -lean_dec(x_81); -x_84 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_84, 0, x_82); -x_10 = x_84; -x_11 = x_83; -goto block_60; +x_75 = lean_ctor_get(x_70, 1); +lean_inc(x_75); +lean_dec(x_70); +x_76 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_76, 0, x_74); +x_10 = x_76; +x_11 = x_75; +goto block_64; +} } else { -lean_object* x_85; lean_object* x_86; lean_object* x_87; -x_85 = lean_ctor_get(x_81, 0); -lean_inc(x_85); -x_86 = lean_ctor_get(x_81, 1); +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; +x_77 = lean_ctor_get(x_4, 0); +x_78 = lean_ctor_get(x_4, 1); +x_79 = lean_ctor_get(x_4, 2); +x_80 = lean_ctor_get(x_4, 3); +x_81 = lean_ctor_get(x_4, 4); +lean_inc(x_81); +lean_inc(x_80); +lean_inc(x_79); +lean_inc(x_78); +lean_inc(x_77); +lean_dec(x_4); +x_82 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_82, 0, x_1); +lean_ctor_set(x_82, 1, x_2); +x_83 = lean_array_push(x_79, x_82); +x_84 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_84, 0, x_77); +lean_ctor_set(x_84, 1, x_78); +lean_ctor_set(x_84, 2, x_83); +lean_ctor_set(x_84, 3, x_80); +lean_ctor_set(x_84, 4, x_81); +x_85 = lean_apply_2(x_3, x_84, x_5); +if (lean_obj_tag(x_85) == 0) +{ +lean_object* x_86; lean_object* x_87; lean_object* x_88; +x_86 = lean_ctor_get(x_85, 0); lean_inc(x_86); -lean_dec(x_81); -x_87 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_87, 0, x_85); -x_10 = x_87; -x_11 = x_86; -goto block_60; +x_87 = lean_ctor_get(x_85, 1); +lean_inc(x_87); +lean_dec(x_85); +x_88 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_88, 0, x_86); +x_10 = x_88; +x_11 = x_87; +goto block_64; +} +else +{ +lean_object* x_89; lean_object* x_90; lean_object* x_91; +x_89 = lean_ctor_get(x_85, 0); +lean_inc(x_89); +x_90 = lean_ctor_get(x_85, 1); +lean_inc(x_90); +lean_dec(x_85); +x_91 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_91, 0, x_89); +x_10 = x_91; +x_11 = x_90; +goto block_64; } } -block_60: +block_64: { if (lean_obj_tag(x_10) == 0) { @@ -7779,668 +7922,705 @@ return x_18; } else { -lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; +lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; x_19 = lean_ctor_get(x_12, 0); x_20 = lean_ctor_get(x_12, 1); x_21 = lean_ctor_get(x_12, 3); +x_22 = lean_ctor_get(x_12, 4); +lean_inc(x_22); lean_inc(x_21); lean_inc(x_20); lean_inc(x_19); lean_dec(x_12); -x_22 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_22, 0, x_19); -lean_ctor_set(x_22, 1, x_20); -lean_ctor_set(x_22, 2, x_9); -lean_ctor_set(x_22, 3, x_21); -lean_ctor_set(x_11, 2, x_22); -x_23 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_23, 0, x_13); -lean_ctor_set(x_23, 1, x_11); -return x_23; +x_23 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_23, 0, x_19); +lean_ctor_set(x_23, 1, x_20); +lean_ctor_set(x_23, 2, x_9); +lean_ctor_set(x_23, 3, x_21); +lean_ctor_set(x_23, 4, x_22); +lean_ctor_set(x_11, 2, x_23); +x_24 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_24, 0, x_13); +lean_ctor_set(x_24, 1, x_11); +return x_24; } } else { -lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; -x_24 = lean_ctor_get(x_11, 0); -x_25 = lean_ctor_get(x_11, 1); -x_26 = lean_ctor_get(x_11, 3); -x_27 = lean_ctor_get(x_11, 4); -x_28 = lean_ctor_get(x_11, 5); +lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; +x_25 = lean_ctor_get(x_11, 0); +x_26 = lean_ctor_get(x_11, 1); +x_27 = lean_ctor_get(x_11, 3); +x_28 = lean_ctor_get(x_11, 4); +x_29 = lean_ctor_get(x_11, 5); +lean_inc(x_29); lean_inc(x_28); lean_inc(x_27); lean_inc(x_26); lean_inc(x_25); -lean_inc(x_24); lean_dec(x_11); -x_29 = lean_ctor_get(x_12, 0); -lean_inc(x_29); -x_30 = lean_ctor_get(x_12, 1); +x_30 = lean_ctor_get(x_12, 0); lean_inc(x_30); -x_31 = lean_ctor_get(x_12, 3); +x_31 = lean_ctor_get(x_12, 1); lean_inc(x_31); +x_32 = lean_ctor_get(x_12, 3); +lean_inc(x_32); +x_33 = lean_ctor_get(x_12, 4); +lean_inc(x_33); if (lean_is_exclusive(x_12)) { lean_ctor_release(x_12, 0); lean_ctor_release(x_12, 1); lean_ctor_release(x_12, 2); lean_ctor_release(x_12, 3); - x_32 = x_12; + lean_ctor_release(x_12, 4); + x_34 = x_12; } else { lean_dec_ref(x_12); - x_32 = lean_box(0); + x_34 = lean_box(0); } -if (lean_is_scalar(x_32)) { - x_33 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_34)) { + x_35 = lean_alloc_ctor(0, 5, 0); } else { - x_33 = x_32; + x_35 = x_34; } -lean_ctor_set(x_33, 0, x_29); -lean_ctor_set(x_33, 1, x_30); -lean_ctor_set(x_33, 2, x_9); -lean_ctor_set(x_33, 3, x_31); -x_34 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_34, 0, x_24); -lean_ctor_set(x_34, 1, x_25); -lean_ctor_set(x_34, 2, x_33); -lean_ctor_set(x_34, 3, x_26); -lean_ctor_set(x_34, 4, x_27); -lean_ctor_set(x_34, 5, x_28); -x_35 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_35, 0, x_13); -lean_ctor_set(x_35, 1, x_34); -return x_35; +lean_ctor_set(x_35, 0, x_30); +lean_ctor_set(x_35, 1, x_31); +lean_ctor_set(x_35, 2, x_9); +lean_ctor_set(x_35, 3, x_32); +lean_ctor_set(x_35, 4, x_33); +x_36 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_36, 0, x_25); +lean_ctor_set(x_36, 1, x_26); +lean_ctor_set(x_36, 2, x_35); +lean_ctor_set(x_36, 3, x_27); +lean_ctor_set(x_36, 4, x_28); +lean_ctor_set(x_36, 5, x_29); +x_37 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_37, 0, x_13); +lean_ctor_set(x_37, 1, x_36); +return x_37; } } else { -lean_object* x_36; lean_object* x_37; uint8_t x_38; -x_36 = lean_ctor_get(x_11, 2); -lean_inc(x_36); -x_37 = lean_ctor_get(x_10, 0); -lean_inc(x_37); +lean_object* x_38; lean_object* x_39; uint8_t x_40; +x_38 = lean_ctor_get(x_11, 2); +lean_inc(x_38); +x_39 = lean_ctor_get(x_10, 0); +lean_inc(x_39); lean_dec(x_10); -x_38 = !lean_is_exclusive(x_11); -if (x_38 == 0) -{ -lean_object* x_39; uint8_t x_40; -x_39 = lean_ctor_get(x_11, 2); -lean_dec(x_39); -x_40 = !lean_is_exclusive(x_36); +x_40 = !lean_is_exclusive(x_11); if (x_40 == 0) { -lean_object* x_41; lean_object* x_42; -x_41 = lean_ctor_get(x_36, 2); +lean_object* x_41; uint8_t x_42; +x_41 = lean_ctor_get(x_11, 2); lean_dec(x_41); -lean_ctor_set(x_36, 2, x_9); -x_42 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_42, 0, x_37); -lean_ctor_set(x_42, 1, x_11); -return x_42; +x_42 = !lean_is_exclusive(x_38); +if (x_42 == 0) +{ +lean_object* x_43; lean_object* x_44; +x_43 = lean_ctor_get(x_38, 2); +lean_dec(x_43); +lean_ctor_set(x_38, 2, x_9); +x_44 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_44, 0, x_39); +lean_ctor_set(x_44, 1, x_11); +return x_44; } else { -lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; -x_43 = lean_ctor_get(x_36, 0); -x_44 = lean_ctor_get(x_36, 1); -x_45 = lean_ctor_get(x_36, 3); +lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; +x_45 = lean_ctor_get(x_38, 0); +x_46 = lean_ctor_get(x_38, 1); +x_47 = lean_ctor_get(x_38, 3); +x_48 = lean_ctor_get(x_38, 4); +lean_inc(x_48); +lean_inc(x_47); +lean_inc(x_46); lean_inc(x_45); -lean_inc(x_44); -lean_inc(x_43); -lean_dec(x_36); -x_46 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_46, 0, x_43); -lean_ctor_set(x_46, 1, x_44); -lean_ctor_set(x_46, 2, x_9); -lean_ctor_set(x_46, 3, x_45); -lean_ctor_set(x_11, 2, x_46); -x_47 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_47, 0, x_37); -lean_ctor_set(x_47, 1, x_11); -return x_47; +lean_dec(x_38); +x_49 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_49, 0, x_45); +lean_ctor_set(x_49, 1, x_46); +lean_ctor_set(x_49, 2, x_9); +lean_ctor_set(x_49, 3, x_47); +lean_ctor_set(x_49, 4, x_48); +lean_ctor_set(x_11, 2, x_49); +x_50 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_50, 0, x_39); +lean_ctor_set(x_50, 1, x_11); +return x_50; } } else { -lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; -x_48 = lean_ctor_get(x_11, 0); -x_49 = lean_ctor_get(x_11, 1); -x_50 = lean_ctor_get(x_11, 3); -x_51 = lean_ctor_get(x_11, 4); -x_52 = lean_ctor_get(x_11, 5); +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_object* x_63; +x_51 = lean_ctor_get(x_11, 0); +x_52 = lean_ctor_get(x_11, 1); +x_53 = lean_ctor_get(x_11, 3); +x_54 = lean_ctor_get(x_11, 4); +x_55 = lean_ctor_get(x_11, 5); +lean_inc(x_55); +lean_inc(x_54); +lean_inc(x_53); lean_inc(x_52); lean_inc(x_51); -lean_inc(x_50); -lean_inc(x_49); -lean_inc(x_48); lean_dec(x_11); -x_53 = lean_ctor_get(x_36, 0); -lean_inc(x_53); -x_54 = lean_ctor_get(x_36, 1); -lean_inc(x_54); -x_55 = lean_ctor_get(x_36, 3); -lean_inc(x_55); -if (lean_is_exclusive(x_36)) { - lean_ctor_release(x_36, 0); - lean_ctor_release(x_36, 1); - lean_ctor_release(x_36, 2); - lean_ctor_release(x_36, 3); - x_56 = x_36; +x_56 = lean_ctor_get(x_38, 0); +lean_inc(x_56); +x_57 = lean_ctor_get(x_38, 1); +lean_inc(x_57); +x_58 = lean_ctor_get(x_38, 3); +lean_inc(x_58); +x_59 = lean_ctor_get(x_38, 4); +lean_inc(x_59); +if (lean_is_exclusive(x_38)) { + lean_ctor_release(x_38, 0); + lean_ctor_release(x_38, 1); + lean_ctor_release(x_38, 2); + lean_ctor_release(x_38, 3); + lean_ctor_release(x_38, 4); + x_60 = x_38; } else { - lean_dec_ref(x_36); - x_56 = lean_box(0); + lean_dec_ref(x_38); + x_60 = lean_box(0); } -if (lean_is_scalar(x_56)) { - x_57 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_60)) { + x_61 = lean_alloc_ctor(0, 5, 0); } else { - x_57 = x_56; + x_61 = x_60; } -lean_ctor_set(x_57, 0, x_53); -lean_ctor_set(x_57, 1, x_54); -lean_ctor_set(x_57, 2, x_9); -lean_ctor_set(x_57, 3, x_55); -x_58 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_58, 0, x_48); -lean_ctor_set(x_58, 1, x_49); -lean_ctor_set(x_58, 2, x_57); -lean_ctor_set(x_58, 3, x_50); -lean_ctor_set(x_58, 4, x_51); -lean_ctor_set(x_58, 5, x_52); -x_59 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_59, 0, x_37); -lean_ctor_set(x_59, 1, x_58); -return x_59; +lean_ctor_set(x_61, 0, x_56); +lean_ctor_set(x_61, 1, x_57); +lean_ctor_set(x_61, 2, x_9); +lean_ctor_set(x_61, 3, x_58); +lean_ctor_set(x_61, 4, x_59); +x_62 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_62, 0, x_51); +lean_ctor_set(x_62, 1, x_52); +lean_ctor_set(x_62, 2, x_61); +lean_ctor_set(x_62, 3, x_53); +lean_ctor_set(x_62, 4, x_54); +lean_ctor_set(x_62, 5, x_55); +x_63 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_63, 0, x_39); +lean_ctor_set(x_63, 1, x_62); +return x_63; } } } } else { -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_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; -x_88 = lean_ctor_get(x_7, 0); -x_89 = lean_ctor_get(x_7, 1); -x_90 = lean_ctor_get(x_7, 2); -x_91 = lean_ctor_get(x_7, 3); -lean_inc(x_91); -lean_inc(x_90); -lean_inc(x_89); -lean_inc(x_88); -lean_dec(x_7); -x_125 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_126 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_126, 0, x_88); -lean_ctor_set(x_126, 1, x_89); -lean_ctor_set(x_126, 2, x_125); -lean_ctor_set(x_126, 3, x_91); -lean_ctor_set(x_5, 2, x_126); -x_127 = lean_ctor_get(x_4, 0); -lean_inc(x_127); -x_128 = lean_ctor_get(x_4, 1); -lean_inc(x_128); -x_129 = lean_ctor_get(x_4, 2); -lean_inc(x_129); -x_130 = lean_ctor_get(x_4, 3); -lean_inc(x_130); -x_131 = lean_ctor_get(x_4, 4); -lean_inc(x_131); -if (lean_is_exclusive(x_4)) { - lean_ctor_release(x_4, 0); - lean_ctor_release(x_4, 1); - lean_ctor_release(x_4, 2); - lean_ctor_release(x_4, 3); - lean_ctor_release(x_4, 4); - x_132 = x_4; -} else { - lean_dec_ref(x_4); - x_132 = lean_box(0); -} -x_133 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_133, 0, x_1); -lean_ctor_set(x_133, 1, x_2); -x_134 = lean_array_push(x_129, x_133); -if (lean_is_scalar(x_132)) { - x_135 = lean_alloc_ctor(0, 5, 0); -} else { - x_135 = x_132; -} -lean_ctor_set(x_135, 0, x_127); -lean_ctor_set(x_135, 1, x_128); -lean_ctor_set(x_135, 2, x_134); -lean_ctor_set(x_135, 3, x_130); -lean_ctor_set(x_135, 4, x_131); -x_136 = lean_apply_2(x_3, x_135, x_5); -if (lean_obj_tag(x_136) == 0) -{ -lean_object* x_137; lean_object* x_138; lean_object* x_139; -x_137 = lean_ctor_get(x_136, 0); -lean_inc(x_137); -x_138 = lean_ctor_get(x_136, 1); -lean_inc(x_138); -lean_dec(x_136); -x_139 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_139, 0, x_137); -x_92 = x_139; -x_93 = x_138; -goto block_124; -} -else -{ -lean_object* x_140; lean_object* x_141; lean_object* x_142; -x_140 = lean_ctor_get(x_136, 0); -lean_inc(x_140); -x_141 = lean_ctor_get(x_136, 1); -lean_inc(x_141); -lean_dec(x_136); -x_142 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_142, 0, x_140); -x_92 = x_142; -x_93 = x_141; -goto block_124; -} -block_124: -{ -if (lean_obj_tag(x_92) == 0) -{ -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; -x_94 = lean_ctor_get(x_93, 2); -lean_inc(x_94); -x_95 = lean_ctor_get(x_92, 0); -lean_inc(x_95); -lean_dec(x_92); -x_96 = lean_ctor_get(x_93, 0); +lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_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; +x_92 = lean_ctor_get(x_7, 0); +x_93 = lean_ctor_get(x_7, 1); +x_94 = lean_ctor_get(x_7, 2); +x_95 = lean_ctor_get(x_7, 3); +x_96 = lean_ctor_get(x_7, 4); lean_inc(x_96); -x_97 = lean_ctor_get(x_93, 1); -lean_inc(x_97); -x_98 = lean_ctor_get(x_93, 3); -lean_inc(x_98); -x_99 = lean_ctor_get(x_93, 4); -lean_inc(x_99); -x_100 = lean_ctor_get(x_93, 5); -lean_inc(x_100); -if (lean_is_exclusive(x_93)) { - lean_ctor_release(x_93, 0); - lean_ctor_release(x_93, 1); - lean_ctor_release(x_93, 2); - lean_ctor_release(x_93, 3); - lean_ctor_release(x_93, 4); - lean_ctor_release(x_93, 5); - x_101 = x_93; -} else { - lean_dec_ref(x_93); - x_101 = lean_box(0); -} -x_102 = lean_ctor_get(x_94, 0); -lean_inc(x_102); -x_103 = lean_ctor_get(x_94, 1); -lean_inc(x_103); -x_104 = lean_ctor_get(x_94, 3); -lean_inc(x_104); -if (lean_is_exclusive(x_94)) { - lean_ctor_release(x_94, 0); - lean_ctor_release(x_94, 1); - lean_ctor_release(x_94, 2); - lean_ctor_release(x_94, 3); - x_105 = x_94; -} else { - lean_dec_ref(x_94); - x_105 = lean_box(0); -} -if (lean_is_scalar(x_105)) { - x_106 = lean_alloc_ctor(0, 4, 0); -} else { - x_106 = x_105; -} -lean_ctor_set(x_106, 0, x_102); -lean_ctor_set(x_106, 1, x_103); -lean_ctor_set(x_106, 2, x_90); -lean_ctor_set(x_106, 3, x_104); -if (lean_is_scalar(x_101)) { - x_107 = lean_alloc_ctor(0, 6, 0); -} else { - x_107 = x_101; -} -lean_ctor_set(x_107, 0, x_96); -lean_ctor_set(x_107, 1, x_97); -lean_ctor_set(x_107, 2, x_106); -lean_ctor_set(x_107, 3, x_98); -lean_ctor_set(x_107, 4, x_99); -lean_ctor_set(x_107, 5, x_100); -x_108 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_108, 0, x_95); -lean_ctor_set(x_108, 1, x_107); -return x_108; -} -else -{ -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; -x_109 = lean_ctor_get(x_93, 2); -lean_inc(x_109); -x_110 = lean_ctor_get(x_92, 0); -lean_inc(x_110); -lean_dec(x_92); -x_111 = lean_ctor_get(x_93, 0); -lean_inc(x_111); -x_112 = lean_ctor_get(x_93, 1); -lean_inc(x_112); -x_113 = lean_ctor_get(x_93, 3); -lean_inc(x_113); -x_114 = lean_ctor_get(x_93, 4); -lean_inc(x_114); -x_115 = lean_ctor_get(x_93, 5); -lean_inc(x_115); -if (lean_is_exclusive(x_93)) { - lean_ctor_release(x_93, 0); - lean_ctor_release(x_93, 1); - lean_ctor_release(x_93, 2); - lean_ctor_release(x_93, 3); - lean_ctor_release(x_93, 4); - lean_ctor_release(x_93, 5); - x_116 = x_93; -} else { - lean_dec_ref(x_93); - x_116 = lean_box(0); -} -x_117 = lean_ctor_get(x_109, 0); -lean_inc(x_117); -x_118 = lean_ctor_get(x_109, 1); -lean_inc(x_118); -x_119 = lean_ctor_get(x_109, 3); -lean_inc(x_119); -if (lean_is_exclusive(x_109)) { - lean_ctor_release(x_109, 0); - lean_ctor_release(x_109, 1); - lean_ctor_release(x_109, 2); - lean_ctor_release(x_109, 3); - x_120 = x_109; -} else { - lean_dec_ref(x_109); - x_120 = lean_box(0); -} -if (lean_is_scalar(x_120)) { - x_121 = lean_alloc_ctor(0, 4, 0); -} else { - x_121 = x_120; -} -lean_ctor_set(x_121, 0, x_117); -lean_ctor_set(x_121, 1, x_118); -lean_ctor_set(x_121, 2, x_90); -lean_ctor_set(x_121, 3, x_119); -if (lean_is_scalar(x_116)) { - x_122 = lean_alloc_ctor(0, 6, 0); -} else { - x_122 = x_116; -} -lean_ctor_set(x_122, 0, x_111); -lean_ctor_set(x_122, 1, x_112); -lean_ctor_set(x_122, 2, x_121); -lean_ctor_set(x_122, 3, x_113); -lean_ctor_set(x_122, 4, x_114); -lean_ctor_set(x_122, 5, x_115); -x_123 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_123, 0, x_110); -lean_ctor_set(x_123, 1, x_122); -return x_123; -} -} -} -} -else -{ -lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; 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_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; -x_143 = lean_ctor_get(x_5, 2); -x_144 = lean_ctor_get(x_5, 0); -x_145 = lean_ctor_get(x_5, 1); -x_146 = lean_ctor_get(x_5, 3); -x_147 = lean_ctor_get(x_5, 4); -x_148 = lean_ctor_get(x_5, 5); -lean_inc(x_148); -lean_inc(x_147); -lean_inc(x_146); -lean_inc(x_143); -lean_inc(x_145); -lean_inc(x_144); -lean_dec(x_5); -x_149 = lean_ctor_get(x_143, 0); -lean_inc(x_149); -x_150 = lean_ctor_get(x_143, 1); -lean_inc(x_150); -x_151 = lean_ctor_get(x_143, 2); -lean_inc(x_151); -x_152 = lean_ctor_get(x_143, 3); -lean_inc(x_152); -if (lean_is_exclusive(x_143)) { - lean_ctor_release(x_143, 0); - lean_ctor_release(x_143, 1); - lean_ctor_release(x_143, 2); - lean_ctor_release(x_143, 3); - x_153 = x_143; -} else { - lean_dec_ref(x_143); - x_153 = lean_box(0); -} -x_187 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_153)) { - x_188 = lean_alloc_ctor(0, 4, 0); -} else { - x_188 = x_153; -} -lean_ctor_set(x_188, 0, x_149); -lean_ctor_set(x_188, 1, x_150); -lean_ctor_set(x_188, 2, x_187); -lean_ctor_set(x_188, 3, x_152); -x_189 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_189, 0, x_144); -lean_ctor_set(x_189, 1, x_145); -lean_ctor_set(x_189, 2, x_188); -lean_ctor_set(x_189, 3, x_146); -lean_ctor_set(x_189, 4, x_147); -lean_ctor_set(x_189, 5, x_148); -x_190 = lean_ctor_get(x_4, 0); -lean_inc(x_190); -x_191 = lean_ctor_get(x_4, 1); -lean_inc(x_191); -x_192 = lean_ctor_get(x_4, 2); -lean_inc(x_192); -x_193 = lean_ctor_get(x_4, 3); -lean_inc(x_193); -x_194 = lean_ctor_get(x_4, 4); -lean_inc(x_194); +lean_inc(x_95); +lean_inc(x_94); +lean_inc(x_93); +lean_inc(x_92); +lean_dec(x_7); +x_132 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_133 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_133, 0, x_92); +lean_ctor_set(x_133, 1, x_93); +lean_ctor_set(x_133, 2, x_132); +lean_ctor_set(x_133, 3, x_95); +lean_ctor_set(x_133, 4, x_96); +lean_ctor_set(x_5, 2, x_133); +x_134 = lean_ctor_get(x_4, 0); +lean_inc(x_134); +x_135 = lean_ctor_get(x_4, 1); +lean_inc(x_135); +x_136 = lean_ctor_get(x_4, 2); +lean_inc(x_136); +x_137 = lean_ctor_get(x_4, 3); +lean_inc(x_137); +x_138 = lean_ctor_get(x_4, 4); +lean_inc(x_138); if (lean_is_exclusive(x_4)) { lean_ctor_release(x_4, 0); lean_ctor_release(x_4, 1); lean_ctor_release(x_4, 2); lean_ctor_release(x_4, 3); lean_ctor_release(x_4, 4); - x_195 = x_4; + x_139 = x_4; } else { lean_dec_ref(x_4); - x_195 = lean_box(0); + x_139 = lean_box(0); } -x_196 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_196, 0, x_1); -lean_ctor_set(x_196, 1, x_2); -x_197 = lean_array_push(x_192, x_196); -if (lean_is_scalar(x_195)) { +x_140 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_140, 0, x_1); +lean_ctor_set(x_140, 1, x_2); +x_141 = lean_array_push(x_136, x_140); +if (lean_is_scalar(x_139)) { + x_142 = lean_alloc_ctor(0, 5, 0); +} else { + x_142 = x_139; +} +lean_ctor_set(x_142, 0, x_134); +lean_ctor_set(x_142, 1, x_135); +lean_ctor_set(x_142, 2, x_141); +lean_ctor_set(x_142, 3, x_137); +lean_ctor_set(x_142, 4, x_138); +x_143 = lean_apply_2(x_3, x_142, x_5); +if (lean_obj_tag(x_143) == 0) +{ +lean_object* x_144; lean_object* x_145; lean_object* x_146; +x_144 = lean_ctor_get(x_143, 0); +lean_inc(x_144); +x_145 = lean_ctor_get(x_143, 1); +lean_inc(x_145); +lean_dec(x_143); +x_146 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_146, 0, x_144); +x_97 = x_146; +x_98 = x_145; +goto block_131; +} +else +{ +lean_object* x_147; lean_object* x_148; lean_object* x_149; +x_147 = lean_ctor_get(x_143, 0); +lean_inc(x_147); +x_148 = lean_ctor_get(x_143, 1); +lean_inc(x_148); +lean_dec(x_143); +x_149 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_149, 0, x_147); +x_97 = x_149; +x_98 = x_148; +goto block_131; +} +block_131: +{ +if (lean_obj_tag(x_97) == 0) +{ +lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; 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; +x_99 = lean_ctor_get(x_98, 2); +lean_inc(x_99); +x_100 = lean_ctor_get(x_97, 0); +lean_inc(x_100); +lean_dec(x_97); +x_101 = lean_ctor_get(x_98, 0); +lean_inc(x_101); +x_102 = lean_ctor_get(x_98, 1); +lean_inc(x_102); +x_103 = lean_ctor_get(x_98, 3); +lean_inc(x_103); +x_104 = lean_ctor_get(x_98, 4); +lean_inc(x_104); +x_105 = lean_ctor_get(x_98, 5); +lean_inc(x_105); +if (lean_is_exclusive(x_98)) { + lean_ctor_release(x_98, 0); + lean_ctor_release(x_98, 1); + lean_ctor_release(x_98, 2); + lean_ctor_release(x_98, 3); + lean_ctor_release(x_98, 4); + lean_ctor_release(x_98, 5); + x_106 = x_98; +} else { + lean_dec_ref(x_98); + x_106 = lean_box(0); +} +x_107 = lean_ctor_get(x_99, 0); +lean_inc(x_107); +x_108 = lean_ctor_get(x_99, 1); +lean_inc(x_108); +x_109 = lean_ctor_get(x_99, 3); +lean_inc(x_109); +x_110 = lean_ctor_get(x_99, 4); +lean_inc(x_110); +if (lean_is_exclusive(x_99)) { + lean_ctor_release(x_99, 0); + lean_ctor_release(x_99, 1); + lean_ctor_release(x_99, 2); + lean_ctor_release(x_99, 3); + lean_ctor_release(x_99, 4); + x_111 = x_99; +} else { + lean_dec_ref(x_99); + x_111 = lean_box(0); +} +if (lean_is_scalar(x_111)) { + x_112 = lean_alloc_ctor(0, 5, 0); +} else { + x_112 = x_111; +} +lean_ctor_set(x_112, 0, x_107); +lean_ctor_set(x_112, 1, x_108); +lean_ctor_set(x_112, 2, x_94); +lean_ctor_set(x_112, 3, x_109); +lean_ctor_set(x_112, 4, x_110); +if (lean_is_scalar(x_106)) { + x_113 = lean_alloc_ctor(0, 6, 0); +} else { + x_113 = x_106; +} +lean_ctor_set(x_113, 0, x_101); +lean_ctor_set(x_113, 1, x_102); +lean_ctor_set(x_113, 2, x_112); +lean_ctor_set(x_113, 3, x_103); +lean_ctor_set(x_113, 4, x_104); +lean_ctor_set(x_113, 5, x_105); +x_114 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_114, 0, x_100); +lean_ctor_set(x_114, 1, x_113); +return x_114; +} +else +{ +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; +x_115 = lean_ctor_get(x_98, 2); +lean_inc(x_115); +x_116 = lean_ctor_get(x_97, 0); +lean_inc(x_116); +lean_dec(x_97); +x_117 = lean_ctor_get(x_98, 0); +lean_inc(x_117); +x_118 = lean_ctor_get(x_98, 1); +lean_inc(x_118); +x_119 = lean_ctor_get(x_98, 3); +lean_inc(x_119); +x_120 = lean_ctor_get(x_98, 4); +lean_inc(x_120); +x_121 = lean_ctor_get(x_98, 5); +lean_inc(x_121); +if (lean_is_exclusive(x_98)) { + lean_ctor_release(x_98, 0); + lean_ctor_release(x_98, 1); + lean_ctor_release(x_98, 2); + lean_ctor_release(x_98, 3); + lean_ctor_release(x_98, 4); + lean_ctor_release(x_98, 5); + x_122 = x_98; +} else { + lean_dec_ref(x_98); + x_122 = lean_box(0); +} +x_123 = lean_ctor_get(x_115, 0); +lean_inc(x_123); +x_124 = lean_ctor_get(x_115, 1); +lean_inc(x_124); +x_125 = lean_ctor_get(x_115, 3); +lean_inc(x_125); +x_126 = lean_ctor_get(x_115, 4); +lean_inc(x_126); +if (lean_is_exclusive(x_115)) { + lean_ctor_release(x_115, 0); + lean_ctor_release(x_115, 1); + lean_ctor_release(x_115, 2); + lean_ctor_release(x_115, 3); + lean_ctor_release(x_115, 4); + x_127 = x_115; +} else { + lean_dec_ref(x_115); + x_127 = lean_box(0); +} +if (lean_is_scalar(x_127)) { + x_128 = lean_alloc_ctor(0, 5, 0); +} else { + x_128 = x_127; +} +lean_ctor_set(x_128, 0, x_123); +lean_ctor_set(x_128, 1, x_124); +lean_ctor_set(x_128, 2, x_94); +lean_ctor_set(x_128, 3, x_125); +lean_ctor_set(x_128, 4, x_126); +if (lean_is_scalar(x_122)) { + x_129 = lean_alloc_ctor(0, 6, 0); +} else { + x_129 = x_122; +} +lean_ctor_set(x_129, 0, x_117); +lean_ctor_set(x_129, 1, x_118); +lean_ctor_set(x_129, 2, x_128); +lean_ctor_set(x_129, 3, x_119); +lean_ctor_set(x_129, 4, x_120); +lean_ctor_set(x_129, 5, x_121); +x_130 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_130, 0, x_116); +lean_ctor_set(x_130, 1, x_129); +return x_130; +} +} +} +} +else +{ +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_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; +x_150 = lean_ctor_get(x_5, 2); +x_151 = lean_ctor_get(x_5, 0); +x_152 = lean_ctor_get(x_5, 1); +x_153 = lean_ctor_get(x_5, 3); +x_154 = lean_ctor_get(x_5, 4); +x_155 = lean_ctor_get(x_5, 5); +lean_inc(x_155); +lean_inc(x_154); +lean_inc(x_153); +lean_inc(x_150); +lean_inc(x_152); +lean_inc(x_151); +lean_dec(x_5); +x_156 = lean_ctor_get(x_150, 0); +lean_inc(x_156); +x_157 = lean_ctor_get(x_150, 1); +lean_inc(x_157); +x_158 = lean_ctor_get(x_150, 2); +lean_inc(x_158); +x_159 = lean_ctor_get(x_150, 3); +lean_inc(x_159); +x_160 = lean_ctor_get(x_150, 4); +lean_inc(x_160); +if (lean_is_exclusive(x_150)) { + lean_ctor_release(x_150, 0); + lean_ctor_release(x_150, 1); + lean_ctor_release(x_150, 2); + lean_ctor_release(x_150, 3); + lean_ctor_release(x_150, 4); + x_161 = x_150; +} else { + lean_dec_ref(x_150); + x_161 = lean_box(0); +} +x_197 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_161)) { x_198 = lean_alloc_ctor(0, 5, 0); } else { - x_198 = x_195; + x_198 = x_161; } -lean_ctor_set(x_198, 0, x_190); -lean_ctor_set(x_198, 1, x_191); +lean_ctor_set(x_198, 0, x_156); +lean_ctor_set(x_198, 1, x_157); lean_ctor_set(x_198, 2, x_197); -lean_ctor_set(x_198, 3, x_193); -lean_ctor_set(x_198, 4, x_194); -x_199 = lean_apply_2(x_3, x_198, x_189); -if (lean_obj_tag(x_199) == 0) -{ -lean_object* x_200; lean_object* x_201; lean_object* x_202; -x_200 = lean_ctor_get(x_199, 0); +lean_ctor_set(x_198, 3, x_159); +lean_ctor_set(x_198, 4, x_160); +x_199 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_199, 0, x_151); +lean_ctor_set(x_199, 1, x_152); +lean_ctor_set(x_199, 2, x_198); +lean_ctor_set(x_199, 3, x_153); +lean_ctor_set(x_199, 4, x_154); +lean_ctor_set(x_199, 5, x_155); +x_200 = lean_ctor_get(x_4, 0); lean_inc(x_200); -x_201 = lean_ctor_get(x_199, 1); +x_201 = lean_ctor_get(x_4, 1); lean_inc(x_201); -lean_dec(x_199); -x_202 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_202, 0, x_200); -x_154 = x_202; -x_155 = x_201; -goto block_186; -} -else -{ -lean_object* x_203; lean_object* x_204; lean_object* x_205; -x_203 = lean_ctor_get(x_199, 0); +x_202 = lean_ctor_get(x_4, 2); +lean_inc(x_202); +x_203 = lean_ctor_get(x_4, 3); lean_inc(x_203); -x_204 = lean_ctor_get(x_199, 1); +x_204 = lean_ctor_get(x_4, 4); lean_inc(x_204); -lean_dec(x_199); -x_205 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_205, 0, x_203); -x_154 = x_205; -x_155 = x_204; -goto block_186; +if (lean_is_exclusive(x_4)) { + lean_ctor_release(x_4, 0); + lean_ctor_release(x_4, 1); + lean_ctor_release(x_4, 2); + lean_ctor_release(x_4, 3); + lean_ctor_release(x_4, 4); + x_205 = x_4; +} else { + lean_dec_ref(x_4); + x_205 = lean_box(0); } -block_186: +x_206 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_206, 0, x_1); +lean_ctor_set(x_206, 1, x_2); +x_207 = lean_array_push(x_202, x_206); +if (lean_is_scalar(x_205)) { + x_208 = lean_alloc_ctor(0, 5, 0); +} else { + x_208 = x_205; +} +lean_ctor_set(x_208, 0, x_200); +lean_ctor_set(x_208, 1, x_201); +lean_ctor_set(x_208, 2, x_207); +lean_ctor_set(x_208, 3, x_203); +lean_ctor_set(x_208, 4, x_204); +x_209 = lean_apply_2(x_3, x_208, x_199); +if (lean_obj_tag(x_209) == 0) { -if (lean_obj_tag(x_154) == 0) -{ -lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; -x_156 = lean_ctor_get(x_155, 2); -lean_inc(x_156); -x_157 = lean_ctor_get(x_154, 0); -lean_inc(x_157); -lean_dec(x_154); -x_158 = lean_ctor_get(x_155, 0); -lean_inc(x_158); -x_159 = lean_ctor_get(x_155, 1); -lean_inc(x_159); -x_160 = lean_ctor_get(x_155, 3); -lean_inc(x_160); -x_161 = lean_ctor_get(x_155, 4); -lean_inc(x_161); -x_162 = lean_ctor_get(x_155, 5); -lean_inc(x_162); -if (lean_is_exclusive(x_155)) { - lean_ctor_release(x_155, 0); - lean_ctor_release(x_155, 1); - lean_ctor_release(x_155, 2); - lean_ctor_release(x_155, 3); - lean_ctor_release(x_155, 4); - lean_ctor_release(x_155, 5); - x_163 = x_155; -} else { - lean_dec_ref(x_155); - x_163 = lean_box(0); -} -x_164 = lean_ctor_get(x_156, 0); -lean_inc(x_164); -x_165 = lean_ctor_get(x_156, 1); -lean_inc(x_165); -x_166 = lean_ctor_get(x_156, 3); -lean_inc(x_166); -if (lean_is_exclusive(x_156)) { - lean_ctor_release(x_156, 0); - lean_ctor_release(x_156, 1); - lean_ctor_release(x_156, 2); - lean_ctor_release(x_156, 3); - x_167 = x_156; -} else { - lean_dec_ref(x_156); - x_167 = lean_box(0); -} -if (lean_is_scalar(x_167)) { - x_168 = lean_alloc_ctor(0, 4, 0); -} else { - x_168 = x_167; -} -lean_ctor_set(x_168, 0, x_164); -lean_ctor_set(x_168, 1, x_165); -lean_ctor_set(x_168, 2, x_151); -lean_ctor_set(x_168, 3, x_166); -if (lean_is_scalar(x_163)) { - x_169 = lean_alloc_ctor(0, 6, 0); -} else { - x_169 = x_163; -} -lean_ctor_set(x_169, 0, x_158); -lean_ctor_set(x_169, 1, x_159); -lean_ctor_set(x_169, 2, x_168); -lean_ctor_set(x_169, 3, x_160); -lean_ctor_set(x_169, 4, x_161); -lean_ctor_set(x_169, 5, x_162); -x_170 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_170, 0, x_157); -lean_ctor_set(x_170, 1, x_169); -return x_170; +lean_object* x_210; lean_object* x_211; lean_object* x_212; +x_210 = lean_ctor_get(x_209, 0); +lean_inc(x_210); +x_211 = lean_ctor_get(x_209, 1); +lean_inc(x_211); +lean_dec(x_209); +x_212 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_212, 0, x_210); +x_162 = x_212; +x_163 = x_211; +goto block_196; } else { -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; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; -x_171 = lean_ctor_get(x_155, 2); -lean_inc(x_171); -x_172 = lean_ctor_get(x_154, 0); +lean_object* x_213; lean_object* x_214; lean_object* x_215; +x_213 = lean_ctor_get(x_209, 0); +lean_inc(x_213); +x_214 = lean_ctor_get(x_209, 1); +lean_inc(x_214); +lean_dec(x_209); +x_215 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_215, 0, x_213); +x_162 = x_215; +x_163 = x_214; +goto block_196; +} +block_196: +{ +if (lean_obj_tag(x_162) == 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_179; +x_164 = lean_ctor_get(x_163, 2); +lean_inc(x_164); +x_165 = lean_ctor_get(x_162, 0); +lean_inc(x_165); +lean_dec(x_162); +x_166 = lean_ctor_get(x_163, 0); +lean_inc(x_166); +x_167 = lean_ctor_get(x_163, 1); +lean_inc(x_167); +x_168 = lean_ctor_get(x_163, 3); +lean_inc(x_168); +x_169 = lean_ctor_get(x_163, 4); +lean_inc(x_169); +x_170 = lean_ctor_get(x_163, 5); +lean_inc(x_170); +if (lean_is_exclusive(x_163)) { + lean_ctor_release(x_163, 0); + lean_ctor_release(x_163, 1); + lean_ctor_release(x_163, 2); + lean_ctor_release(x_163, 3); + lean_ctor_release(x_163, 4); + lean_ctor_release(x_163, 5); + x_171 = x_163; +} else { + lean_dec_ref(x_163); + x_171 = lean_box(0); +} +x_172 = lean_ctor_get(x_164, 0); lean_inc(x_172); -lean_dec(x_154); -x_173 = lean_ctor_get(x_155, 0); +x_173 = lean_ctor_get(x_164, 1); lean_inc(x_173); -x_174 = lean_ctor_get(x_155, 1); +x_174 = lean_ctor_get(x_164, 3); lean_inc(x_174); -x_175 = lean_ctor_get(x_155, 3); +x_175 = lean_ctor_get(x_164, 4); lean_inc(x_175); -x_176 = lean_ctor_get(x_155, 4); -lean_inc(x_176); -x_177 = lean_ctor_get(x_155, 5); -lean_inc(x_177); -if (lean_is_exclusive(x_155)) { - lean_ctor_release(x_155, 0); - lean_ctor_release(x_155, 1); - lean_ctor_release(x_155, 2); - lean_ctor_release(x_155, 3); - lean_ctor_release(x_155, 4); - lean_ctor_release(x_155, 5); - x_178 = x_155; +if (lean_is_exclusive(x_164)) { + lean_ctor_release(x_164, 0); + lean_ctor_release(x_164, 1); + lean_ctor_release(x_164, 2); + lean_ctor_release(x_164, 3); + lean_ctor_release(x_164, 4); + x_176 = x_164; } else { - lean_dec_ref(x_155); - x_178 = lean_box(0); + lean_dec_ref(x_164); + x_176 = lean_box(0); } -x_179 = lean_ctor_get(x_171, 0); -lean_inc(x_179); -x_180 = lean_ctor_get(x_171, 1); +if (lean_is_scalar(x_176)) { + x_177 = lean_alloc_ctor(0, 5, 0); +} else { + x_177 = x_176; +} +lean_ctor_set(x_177, 0, x_172); +lean_ctor_set(x_177, 1, x_173); +lean_ctor_set(x_177, 2, x_158); +lean_ctor_set(x_177, 3, x_174); +lean_ctor_set(x_177, 4, x_175); +if (lean_is_scalar(x_171)) { + x_178 = lean_alloc_ctor(0, 6, 0); +} else { + x_178 = x_171; +} +lean_ctor_set(x_178, 0, x_166); +lean_ctor_set(x_178, 1, x_167); +lean_ctor_set(x_178, 2, x_177); +lean_ctor_set(x_178, 3, x_168); +lean_ctor_set(x_178, 4, x_169); +lean_ctor_set(x_178, 5, x_170); +x_179 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_179, 0, x_165); +lean_ctor_set(x_179, 1, x_178); +return x_179; +} +else +{ +lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; 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; +x_180 = lean_ctor_get(x_163, 2); lean_inc(x_180); -x_181 = lean_ctor_get(x_171, 3); +x_181 = lean_ctor_get(x_162, 0); lean_inc(x_181); -if (lean_is_exclusive(x_171)) { - lean_ctor_release(x_171, 0); - lean_ctor_release(x_171, 1); - lean_ctor_release(x_171, 2); - lean_ctor_release(x_171, 3); - x_182 = x_171; +lean_dec(x_162); +x_182 = lean_ctor_get(x_163, 0); +lean_inc(x_182); +x_183 = lean_ctor_get(x_163, 1); +lean_inc(x_183); +x_184 = lean_ctor_get(x_163, 3); +lean_inc(x_184); +x_185 = lean_ctor_get(x_163, 4); +lean_inc(x_185); +x_186 = lean_ctor_get(x_163, 5); +lean_inc(x_186); +if (lean_is_exclusive(x_163)) { + lean_ctor_release(x_163, 0); + lean_ctor_release(x_163, 1); + lean_ctor_release(x_163, 2); + lean_ctor_release(x_163, 3); + lean_ctor_release(x_163, 4); + lean_ctor_release(x_163, 5); + x_187 = x_163; } else { - lean_dec_ref(x_171); - x_182 = lean_box(0); + lean_dec_ref(x_163); + x_187 = lean_box(0); } -if (lean_is_scalar(x_182)) { - x_183 = lean_alloc_ctor(0, 4, 0); +x_188 = lean_ctor_get(x_180, 0); +lean_inc(x_188); +x_189 = lean_ctor_get(x_180, 1); +lean_inc(x_189); +x_190 = lean_ctor_get(x_180, 3); +lean_inc(x_190); +x_191 = lean_ctor_get(x_180, 4); +lean_inc(x_191); +if (lean_is_exclusive(x_180)) { + lean_ctor_release(x_180, 0); + lean_ctor_release(x_180, 1); + lean_ctor_release(x_180, 2); + lean_ctor_release(x_180, 3); + lean_ctor_release(x_180, 4); + x_192 = x_180; } else { - x_183 = x_182; + lean_dec_ref(x_180); + x_192 = lean_box(0); } -lean_ctor_set(x_183, 0, x_179); -lean_ctor_set(x_183, 1, x_180); -lean_ctor_set(x_183, 2, x_151); -lean_ctor_set(x_183, 3, x_181); -if (lean_is_scalar(x_178)) { - x_184 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_192)) { + x_193 = lean_alloc_ctor(0, 5, 0); } else { - x_184 = x_178; + x_193 = x_192; } -lean_ctor_set(x_184, 0, x_173); -lean_ctor_set(x_184, 1, x_174); -lean_ctor_set(x_184, 2, x_183); -lean_ctor_set(x_184, 3, x_175); -lean_ctor_set(x_184, 4, x_176); -lean_ctor_set(x_184, 5, x_177); -x_185 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_185, 0, x_172); -lean_ctor_set(x_185, 1, x_184); -return x_185; +lean_ctor_set(x_193, 0, x_188); +lean_ctor_set(x_193, 1, x_189); +lean_ctor_set(x_193, 2, x_158); +lean_ctor_set(x_193, 3, x_190); +lean_ctor_set(x_193, 4, x_191); +if (lean_is_scalar(x_187)) { + x_194 = lean_alloc_ctor(0, 6, 0); +} else { + x_194 = x_187; +} +lean_ctor_set(x_194, 0, x_182); +lean_ctor_set(x_194, 1, x_183); +lean_ctor_set(x_194, 2, x_193); +lean_ctor_set(x_194, 3, x_184); +lean_ctor_set(x_194, 4, x_185); +lean_ctor_set(x_194, 5, x_186); +x_195 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_195, 0, x_181); +lean_ctor_set(x_195, 1, x_194); +return x_195; } } } @@ -8537,105 +8717,105 @@ x_27 = lean_ctor_get(x_21, 2); x_28 = !lean_is_exclusive(x_27); if (x_28 == 0) { -lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_81; uint8_t x_82; +lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_85; uint8_t x_86; x_29 = lean_ctor_get(x_27, 2); -x_81 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_27, 2, x_81); -x_82 = !lean_is_exclusive(x_5); -if (x_82 == 0) +x_85 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_27, 2, x_85); +x_86 = !lean_is_exclusive(x_5); +if (x_86 == 0) { -lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; -x_83 = lean_ctor_get(x_5, 2); -x_84 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_84, 0, x_23); -lean_ctor_set(x_84, 1, x_10); -x_85 = lean_array_push(x_83, x_84); -lean_ctor_set(x_5, 2, x_85); -x_86 = l_Lean_Meta_withNewLocalInstances___main___rarg(x_1, x_2, x_25, x_4, x_5, x_21); -if (lean_obj_tag(x_86) == 0) +lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; +x_87 = lean_ctor_get(x_5, 2); +x_88 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_88, 0, x_23); +lean_ctor_set(x_88, 1, x_10); +x_89 = lean_array_push(x_87, x_88); +lean_ctor_set(x_5, 2, x_89); +x_90 = l_Lean_Meta_withNewLocalInstances___main___rarg(x_1, x_2, x_25, x_4, x_5, x_21); +if (lean_obj_tag(x_90) == 0) { -lean_object* x_87; lean_object* x_88; lean_object* x_89; -x_87 = lean_ctor_get(x_86, 0); -lean_inc(x_87); -x_88 = lean_ctor_get(x_86, 1); -lean_inc(x_88); -lean_dec(x_86); -x_89 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_89, 0, x_87); -x_30 = x_89; -x_31 = x_88; -goto block_80; -} -else -{ -lean_object* x_90; lean_object* x_91; lean_object* x_92; -x_90 = lean_ctor_get(x_86, 0); -lean_inc(x_90); -x_91 = lean_ctor_get(x_86, 1); +lean_object* x_91; lean_object* x_92; lean_object* x_93; +x_91 = lean_ctor_get(x_90, 0); lean_inc(x_91); -lean_dec(x_86); -x_92 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_92, 0, x_90); -x_30 = x_92; -x_31 = x_91; -goto block_80; -} +x_92 = lean_ctor_get(x_90, 1); +lean_inc(x_92); +lean_dec(x_90); +x_93 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_93, 0, x_91); +x_30 = x_93; +x_31 = x_92; +goto block_84; } else { -lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; -x_93 = lean_ctor_get(x_5, 0); -x_94 = lean_ctor_get(x_5, 1); -x_95 = lean_ctor_get(x_5, 2); -x_96 = lean_ctor_get(x_5, 3); -x_97 = lean_ctor_get(x_5, 4); -lean_inc(x_97); -lean_inc(x_96); -lean_inc(x_95); +lean_object* x_94; lean_object* x_95; lean_object* x_96; +x_94 = lean_ctor_get(x_90, 0); lean_inc(x_94); -lean_inc(x_93); -lean_dec(x_5); -x_98 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_98, 0, x_23); -lean_ctor_set(x_98, 1, x_10); -x_99 = lean_array_push(x_95, x_98); -x_100 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_100, 0, x_93); -lean_ctor_set(x_100, 1, x_94); -lean_ctor_set(x_100, 2, x_99); -lean_ctor_set(x_100, 3, x_96); -lean_ctor_set(x_100, 4, x_97); -x_101 = l_Lean_Meta_withNewLocalInstances___main___rarg(x_1, x_2, x_25, x_4, x_100, x_21); -if (lean_obj_tag(x_101) == 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); -x_104 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_104, 0, x_102); -x_30 = x_104; -x_31 = x_103; -goto block_80; +x_95 = lean_ctor_get(x_90, 1); +lean_inc(x_95); +lean_dec(x_90); +x_96 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_96, 0, x_94); +x_30 = x_96; +x_31 = x_95; +goto block_84; +} } else { -lean_object* x_105; lean_object* x_106; lean_object* x_107; -x_105 = lean_ctor_get(x_101, 0); -lean_inc(x_105); -x_106 = lean_ctor_get(x_101, 1); +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; +x_97 = lean_ctor_get(x_5, 0); +x_98 = lean_ctor_get(x_5, 1); +x_99 = lean_ctor_get(x_5, 2); +x_100 = lean_ctor_get(x_5, 3); +x_101 = lean_ctor_get(x_5, 4); +lean_inc(x_101); +lean_inc(x_100); +lean_inc(x_99); +lean_inc(x_98); +lean_inc(x_97); +lean_dec(x_5); +x_102 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_102, 0, x_23); +lean_ctor_set(x_102, 1, x_10); +x_103 = lean_array_push(x_99, x_102); +x_104 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_104, 0, x_97); +lean_ctor_set(x_104, 1, x_98); +lean_ctor_set(x_104, 2, x_103); +lean_ctor_set(x_104, 3, x_100); +lean_ctor_set(x_104, 4, x_101); +x_105 = l_Lean_Meta_withNewLocalInstances___main___rarg(x_1, x_2, x_25, x_4, x_104, x_21); +if (lean_obj_tag(x_105) == 0) +{ +lean_object* x_106; lean_object* x_107; lean_object* x_108; +x_106 = lean_ctor_get(x_105, 0); lean_inc(x_106); -lean_dec(x_101); -x_107 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_107, 0, x_105); -x_30 = x_107; -x_31 = x_106; -goto block_80; +x_107 = lean_ctor_get(x_105, 1); +lean_inc(x_107); +lean_dec(x_105); +x_108 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_108, 0, x_106); +x_30 = x_108; +x_31 = x_107; +goto block_84; +} +else +{ +lean_object* x_109; lean_object* x_110; lean_object* x_111; +x_109 = lean_ctor_get(x_105, 0); +lean_inc(x_109); +x_110 = lean_ctor_get(x_105, 1); +lean_inc(x_110); +lean_dec(x_105); +x_111 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_111, 0, x_109); +x_30 = x_111; +x_31 = x_110; +goto block_84; } } -block_80: +block_84: { if (lean_obj_tag(x_30) == 0) { @@ -8670,1285 +8850,1263 @@ return x_38; } else { -lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; +lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; x_39 = lean_ctor_get(x_32, 0); x_40 = lean_ctor_get(x_32, 1); x_41 = lean_ctor_get(x_32, 3); +x_42 = lean_ctor_get(x_32, 4); +lean_inc(x_42); lean_inc(x_41); lean_inc(x_40); lean_inc(x_39); lean_dec(x_32); -x_42 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_42, 0, x_39); -lean_ctor_set(x_42, 1, x_40); -lean_ctor_set(x_42, 2, x_29); -lean_ctor_set(x_42, 3, x_41); -lean_ctor_set(x_31, 2, x_42); +x_43 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_43, 0, x_39); +lean_ctor_set(x_43, 1, x_40); +lean_ctor_set(x_43, 2, x_29); +lean_ctor_set(x_43, 3, x_41); +lean_ctor_set(x_43, 4, x_42); +lean_ctor_set(x_31, 2, x_43); if (lean_is_scalar(x_22)) { - x_43 = lean_alloc_ctor(1, 2, 0); + x_44 = lean_alloc_ctor(1, 2, 0); } else { - x_43 = x_22; - lean_ctor_set_tag(x_43, 1); + x_44 = x_22; + lean_ctor_set_tag(x_44, 1); } -lean_ctor_set(x_43, 0, x_33); -lean_ctor_set(x_43, 1, x_31); -return x_43; +lean_ctor_set(x_44, 0, x_33); +lean_ctor_set(x_44, 1, x_31); +return x_44; } } 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; -x_44 = lean_ctor_get(x_31, 0); -x_45 = lean_ctor_get(x_31, 1); -x_46 = lean_ctor_get(x_31, 3); -x_47 = lean_ctor_get(x_31, 4); -x_48 = lean_ctor_get(x_31, 5); +lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; +x_45 = lean_ctor_get(x_31, 0); +x_46 = lean_ctor_get(x_31, 1); +x_47 = lean_ctor_get(x_31, 3); +x_48 = lean_ctor_get(x_31, 4); +x_49 = lean_ctor_get(x_31, 5); +lean_inc(x_49); lean_inc(x_48); lean_inc(x_47); lean_inc(x_46); lean_inc(x_45); -lean_inc(x_44); lean_dec(x_31); -x_49 = lean_ctor_get(x_32, 0); -lean_inc(x_49); -x_50 = lean_ctor_get(x_32, 1); +x_50 = lean_ctor_get(x_32, 0); lean_inc(x_50); -x_51 = lean_ctor_get(x_32, 3); +x_51 = lean_ctor_get(x_32, 1); lean_inc(x_51); +x_52 = lean_ctor_get(x_32, 3); +lean_inc(x_52); +x_53 = lean_ctor_get(x_32, 4); +lean_inc(x_53); if (lean_is_exclusive(x_32)) { lean_ctor_release(x_32, 0); lean_ctor_release(x_32, 1); lean_ctor_release(x_32, 2); lean_ctor_release(x_32, 3); - x_52 = x_32; + lean_ctor_release(x_32, 4); + x_54 = x_32; } else { lean_dec_ref(x_32); - x_52 = lean_box(0); + x_54 = lean_box(0); } -if (lean_is_scalar(x_52)) { - x_53 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_54)) { + x_55 = lean_alloc_ctor(0, 5, 0); } else { - x_53 = x_52; + x_55 = x_54; } -lean_ctor_set(x_53, 0, x_49); -lean_ctor_set(x_53, 1, x_50); -lean_ctor_set(x_53, 2, x_29); -lean_ctor_set(x_53, 3, x_51); -x_54 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_54, 0, x_44); -lean_ctor_set(x_54, 1, x_45); -lean_ctor_set(x_54, 2, x_53); -lean_ctor_set(x_54, 3, x_46); -lean_ctor_set(x_54, 4, x_47); -lean_ctor_set(x_54, 5, x_48); +lean_ctor_set(x_55, 0, x_50); +lean_ctor_set(x_55, 1, x_51); +lean_ctor_set(x_55, 2, x_29); +lean_ctor_set(x_55, 3, x_52); +lean_ctor_set(x_55, 4, x_53); +x_56 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_56, 0, x_45); +lean_ctor_set(x_56, 1, x_46); +lean_ctor_set(x_56, 2, x_55); +lean_ctor_set(x_56, 3, x_47); +lean_ctor_set(x_56, 4, x_48); +lean_ctor_set(x_56, 5, x_49); if (lean_is_scalar(x_22)) { - x_55 = lean_alloc_ctor(1, 2, 0); + x_57 = lean_alloc_ctor(1, 2, 0); } else { - x_55 = x_22; - lean_ctor_set_tag(x_55, 1); + x_57 = x_22; + lean_ctor_set_tag(x_57, 1); } -lean_ctor_set(x_55, 0, x_33); -lean_ctor_set(x_55, 1, x_54); -return x_55; +lean_ctor_set(x_57, 0, x_33); +lean_ctor_set(x_57, 1, x_56); +return x_57; } } else { -lean_object* x_56; lean_object* x_57; uint8_t x_58; -x_56 = lean_ctor_get(x_31, 2); -lean_inc(x_56); -x_57 = lean_ctor_get(x_30, 0); -lean_inc(x_57); +lean_object* x_58; lean_object* x_59; uint8_t x_60; +x_58 = lean_ctor_get(x_31, 2); +lean_inc(x_58); +x_59 = lean_ctor_get(x_30, 0); +lean_inc(x_59); lean_dec(x_30); -x_58 = !lean_is_exclusive(x_31); -if (x_58 == 0) -{ -lean_object* x_59; uint8_t x_60; -x_59 = lean_ctor_get(x_31, 2); -lean_dec(x_59); -x_60 = !lean_is_exclusive(x_56); +x_60 = !lean_is_exclusive(x_31); if (x_60 == 0) { -lean_object* x_61; lean_object* x_62; -x_61 = lean_ctor_get(x_56, 2); +lean_object* x_61; uint8_t x_62; +x_61 = lean_ctor_get(x_31, 2); lean_dec(x_61); -lean_ctor_set(x_56, 2, x_29); +x_62 = !lean_is_exclusive(x_58); +if (x_62 == 0) +{ +lean_object* x_63; lean_object* x_64; +x_63 = lean_ctor_get(x_58, 2); +lean_dec(x_63); +lean_ctor_set(x_58, 2, x_29); if (lean_is_scalar(x_22)) { - x_62 = lean_alloc_ctor(0, 2, 0); + x_64 = lean_alloc_ctor(0, 2, 0); } else { - x_62 = x_22; + x_64 = x_22; } -lean_ctor_set(x_62, 0, x_57); -lean_ctor_set(x_62, 1, x_31); -return x_62; +lean_ctor_set(x_64, 0, x_59); +lean_ctor_set(x_64, 1, x_31); +return x_64; } else { -lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; -x_63 = lean_ctor_get(x_56, 0); -x_64 = lean_ctor_get(x_56, 1); -x_65 = lean_ctor_get(x_56, 3); +lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; +x_65 = lean_ctor_get(x_58, 0); +x_66 = lean_ctor_get(x_58, 1); +x_67 = lean_ctor_get(x_58, 3); +x_68 = lean_ctor_get(x_58, 4); +lean_inc(x_68); +lean_inc(x_67); +lean_inc(x_66); lean_inc(x_65); -lean_inc(x_64); -lean_inc(x_63); -lean_dec(x_56); -x_66 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_66, 0, x_63); -lean_ctor_set(x_66, 1, x_64); -lean_ctor_set(x_66, 2, x_29); -lean_ctor_set(x_66, 3, x_65); -lean_ctor_set(x_31, 2, x_66); +lean_dec(x_58); +x_69 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_69, 0, x_65); +lean_ctor_set(x_69, 1, x_66); +lean_ctor_set(x_69, 2, x_29); +lean_ctor_set(x_69, 3, x_67); +lean_ctor_set(x_69, 4, x_68); +lean_ctor_set(x_31, 2, x_69); if (lean_is_scalar(x_22)) { - x_67 = lean_alloc_ctor(0, 2, 0); + x_70 = lean_alloc_ctor(0, 2, 0); } else { - x_67 = x_22; + x_70 = x_22; } -lean_ctor_set(x_67, 0, x_57); -lean_ctor_set(x_67, 1, x_31); -return x_67; +lean_ctor_set(x_70, 0, x_59); +lean_ctor_set(x_70, 1, x_31); +return x_70; } } else { -lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; -x_68 = lean_ctor_get(x_31, 0); -x_69 = lean_ctor_get(x_31, 1); -x_70 = lean_ctor_get(x_31, 3); -x_71 = lean_ctor_get(x_31, 4); -x_72 = lean_ctor_get(x_31, 5); +lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; +x_71 = lean_ctor_get(x_31, 0); +x_72 = lean_ctor_get(x_31, 1); +x_73 = lean_ctor_get(x_31, 3); +x_74 = lean_ctor_get(x_31, 4); +x_75 = lean_ctor_get(x_31, 5); +lean_inc(x_75); +lean_inc(x_74); +lean_inc(x_73); lean_inc(x_72); lean_inc(x_71); -lean_inc(x_70); -lean_inc(x_69); -lean_inc(x_68); lean_dec(x_31); -x_73 = lean_ctor_get(x_56, 0); -lean_inc(x_73); -x_74 = lean_ctor_get(x_56, 1); -lean_inc(x_74); -x_75 = lean_ctor_get(x_56, 3); -lean_inc(x_75); -if (lean_is_exclusive(x_56)) { - lean_ctor_release(x_56, 0); - lean_ctor_release(x_56, 1); - lean_ctor_release(x_56, 2); - lean_ctor_release(x_56, 3); - x_76 = x_56; +x_76 = lean_ctor_get(x_58, 0); +lean_inc(x_76); +x_77 = lean_ctor_get(x_58, 1); +lean_inc(x_77); +x_78 = lean_ctor_get(x_58, 3); +lean_inc(x_78); +x_79 = lean_ctor_get(x_58, 4); +lean_inc(x_79); +if (lean_is_exclusive(x_58)) { + lean_ctor_release(x_58, 0); + lean_ctor_release(x_58, 1); + lean_ctor_release(x_58, 2); + lean_ctor_release(x_58, 3); + lean_ctor_release(x_58, 4); + x_80 = x_58; } else { - lean_dec_ref(x_56); - x_76 = lean_box(0); + lean_dec_ref(x_58); + x_80 = lean_box(0); } -if (lean_is_scalar(x_76)) { - x_77 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_80)) { + x_81 = lean_alloc_ctor(0, 5, 0); } else { - x_77 = x_76; + x_81 = x_80; } -lean_ctor_set(x_77, 0, x_73); -lean_ctor_set(x_77, 1, x_74); -lean_ctor_set(x_77, 2, x_29); -lean_ctor_set(x_77, 3, x_75); -x_78 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_78, 0, x_68); -lean_ctor_set(x_78, 1, x_69); -lean_ctor_set(x_78, 2, x_77); -lean_ctor_set(x_78, 3, x_70); -lean_ctor_set(x_78, 4, x_71); -lean_ctor_set(x_78, 5, x_72); +lean_ctor_set(x_81, 0, x_76); +lean_ctor_set(x_81, 1, x_77); +lean_ctor_set(x_81, 2, x_29); +lean_ctor_set(x_81, 3, x_78); +lean_ctor_set(x_81, 4, x_79); +x_82 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_82, 0, x_71); +lean_ctor_set(x_82, 1, x_72); +lean_ctor_set(x_82, 2, x_81); +lean_ctor_set(x_82, 3, x_73); +lean_ctor_set(x_82, 4, x_74); +lean_ctor_set(x_82, 5, x_75); if (lean_is_scalar(x_22)) { - x_79 = lean_alloc_ctor(0, 2, 0); + x_83 = lean_alloc_ctor(0, 2, 0); } else { - x_79 = x_22; + x_83 = x_22; } -lean_ctor_set(x_79, 0, x_57); -lean_ctor_set(x_79, 1, x_78); -return x_79; +lean_ctor_set(x_83, 0, x_59); +lean_ctor_set(x_83, 1, x_82); +return x_83; } } } } else { -lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_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; -x_108 = lean_ctor_get(x_27, 0); -x_109 = lean_ctor_get(x_27, 1); -x_110 = lean_ctor_get(x_27, 2); -x_111 = lean_ctor_get(x_27, 3); -lean_inc(x_111); -lean_inc(x_110); -lean_inc(x_109); -lean_inc(x_108); -lean_dec(x_27); -x_145 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_146 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_146, 0, x_108); -lean_ctor_set(x_146, 1, x_109); -lean_ctor_set(x_146, 2, x_145); -lean_ctor_set(x_146, 3, x_111); -lean_ctor_set(x_21, 2, x_146); -x_147 = lean_ctor_get(x_5, 0); -lean_inc(x_147); -x_148 = lean_ctor_get(x_5, 1); -lean_inc(x_148); -x_149 = lean_ctor_get(x_5, 2); -lean_inc(x_149); -x_150 = lean_ctor_get(x_5, 3); -lean_inc(x_150); -x_151 = lean_ctor_get(x_5, 4); -lean_inc(x_151); -if (lean_is_exclusive(x_5)) { - lean_ctor_release(x_5, 0); - lean_ctor_release(x_5, 1); - lean_ctor_release(x_5, 2); - lean_ctor_release(x_5, 3); - lean_ctor_release(x_5, 4); - x_152 = x_5; -} else { - lean_dec_ref(x_5); - x_152 = lean_box(0); -} -x_153 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_153, 0, x_23); -lean_ctor_set(x_153, 1, x_10); -x_154 = lean_array_push(x_149, x_153); -if (lean_is_scalar(x_152)) { - x_155 = lean_alloc_ctor(0, 5, 0); -} else { - x_155 = x_152; -} -lean_ctor_set(x_155, 0, x_147); -lean_ctor_set(x_155, 1, x_148); -lean_ctor_set(x_155, 2, x_154); -lean_ctor_set(x_155, 3, x_150); -lean_ctor_set(x_155, 4, x_151); -x_156 = l_Lean_Meta_withNewLocalInstances___main___rarg(x_1, x_2, x_25, x_4, x_155, x_21); -if (lean_obj_tag(x_156) == 0) -{ -lean_object* x_157; lean_object* x_158; lean_object* x_159; -x_157 = lean_ctor_get(x_156, 0); -lean_inc(x_157); -x_158 = lean_ctor_get(x_156, 1); -lean_inc(x_158); -lean_dec(x_156); -x_159 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_159, 0, x_157); -x_112 = x_159; -x_113 = x_158; -goto block_144; -} -else -{ -lean_object* x_160; lean_object* x_161; lean_object* x_162; -x_160 = lean_ctor_get(x_156, 0); -lean_inc(x_160); -x_161 = lean_ctor_get(x_156, 1); -lean_inc(x_161); -lean_dec(x_156); -x_162 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_162, 0, x_160); -x_112 = x_162; -x_113 = x_161; -goto block_144; -} -block_144: -{ -if (lean_obj_tag(x_112) == 0) -{ -lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; -x_114 = lean_ctor_get(x_113, 2); -lean_inc(x_114); -x_115 = lean_ctor_get(x_112, 0); -lean_inc(x_115); -lean_dec(x_112); -x_116 = lean_ctor_get(x_113, 0); +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_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; +x_112 = lean_ctor_get(x_27, 0); +x_113 = lean_ctor_get(x_27, 1); +x_114 = lean_ctor_get(x_27, 2); +x_115 = lean_ctor_get(x_27, 3); +x_116 = lean_ctor_get(x_27, 4); lean_inc(x_116); -x_117 = lean_ctor_get(x_113, 1); -lean_inc(x_117); -x_118 = lean_ctor_get(x_113, 3); -lean_inc(x_118); -x_119 = lean_ctor_get(x_113, 4); -lean_inc(x_119); -x_120 = lean_ctor_get(x_113, 5); -lean_inc(x_120); -if (lean_is_exclusive(x_113)) { - lean_ctor_release(x_113, 0); - lean_ctor_release(x_113, 1); - lean_ctor_release(x_113, 2); - lean_ctor_release(x_113, 3); - lean_ctor_release(x_113, 4); - lean_ctor_release(x_113, 5); - x_121 = x_113; -} else { - lean_dec_ref(x_113); - x_121 = lean_box(0); -} -x_122 = lean_ctor_get(x_114, 0); -lean_inc(x_122); -x_123 = lean_ctor_get(x_114, 1); -lean_inc(x_123); -x_124 = lean_ctor_get(x_114, 3); -lean_inc(x_124); -if (lean_is_exclusive(x_114)) { - lean_ctor_release(x_114, 0); - lean_ctor_release(x_114, 1); - lean_ctor_release(x_114, 2); - lean_ctor_release(x_114, 3); - x_125 = x_114; -} else { - lean_dec_ref(x_114); - x_125 = lean_box(0); -} -if (lean_is_scalar(x_125)) { - x_126 = lean_alloc_ctor(0, 4, 0); -} else { - x_126 = x_125; -} -lean_ctor_set(x_126, 0, x_122); -lean_ctor_set(x_126, 1, x_123); -lean_ctor_set(x_126, 2, x_110); -lean_ctor_set(x_126, 3, x_124); -if (lean_is_scalar(x_121)) { - x_127 = lean_alloc_ctor(0, 6, 0); -} else { - x_127 = x_121; -} -lean_ctor_set(x_127, 0, x_116); -lean_ctor_set(x_127, 1, x_117); -lean_ctor_set(x_127, 2, x_126); -lean_ctor_set(x_127, 3, x_118); -lean_ctor_set(x_127, 4, x_119); -lean_ctor_set(x_127, 5, x_120); -if (lean_is_scalar(x_22)) { - x_128 = lean_alloc_ctor(1, 2, 0); -} else { - x_128 = x_22; - lean_ctor_set_tag(x_128, 1); -} -lean_ctor_set(x_128, 0, x_115); -lean_ctor_set(x_128, 1, x_127); -return x_128; -} -else -{ -lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; 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; -x_129 = lean_ctor_get(x_113, 2); -lean_inc(x_129); -x_130 = lean_ctor_get(x_112, 0); -lean_inc(x_130); -lean_dec(x_112); -x_131 = lean_ctor_get(x_113, 0); -lean_inc(x_131); -x_132 = lean_ctor_get(x_113, 1); -lean_inc(x_132); -x_133 = lean_ctor_get(x_113, 3); -lean_inc(x_133); -x_134 = lean_ctor_get(x_113, 4); -lean_inc(x_134); -x_135 = lean_ctor_get(x_113, 5); -lean_inc(x_135); -if (lean_is_exclusive(x_113)) { - lean_ctor_release(x_113, 0); - lean_ctor_release(x_113, 1); - lean_ctor_release(x_113, 2); - lean_ctor_release(x_113, 3); - lean_ctor_release(x_113, 4); - lean_ctor_release(x_113, 5); - x_136 = x_113; -} else { - lean_dec_ref(x_113); - x_136 = lean_box(0); -} -x_137 = lean_ctor_get(x_129, 0); -lean_inc(x_137); -x_138 = lean_ctor_get(x_129, 1); -lean_inc(x_138); -x_139 = lean_ctor_get(x_129, 3); -lean_inc(x_139); -if (lean_is_exclusive(x_129)) { - lean_ctor_release(x_129, 0); - lean_ctor_release(x_129, 1); - lean_ctor_release(x_129, 2); - lean_ctor_release(x_129, 3); - x_140 = x_129; -} else { - lean_dec_ref(x_129); - x_140 = lean_box(0); -} -if (lean_is_scalar(x_140)) { - x_141 = lean_alloc_ctor(0, 4, 0); -} else { - x_141 = x_140; -} -lean_ctor_set(x_141, 0, x_137); -lean_ctor_set(x_141, 1, x_138); -lean_ctor_set(x_141, 2, x_110); -lean_ctor_set(x_141, 3, x_139); -if (lean_is_scalar(x_136)) { - x_142 = lean_alloc_ctor(0, 6, 0); -} else { - x_142 = x_136; -} -lean_ctor_set(x_142, 0, x_131); -lean_ctor_set(x_142, 1, x_132); -lean_ctor_set(x_142, 2, x_141); -lean_ctor_set(x_142, 3, x_133); -lean_ctor_set(x_142, 4, x_134); -lean_ctor_set(x_142, 5, x_135); -if (lean_is_scalar(x_22)) { - x_143 = lean_alloc_ctor(0, 2, 0); -} else { - x_143 = x_22; -} -lean_ctor_set(x_143, 0, x_130); -lean_ctor_set(x_143, 1, x_142); -return x_143; -} -} -} -} -else -{ -lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; lean_object* x_173; lean_object* x_174; lean_object* x_175; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; -x_163 = lean_ctor_get(x_21, 2); -x_164 = lean_ctor_get(x_21, 0); -x_165 = lean_ctor_get(x_21, 1); -x_166 = lean_ctor_get(x_21, 3); -x_167 = lean_ctor_get(x_21, 4); -x_168 = lean_ctor_get(x_21, 5); -lean_inc(x_168); -lean_inc(x_167); -lean_inc(x_166); -lean_inc(x_163); -lean_inc(x_165); -lean_inc(x_164); -lean_dec(x_21); -x_169 = lean_ctor_get(x_163, 0); -lean_inc(x_169); -x_170 = lean_ctor_get(x_163, 1); -lean_inc(x_170); -x_171 = lean_ctor_get(x_163, 2); -lean_inc(x_171); -x_172 = lean_ctor_get(x_163, 3); -lean_inc(x_172); -if (lean_is_exclusive(x_163)) { - lean_ctor_release(x_163, 0); - lean_ctor_release(x_163, 1); - lean_ctor_release(x_163, 2); - lean_ctor_release(x_163, 3); - x_173 = x_163; -} else { - lean_dec_ref(x_163); - x_173 = lean_box(0); -} -x_207 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_173)) { - x_208 = lean_alloc_ctor(0, 4, 0); -} else { - x_208 = x_173; -} -lean_ctor_set(x_208, 0, x_169); -lean_ctor_set(x_208, 1, x_170); -lean_ctor_set(x_208, 2, x_207); -lean_ctor_set(x_208, 3, x_172); -x_209 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_209, 0, x_164); -lean_ctor_set(x_209, 1, x_165); -lean_ctor_set(x_209, 2, x_208); -lean_ctor_set(x_209, 3, x_166); -lean_ctor_set(x_209, 4, x_167); -lean_ctor_set(x_209, 5, x_168); -x_210 = lean_ctor_get(x_5, 0); -lean_inc(x_210); -x_211 = lean_ctor_get(x_5, 1); -lean_inc(x_211); -x_212 = lean_ctor_get(x_5, 2); -lean_inc(x_212); -x_213 = lean_ctor_get(x_5, 3); -lean_inc(x_213); -x_214 = lean_ctor_get(x_5, 4); -lean_inc(x_214); +lean_inc(x_115); +lean_inc(x_114); +lean_inc(x_113); +lean_inc(x_112); +lean_dec(x_27); +x_152 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_153 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_153, 0, x_112); +lean_ctor_set(x_153, 1, x_113); +lean_ctor_set(x_153, 2, x_152); +lean_ctor_set(x_153, 3, x_115); +lean_ctor_set(x_153, 4, x_116); +lean_ctor_set(x_21, 2, x_153); +x_154 = lean_ctor_get(x_5, 0); +lean_inc(x_154); +x_155 = lean_ctor_get(x_5, 1); +lean_inc(x_155); +x_156 = lean_ctor_get(x_5, 2); +lean_inc(x_156); +x_157 = lean_ctor_get(x_5, 3); +lean_inc(x_157); +x_158 = lean_ctor_get(x_5, 4); +lean_inc(x_158); if (lean_is_exclusive(x_5)) { lean_ctor_release(x_5, 0); lean_ctor_release(x_5, 1); lean_ctor_release(x_5, 2); lean_ctor_release(x_5, 3); lean_ctor_release(x_5, 4); - x_215 = x_5; + x_159 = x_5; } else { lean_dec_ref(x_5); - x_215 = lean_box(0); + x_159 = lean_box(0); } -x_216 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_216, 0, x_23); -lean_ctor_set(x_216, 1, x_10); -x_217 = lean_array_push(x_212, x_216); -if (lean_is_scalar(x_215)) { +x_160 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_160, 0, x_23); +lean_ctor_set(x_160, 1, x_10); +x_161 = lean_array_push(x_156, x_160); +if (lean_is_scalar(x_159)) { + x_162 = lean_alloc_ctor(0, 5, 0); +} else { + x_162 = x_159; +} +lean_ctor_set(x_162, 0, x_154); +lean_ctor_set(x_162, 1, x_155); +lean_ctor_set(x_162, 2, x_161); +lean_ctor_set(x_162, 3, x_157); +lean_ctor_set(x_162, 4, x_158); +x_163 = l_Lean_Meta_withNewLocalInstances___main___rarg(x_1, x_2, x_25, x_4, x_162, x_21); +if (lean_obj_tag(x_163) == 0) +{ +lean_object* x_164; lean_object* x_165; lean_object* x_166; +x_164 = lean_ctor_get(x_163, 0); +lean_inc(x_164); +x_165 = lean_ctor_get(x_163, 1); +lean_inc(x_165); +lean_dec(x_163); +x_166 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_166, 0, x_164); +x_117 = x_166; +x_118 = x_165; +goto block_151; +} +else +{ +lean_object* x_167; lean_object* x_168; lean_object* x_169; +x_167 = lean_ctor_get(x_163, 0); +lean_inc(x_167); +x_168 = lean_ctor_get(x_163, 1); +lean_inc(x_168); +lean_dec(x_163); +x_169 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_169, 0, x_167); +x_117 = x_169; +x_118 = x_168; +goto block_151; +} +block_151: +{ +if (lean_obj_tag(x_117) == 0) +{ +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; +x_119 = lean_ctor_get(x_118, 2); +lean_inc(x_119); +x_120 = lean_ctor_get(x_117, 0); +lean_inc(x_120); +lean_dec(x_117); +x_121 = lean_ctor_get(x_118, 0); +lean_inc(x_121); +x_122 = lean_ctor_get(x_118, 1); +lean_inc(x_122); +x_123 = lean_ctor_get(x_118, 3); +lean_inc(x_123); +x_124 = lean_ctor_get(x_118, 4); +lean_inc(x_124); +x_125 = lean_ctor_get(x_118, 5); +lean_inc(x_125); +if (lean_is_exclusive(x_118)) { + lean_ctor_release(x_118, 0); + lean_ctor_release(x_118, 1); + lean_ctor_release(x_118, 2); + lean_ctor_release(x_118, 3); + lean_ctor_release(x_118, 4); + lean_ctor_release(x_118, 5); + x_126 = x_118; +} else { + lean_dec_ref(x_118); + x_126 = lean_box(0); +} +x_127 = lean_ctor_get(x_119, 0); +lean_inc(x_127); +x_128 = lean_ctor_get(x_119, 1); +lean_inc(x_128); +x_129 = lean_ctor_get(x_119, 3); +lean_inc(x_129); +x_130 = lean_ctor_get(x_119, 4); +lean_inc(x_130); +if (lean_is_exclusive(x_119)) { + lean_ctor_release(x_119, 0); + lean_ctor_release(x_119, 1); + lean_ctor_release(x_119, 2); + lean_ctor_release(x_119, 3); + lean_ctor_release(x_119, 4); + x_131 = x_119; +} else { + lean_dec_ref(x_119); + x_131 = lean_box(0); +} +if (lean_is_scalar(x_131)) { + x_132 = lean_alloc_ctor(0, 5, 0); +} else { + x_132 = x_131; +} +lean_ctor_set(x_132, 0, x_127); +lean_ctor_set(x_132, 1, x_128); +lean_ctor_set(x_132, 2, x_114); +lean_ctor_set(x_132, 3, x_129); +lean_ctor_set(x_132, 4, x_130); +if (lean_is_scalar(x_126)) { + x_133 = lean_alloc_ctor(0, 6, 0); +} else { + x_133 = x_126; +} +lean_ctor_set(x_133, 0, x_121); +lean_ctor_set(x_133, 1, x_122); +lean_ctor_set(x_133, 2, x_132); +lean_ctor_set(x_133, 3, x_123); +lean_ctor_set(x_133, 4, x_124); +lean_ctor_set(x_133, 5, x_125); +if (lean_is_scalar(x_22)) { + x_134 = lean_alloc_ctor(1, 2, 0); +} else { + x_134 = x_22; + lean_ctor_set_tag(x_134, 1); +} +lean_ctor_set(x_134, 0, x_120); +lean_ctor_set(x_134, 1, x_133); +return x_134; +} +else +{ +lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; 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; +x_135 = lean_ctor_get(x_118, 2); +lean_inc(x_135); +x_136 = lean_ctor_get(x_117, 0); +lean_inc(x_136); +lean_dec(x_117); +x_137 = lean_ctor_get(x_118, 0); +lean_inc(x_137); +x_138 = lean_ctor_get(x_118, 1); +lean_inc(x_138); +x_139 = lean_ctor_get(x_118, 3); +lean_inc(x_139); +x_140 = lean_ctor_get(x_118, 4); +lean_inc(x_140); +x_141 = lean_ctor_get(x_118, 5); +lean_inc(x_141); +if (lean_is_exclusive(x_118)) { + lean_ctor_release(x_118, 0); + lean_ctor_release(x_118, 1); + lean_ctor_release(x_118, 2); + lean_ctor_release(x_118, 3); + lean_ctor_release(x_118, 4); + lean_ctor_release(x_118, 5); + x_142 = x_118; +} else { + lean_dec_ref(x_118); + x_142 = lean_box(0); +} +x_143 = lean_ctor_get(x_135, 0); +lean_inc(x_143); +x_144 = lean_ctor_get(x_135, 1); +lean_inc(x_144); +x_145 = lean_ctor_get(x_135, 3); +lean_inc(x_145); +x_146 = lean_ctor_get(x_135, 4); +lean_inc(x_146); +if (lean_is_exclusive(x_135)) { + lean_ctor_release(x_135, 0); + lean_ctor_release(x_135, 1); + lean_ctor_release(x_135, 2); + lean_ctor_release(x_135, 3); + lean_ctor_release(x_135, 4); + x_147 = x_135; +} else { + lean_dec_ref(x_135); + x_147 = lean_box(0); +} +if (lean_is_scalar(x_147)) { + x_148 = lean_alloc_ctor(0, 5, 0); +} else { + x_148 = x_147; +} +lean_ctor_set(x_148, 0, x_143); +lean_ctor_set(x_148, 1, x_144); +lean_ctor_set(x_148, 2, x_114); +lean_ctor_set(x_148, 3, x_145); +lean_ctor_set(x_148, 4, x_146); +if (lean_is_scalar(x_142)) { + x_149 = lean_alloc_ctor(0, 6, 0); +} else { + x_149 = x_142; +} +lean_ctor_set(x_149, 0, x_137); +lean_ctor_set(x_149, 1, x_138); +lean_ctor_set(x_149, 2, x_148); +lean_ctor_set(x_149, 3, x_139); +lean_ctor_set(x_149, 4, x_140); +lean_ctor_set(x_149, 5, x_141); +if (lean_is_scalar(x_22)) { + x_150 = lean_alloc_ctor(0, 2, 0); +} else { + x_150 = x_22; +} +lean_ctor_set(x_150, 0, x_136); +lean_ctor_set(x_150, 1, x_149); +return x_150; +} +} +} +} +else +{ +lean_object* x_170; lean_object* x_171; lean_object* x_172; lean_object* x_173; lean_object* x_174; lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; lean_object* x_224; lean_object* x_225; lean_object* x_226; lean_object* x_227; lean_object* x_228; lean_object* x_229; +x_170 = lean_ctor_get(x_21, 2); +x_171 = lean_ctor_get(x_21, 0); +x_172 = lean_ctor_get(x_21, 1); +x_173 = lean_ctor_get(x_21, 3); +x_174 = lean_ctor_get(x_21, 4); +x_175 = lean_ctor_get(x_21, 5); +lean_inc(x_175); +lean_inc(x_174); +lean_inc(x_173); +lean_inc(x_170); +lean_inc(x_172); +lean_inc(x_171); +lean_dec(x_21); +x_176 = lean_ctor_get(x_170, 0); +lean_inc(x_176); +x_177 = lean_ctor_get(x_170, 1); +lean_inc(x_177); +x_178 = lean_ctor_get(x_170, 2); +lean_inc(x_178); +x_179 = lean_ctor_get(x_170, 3); +lean_inc(x_179); +x_180 = lean_ctor_get(x_170, 4); +lean_inc(x_180); +if (lean_is_exclusive(x_170)) { + lean_ctor_release(x_170, 0); + lean_ctor_release(x_170, 1); + lean_ctor_release(x_170, 2); + lean_ctor_release(x_170, 3); + lean_ctor_release(x_170, 4); + x_181 = x_170; +} else { + lean_dec_ref(x_170); + x_181 = lean_box(0); +} +x_217 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_181)) { x_218 = lean_alloc_ctor(0, 5, 0); } else { - x_218 = x_215; + x_218 = x_181; } -lean_ctor_set(x_218, 0, x_210); -lean_ctor_set(x_218, 1, x_211); +lean_ctor_set(x_218, 0, x_176); +lean_ctor_set(x_218, 1, x_177); lean_ctor_set(x_218, 2, x_217); -lean_ctor_set(x_218, 3, x_213); -lean_ctor_set(x_218, 4, x_214); -x_219 = l_Lean_Meta_withNewLocalInstances___main___rarg(x_1, x_2, x_25, x_4, x_218, x_209); -if (lean_obj_tag(x_219) == 0) -{ -lean_object* x_220; lean_object* x_221; lean_object* x_222; -x_220 = lean_ctor_get(x_219, 0); +lean_ctor_set(x_218, 3, x_179); +lean_ctor_set(x_218, 4, x_180); +x_219 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_219, 0, x_171); +lean_ctor_set(x_219, 1, x_172); +lean_ctor_set(x_219, 2, x_218); +lean_ctor_set(x_219, 3, x_173); +lean_ctor_set(x_219, 4, x_174); +lean_ctor_set(x_219, 5, x_175); +x_220 = lean_ctor_get(x_5, 0); lean_inc(x_220); -x_221 = lean_ctor_get(x_219, 1); +x_221 = lean_ctor_get(x_5, 1); lean_inc(x_221); -lean_dec(x_219); -x_222 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_222, 0, x_220); -x_174 = x_222; -x_175 = x_221; -goto block_206; -} -else -{ -lean_object* x_223; lean_object* x_224; lean_object* x_225; -x_223 = lean_ctor_get(x_219, 0); +x_222 = lean_ctor_get(x_5, 2); +lean_inc(x_222); +x_223 = lean_ctor_get(x_5, 3); lean_inc(x_223); -x_224 = lean_ctor_get(x_219, 1); +x_224 = lean_ctor_get(x_5, 4); lean_inc(x_224); -lean_dec(x_219); -x_225 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_225, 0, x_223); -x_174 = x_225; -x_175 = x_224; -goto block_206; +if (lean_is_exclusive(x_5)) { + lean_ctor_release(x_5, 0); + lean_ctor_release(x_5, 1); + lean_ctor_release(x_5, 2); + lean_ctor_release(x_5, 3); + lean_ctor_release(x_5, 4); + x_225 = x_5; +} else { + lean_dec_ref(x_5); + x_225 = lean_box(0); } -block_206: +x_226 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_226, 0, x_23); +lean_ctor_set(x_226, 1, x_10); +x_227 = lean_array_push(x_222, x_226); +if (lean_is_scalar(x_225)) { + x_228 = lean_alloc_ctor(0, 5, 0); +} else { + x_228 = x_225; +} +lean_ctor_set(x_228, 0, x_220); +lean_ctor_set(x_228, 1, x_221); +lean_ctor_set(x_228, 2, x_227); +lean_ctor_set(x_228, 3, x_223); +lean_ctor_set(x_228, 4, x_224); +x_229 = l_Lean_Meta_withNewLocalInstances___main___rarg(x_1, x_2, x_25, x_4, x_228, x_219); +if (lean_obj_tag(x_229) == 0) { -if (lean_obj_tag(x_174) == 0) -{ -lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; 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; -x_176 = lean_ctor_get(x_175, 2); -lean_inc(x_176); -x_177 = lean_ctor_get(x_174, 0); -lean_inc(x_177); -lean_dec(x_174); -x_178 = lean_ctor_get(x_175, 0); -lean_inc(x_178); -x_179 = lean_ctor_get(x_175, 1); -lean_inc(x_179); -x_180 = lean_ctor_get(x_175, 3); -lean_inc(x_180); -x_181 = lean_ctor_get(x_175, 4); -lean_inc(x_181); -x_182 = lean_ctor_get(x_175, 5); -lean_inc(x_182); -if (lean_is_exclusive(x_175)) { - lean_ctor_release(x_175, 0); - lean_ctor_release(x_175, 1); - lean_ctor_release(x_175, 2); - lean_ctor_release(x_175, 3); - lean_ctor_release(x_175, 4); - lean_ctor_release(x_175, 5); - x_183 = x_175; -} else { - lean_dec_ref(x_175); - x_183 = lean_box(0); -} -x_184 = lean_ctor_get(x_176, 0); -lean_inc(x_184); -x_185 = lean_ctor_get(x_176, 1); -lean_inc(x_185); -x_186 = lean_ctor_get(x_176, 3); -lean_inc(x_186); -if (lean_is_exclusive(x_176)) { - lean_ctor_release(x_176, 0); - lean_ctor_release(x_176, 1); - lean_ctor_release(x_176, 2); - lean_ctor_release(x_176, 3); - x_187 = x_176; -} else { - lean_dec_ref(x_176); - x_187 = lean_box(0); -} -if (lean_is_scalar(x_187)) { - x_188 = lean_alloc_ctor(0, 4, 0); -} else { - x_188 = x_187; -} -lean_ctor_set(x_188, 0, x_184); -lean_ctor_set(x_188, 1, x_185); -lean_ctor_set(x_188, 2, x_171); -lean_ctor_set(x_188, 3, x_186); -if (lean_is_scalar(x_183)) { - x_189 = lean_alloc_ctor(0, 6, 0); -} else { - x_189 = x_183; -} -lean_ctor_set(x_189, 0, x_178); -lean_ctor_set(x_189, 1, x_179); -lean_ctor_set(x_189, 2, x_188); -lean_ctor_set(x_189, 3, x_180); -lean_ctor_set(x_189, 4, x_181); -lean_ctor_set(x_189, 5, x_182); -if (lean_is_scalar(x_22)) { - x_190 = lean_alloc_ctor(1, 2, 0); -} else { - x_190 = x_22; - lean_ctor_set_tag(x_190, 1); -} -lean_ctor_set(x_190, 0, x_177); -lean_ctor_set(x_190, 1, x_189); -return x_190; +lean_object* x_230; lean_object* x_231; lean_object* x_232; +x_230 = lean_ctor_get(x_229, 0); +lean_inc(x_230); +x_231 = lean_ctor_get(x_229, 1); +lean_inc(x_231); +lean_dec(x_229); +x_232 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_232, 0, x_230); +x_182 = x_232; +x_183 = x_231; +goto block_216; } else { -lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; -x_191 = lean_ctor_get(x_175, 2); -lean_inc(x_191); -x_192 = lean_ctor_get(x_174, 0); +lean_object* x_233; lean_object* x_234; lean_object* x_235; +x_233 = lean_ctor_get(x_229, 0); +lean_inc(x_233); +x_234 = lean_ctor_get(x_229, 1); +lean_inc(x_234); +lean_dec(x_229); +x_235 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_235, 0, x_233); +x_182 = x_235; +x_183 = x_234; +goto block_216; +} +block_216: +{ +if (lean_obj_tag(x_182) == 0) +{ +lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; +x_184 = lean_ctor_get(x_183, 2); +lean_inc(x_184); +x_185 = lean_ctor_get(x_182, 0); +lean_inc(x_185); +lean_dec(x_182); +x_186 = lean_ctor_get(x_183, 0); +lean_inc(x_186); +x_187 = lean_ctor_get(x_183, 1); +lean_inc(x_187); +x_188 = lean_ctor_get(x_183, 3); +lean_inc(x_188); +x_189 = lean_ctor_get(x_183, 4); +lean_inc(x_189); +x_190 = lean_ctor_get(x_183, 5); +lean_inc(x_190); +if (lean_is_exclusive(x_183)) { + lean_ctor_release(x_183, 0); + lean_ctor_release(x_183, 1); + lean_ctor_release(x_183, 2); + lean_ctor_release(x_183, 3); + lean_ctor_release(x_183, 4); + lean_ctor_release(x_183, 5); + x_191 = x_183; +} else { + lean_dec_ref(x_183); + x_191 = lean_box(0); +} +x_192 = lean_ctor_get(x_184, 0); lean_inc(x_192); -lean_dec(x_174); -x_193 = lean_ctor_get(x_175, 0); +x_193 = lean_ctor_get(x_184, 1); lean_inc(x_193); -x_194 = lean_ctor_get(x_175, 1); +x_194 = lean_ctor_get(x_184, 3); lean_inc(x_194); -x_195 = lean_ctor_get(x_175, 3); +x_195 = lean_ctor_get(x_184, 4); lean_inc(x_195); -x_196 = lean_ctor_get(x_175, 4); -lean_inc(x_196); -x_197 = lean_ctor_get(x_175, 5); -lean_inc(x_197); -if (lean_is_exclusive(x_175)) { - lean_ctor_release(x_175, 0); - lean_ctor_release(x_175, 1); - lean_ctor_release(x_175, 2); - lean_ctor_release(x_175, 3); - lean_ctor_release(x_175, 4); - lean_ctor_release(x_175, 5); - x_198 = x_175; +if (lean_is_exclusive(x_184)) { + lean_ctor_release(x_184, 0); + lean_ctor_release(x_184, 1); + lean_ctor_release(x_184, 2); + lean_ctor_release(x_184, 3); + lean_ctor_release(x_184, 4); + x_196 = x_184; } else { - lean_dec_ref(x_175); - x_198 = lean_box(0); + lean_dec_ref(x_184); + x_196 = lean_box(0); } -x_199 = lean_ctor_get(x_191, 0); -lean_inc(x_199); -x_200 = lean_ctor_get(x_191, 1); -lean_inc(x_200); -x_201 = lean_ctor_get(x_191, 3); -lean_inc(x_201); -if (lean_is_exclusive(x_191)) { - lean_ctor_release(x_191, 0); - lean_ctor_release(x_191, 1); - lean_ctor_release(x_191, 2); - lean_ctor_release(x_191, 3); - x_202 = x_191; +if (lean_is_scalar(x_196)) { + x_197 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_191); - x_202 = lean_box(0); + x_197 = x_196; } -if (lean_is_scalar(x_202)) { - x_203 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_197, 0, x_192); +lean_ctor_set(x_197, 1, x_193); +lean_ctor_set(x_197, 2, x_178); +lean_ctor_set(x_197, 3, x_194); +lean_ctor_set(x_197, 4, x_195); +if (lean_is_scalar(x_191)) { + x_198 = lean_alloc_ctor(0, 6, 0); } else { - x_203 = x_202; + x_198 = x_191; } -lean_ctor_set(x_203, 0, x_199); -lean_ctor_set(x_203, 1, x_200); -lean_ctor_set(x_203, 2, x_171); -lean_ctor_set(x_203, 3, x_201); -if (lean_is_scalar(x_198)) { - x_204 = lean_alloc_ctor(0, 6, 0); -} else { - x_204 = x_198; -} -lean_ctor_set(x_204, 0, x_193); -lean_ctor_set(x_204, 1, x_194); -lean_ctor_set(x_204, 2, x_203); -lean_ctor_set(x_204, 3, x_195); -lean_ctor_set(x_204, 4, x_196); -lean_ctor_set(x_204, 5, x_197); +lean_ctor_set(x_198, 0, x_186); +lean_ctor_set(x_198, 1, x_187); +lean_ctor_set(x_198, 2, x_197); +lean_ctor_set(x_198, 3, x_188); +lean_ctor_set(x_198, 4, x_189); +lean_ctor_set(x_198, 5, x_190); if (lean_is_scalar(x_22)) { - x_205 = lean_alloc_ctor(0, 2, 0); + x_199 = lean_alloc_ctor(1, 2, 0); } else { - x_205 = x_22; + x_199 = x_22; + lean_ctor_set_tag(x_199, 1); } -lean_ctor_set(x_205, 0, x_192); -lean_ctor_set(x_205, 1, x_204); -return x_205; +lean_ctor_set(x_199, 0, x_185); +lean_ctor_set(x_199, 1, x_198); +return x_199; +} +else +{ +lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; +x_200 = lean_ctor_get(x_183, 2); +lean_inc(x_200); +x_201 = lean_ctor_get(x_182, 0); +lean_inc(x_201); +lean_dec(x_182); +x_202 = lean_ctor_get(x_183, 0); +lean_inc(x_202); +x_203 = lean_ctor_get(x_183, 1); +lean_inc(x_203); +x_204 = lean_ctor_get(x_183, 3); +lean_inc(x_204); +x_205 = lean_ctor_get(x_183, 4); +lean_inc(x_205); +x_206 = lean_ctor_get(x_183, 5); +lean_inc(x_206); +if (lean_is_exclusive(x_183)) { + lean_ctor_release(x_183, 0); + lean_ctor_release(x_183, 1); + lean_ctor_release(x_183, 2); + lean_ctor_release(x_183, 3); + lean_ctor_release(x_183, 4); + lean_ctor_release(x_183, 5); + x_207 = x_183; +} else { + lean_dec_ref(x_183); + x_207 = lean_box(0); +} +x_208 = lean_ctor_get(x_200, 0); +lean_inc(x_208); +x_209 = lean_ctor_get(x_200, 1); +lean_inc(x_209); +x_210 = lean_ctor_get(x_200, 3); +lean_inc(x_210); +x_211 = lean_ctor_get(x_200, 4); +lean_inc(x_211); +if (lean_is_exclusive(x_200)) { + lean_ctor_release(x_200, 0); + lean_ctor_release(x_200, 1); + lean_ctor_release(x_200, 2); + lean_ctor_release(x_200, 3); + lean_ctor_release(x_200, 4); + x_212 = x_200; +} else { + lean_dec_ref(x_200); + x_212 = lean_box(0); +} +if (lean_is_scalar(x_212)) { + x_213 = lean_alloc_ctor(0, 5, 0); +} else { + x_213 = x_212; +} +lean_ctor_set(x_213, 0, x_208); +lean_ctor_set(x_213, 1, x_209); +lean_ctor_set(x_213, 2, x_178); +lean_ctor_set(x_213, 3, x_210); +lean_ctor_set(x_213, 4, x_211); +if (lean_is_scalar(x_207)) { + x_214 = lean_alloc_ctor(0, 6, 0); +} else { + x_214 = x_207; +} +lean_ctor_set(x_214, 0, x_202); +lean_ctor_set(x_214, 1, x_203); +lean_ctor_set(x_214, 2, x_213); +lean_ctor_set(x_214, 3, x_204); +lean_ctor_set(x_214, 4, x_205); +lean_ctor_set(x_214, 5, x_206); +if (lean_is_scalar(x_22)) { + x_215 = lean_alloc_ctor(0, 2, 0); +} else { + x_215 = x_22; +} +lean_ctor_set(x_215, 0, x_201); +lean_ctor_set(x_215, 1, x_214); +return x_215; } } } } default: { -lean_object* x_226; lean_object* x_227; -x_226 = lean_ctor_get(x_15, 1); -lean_inc(x_226); +lean_object* x_236; lean_object* x_237; +x_236 = lean_ctor_get(x_15, 1); +lean_inc(x_236); lean_dec(x_15); lean_inc(x_1); lean_inc(x_5); -x_227 = lean_apply_3(x_1, x_14, x_5, x_226); -if (lean_obj_tag(x_227) == 0) +x_237 = lean_apply_3(x_1, x_14, x_5, x_236); +if (lean_obj_tag(x_237) == 0) { -lean_object* x_228; -x_228 = lean_ctor_get(x_227, 0); -lean_inc(x_228); -if (lean_obj_tag(x_228) == 0) +lean_object* x_238; +x_238 = lean_ctor_get(x_237, 0); +lean_inc(x_238); +if (lean_obj_tag(x_238) == 0) { -lean_object* x_229; lean_object* x_230; lean_object* x_231; +lean_object* x_239; lean_object* x_240; lean_object* x_241; lean_dec(x_10); -x_229 = lean_ctor_get(x_227, 1); -lean_inc(x_229); -lean_dec(x_227); -x_230 = lean_unsigned_to_nat(1u); -x_231 = lean_nat_add(x_3, x_230); +x_239 = lean_ctor_get(x_237, 1); +lean_inc(x_239); +lean_dec(x_237); +x_240 = lean_unsigned_to_nat(1u); +x_241 = lean_nat_add(x_3, x_240); lean_dec(x_3); -x_3 = x_231; -x_6 = x_229; +x_3 = x_241; +x_6 = x_239; goto _start; } else { -lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_object* x_236; lean_object* x_237; uint8_t x_238; -x_233 = lean_ctor_get(x_227, 1); -lean_inc(x_233); -if (lean_is_exclusive(x_227)) { - lean_ctor_release(x_227, 0); - lean_ctor_release(x_227, 1); - x_234 = x_227; +lean_object* x_243; lean_object* x_244; lean_object* x_245; lean_object* x_246; lean_object* x_247; uint8_t x_248; +x_243 = lean_ctor_get(x_237, 1); +lean_inc(x_243); +if (lean_is_exclusive(x_237)) { + lean_ctor_release(x_237, 0); + lean_ctor_release(x_237, 1); + x_244 = x_237; } else { - lean_dec_ref(x_227); - x_234 = lean_box(0); + lean_dec_ref(x_237); + x_244 = lean_box(0); } -x_235 = lean_ctor_get(x_228, 0); -lean_inc(x_235); -lean_dec(x_228); -x_236 = lean_unsigned_to_nat(1u); -x_237 = lean_nat_add(x_3, x_236); -lean_dec(x_3); -x_238 = !lean_is_exclusive(x_233); -if (x_238 == 0) -{ -lean_object* x_239; uint8_t x_240; -x_239 = lean_ctor_get(x_233, 2); -x_240 = !lean_is_exclusive(x_239); -if (x_240 == 0) -{ -lean_object* x_241; lean_object* x_242; lean_object* x_243; lean_object* x_293; uint8_t x_294; -x_241 = lean_ctor_get(x_239, 2); -x_293 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_239, 2, x_293); -x_294 = !lean_is_exclusive(x_5); -if (x_294 == 0) -{ -lean_object* x_295; lean_object* x_296; lean_object* x_297; lean_object* x_298; -x_295 = lean_ctor_get(x_5, 2); -x_296 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_296, 0, x_235); -lean_ctor_set(x_296, 1, x_10); -x_297 = lean_array_push(x_295, x_296); -lean_ctor_set(x_5, 2, x_297); -x_298 = l_Lean_Meta_withNewLocalInstances___main___rarg(x_1, x_2, x_237, x_4, x_5, x_233); -if (lean_obj_tag(x_298) == 0) -{ -lean_object* x_299; lean_object* x_300; lean_object* x_301; -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_alloc_ctor(1, 1, 0); -lean_ctor_set(x_301, 0, x_299); -x_242 = x_301; -x_243 = x_300; -goto block_292; -} -else -{ -lean_object* x_302; lean_object* x_303; lean_object* x_304; -x_302 = lean_ctor_get(x_298, 0); -lean_inc(x_302); -x_303 = lean_ctor_get(x_298, 1); -lean_inc(x_303); -lean_dec(x_298); -x_304 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_304, 0, x_302); -x_242 = x_304; -x_243 = x_303; -goto block_292; -} -} -else -{ -lean_object* x_305; lean_object* x_306; lean_object* x_307; lean_object* x_308; lean_object* x_309; lean_object* x_310; lean_object* x_311; lean_object* x_312; lean_object* x_313; -x_305 = lean_ctor_get(x_5, 0); -x_306 = lean_ctor_get(x_5, 1); -x_307 = lean_ctor_get(x_5, 2); -x_308 = lean_ctor_get(x_5, 3); -x_309 = lean_ctor_get(x_5, 4); -lean_inc(x_309); -lean_inc(x_308); -lean_inc(x_307); -lean_inc(x_306); -lean_inc(x_305); -lean_dec(x_5); -x_310 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_310, 0, x_235); -lean_ctor_set(x_310, 1, x_10); -x_311 = lean_array_push(x_307, x_310); -x_312 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_312, 0, x_305); -lean_ctor_set(x_312, 1, x_306); -lean_ctor_set(x_312, 2, x_311); -lean_ctor_set(x_312, 3, x_308); -lean_ctor_set(x_312, 4, x_309); -x_313 = l_Lean_Meta_withNewLocalInstances___main___rarg(x_1, x_2, x_237, x_4, x_312, x_233); -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); -x_316 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_316, 0, x_314); -x_242 = x_316; -x_243 = x_315; -goto block_292; -} -else -{ -lean_object* x_317; lean_object* x_318; lean_object* x_319; -x_317 = lean_ctor_get(x_313, 0); -lean_inc(x_317); -x_318 = lean_ctor_get(x_313, 1); -lean_inc(x_318); -lean_dec(x_313); -x_319 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_319, 0, x_317); -x_242 = x_319; -x_243 = x_318; -goto block_292; -} -} -block_292: -{ -if (lean_obj_tag(x_242) == 0) -{ -lean_object* x_244; lean_object* x_245; uint8_t x_246; -x_244 = lean_ctor_get(x_243, 2); -lean_inc(x_244); -x_245 = lean_ctor_get(x_242, 0); +x_245 = lean_ctor_get(x_238, 0); lean_inc(x_245); -lean_dec(x_242); -x_246 = !lean_is_exclusive(x_243); -if (x_246 == 0) -{ -lean_object* x_247; uint8_t x_248; -x_247 = lean_ctor_get(x_243, 2); -lean_dec(x_247); -x_248 = !lean_is_exclusive(x_244); +lean_dec(x_238); +x_246 = lean_unsigned_to_nat(1u); +x_247 = lean_nat_add(x_3, x_246); +lean_dec(x_3); +x_248 = !lean_is_exclusive(x_243); if (x_248 == 0) { -lean_object* x_249; lean_object* x_250; -x_249 = lean_ctor_get(x_244, 2); -lean_dec(x_249); -lean_ctor_set(x_244, 2, x_241); -if (lean_is_scalar(x_234)) { - x_250 = lean_alloc_ctor(1, 2, 0); -} else { - x_250 = x_234; - lean_ctor_set_tag(x_250, 1); -} -lean_ctor_set(x_250, 0, x_245); -lean_ctor_set(x_250, 1, x_243); -return x_250; +lean_object* x_249; uint8_t x_250; +x_249 = lean_ctor_get(x_243, 2); +x_250 = !lean_is_exclusive(x_249); +if (x_250 == 0) +{ +lean_object* x_251; lean_object* x_252; lean_object* x_253; lean_object* x_307; uint8_t x_308; +x_251 = lean_ctor_get(x_249, 2); +x_307 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_249, 2, x_307); +x_308 = !lean_is_exclusive(x_5); +if (x_308 == 0) +{ +lean_object* x_309; lean_object* x_310; lean_object* x_311; lean_object* x_312; +x_309 = lean_ctor_get(x_5, 2); +x_310 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_310, 0, x_245); +lean_ctor_set(x_310, 1, x_10); +x_311 = lean_array_push(x_309, x_310); +lean_ctor_set(x_5, 2, x_311); +x_312 = l_Lean_Meta_withNewLocalInstances___main___rarg(x_1, x_2, x_247, x_4, x_5, x_243); +if (lean_obj_tag(x_312) == 0) +{ +lean_object* x_313; lean_object* x_314; lean_object* x_315; +x_313 = lean_ctor_get(x_312, 0); +lean_inc(x_313); +x_314 = lean_ctor_get(x_312, 1); +lean_inc(x_314); +lean_dec(x_312); +x_315 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_315, 0, x_313); +x_252 = x_315; +x_253 = x_314; +goto block_306; } else { -lean_object* x_251; lean_object* x_252; lean_object* x_253; lean_object* x_254; lean_object* x_255; -x_251 = lean_ctor_get(x_244, 0); -x_252 = lean_ctor_get(x_244, 1); -x_253 = lean_ctor_get(x_244, 3); -lean_inc(x_253); -lean_inc(x_252); -lean_inc(x_251); -lean_dec(x_244); -x_254 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_254, 0, x_251); -lean_ctor_set(x_254, 1, x_252); -lean_ctor_set(x_254, 2, x_241); -lean_ctor_set(x_254, 3, x_253); -lean_ctor_set(x_243, 2, x_254); -if (lean_is_scalar(x_234)) { - x_255 = lean_alloc_ctor(1, 2, 0); -} else { - x_255 = x_234; - lean_ctor_set_tag(x_255, 1); -} -lean_ctor_set(x_255, 0, x_245); -lean_ctor_set(x_255, 1, x_243); -return x_255; +lean_object* x_316; lean_object* x_317; lean_object* x_318; +x_316 = lean_ctor_get(x_312, 0); +lean_inc(x_316); +x_317 = lean_ctor_get(x_312, 1); +lean_inc(x_317); +lean_dec(x_312); +x_318 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_318, 0, x_316); +x_252 = x_318; +x_253 = x_317; +goto block_306; } } else { -lean_object* x_256; lean_object* x_257; lean_object* x_258; lean_object* x_259; lean_object* x_260; lean_object* x_261; lean_object* x_262; lean_object* x_263; lean_object* x_264; lean_object* x_265; lean_object* x_266; lean_object* x_267; -x_256 = lean_ctor_get(x_243, 0); -x_257 = lean_ctor_get(x_243, 1); -x_258 = lean_ctor_get(x_243, 3); -x_259 = lean_ctor_get(x_243, 4); -x_260 = lean_ctor_get(x_243, 5); -lean_inc(x_260); -lean_inc(x_259); -lean_inc(x_258); -lean_inc(x_257); -lean_inc(x_256); -lean_dec(x_243); -x_261 = lean_ctor_get(x_244, 0); -lean_inc(x_261); -x_262 = lean_ctor_get(x_244, 1); -lean_inc(x_262); -x_263 = lean_ctor_get(x_244, 3); +lean_object* x_319; lean_object* x_320; lean_object* x_321; lean_object* x_322; lean_object* x_323; lean_object* x_324; lean_object* x_325; lean_object* x_326; lean_object* x_327; +x_319 = lean_ctor_get(x_5, 0); +x_320 = lean_ctor_get(x_5, 1); +x_321 = lean_ctor_get(x_5, 2); +x_322 = lean_ctor_get(x_5, 3); +x_323 = lean_ctor_get(x_5, 4); +lean_inc(x_323); +lean_inc(x_322); +lean_inc(x_321); +lean_inc(x_320); +lean_inc(x_319); +lean_dec(x_5); +x_324 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_324, 0, x_245); +lean_ctor_set(x_324, 1, x_10); +x_325 = lean_array_push(x_321, x_324); +x_326 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_326, 0, x_319); +lean_ctor_set(x_326, 1, x_320); +lean_ctor_set(x_326, 2, x_325); +lean_ctor_set(x_326, 3, x_322); +lean_ctor_set(x_326, 4, x_323); +x_327 = l_Lean_Meta_withNewLocalInstances___main___rarg(x_1, x_2, x_247, x_4, x_326, x_243); +if (lean_obj_tag(x_327) == 0) +{ +lean_object* x_328; lean_object* x_329; lean_object* x_330; +x_328 = lean_ctor_get(x_327, 0); +lean_inc(x_328); +x_329 = lean_ctor_get(x_327, 1); +lean_inc(x_329); +lean_dec(x_327); +x_330 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_330, 0, x_328); +x_252 = x_330; +x_253 = x_329; +goto block_306; +} +else +{ +lean_object* x_331; lean_object* x_332; lean_object* x_333; +x_331 = lean_ctor_get(x_327, 0); +lean_inc(x_331); +x_332 = lean_ctor_get(x_327, 1); +lean_inc(x_332); +lean_dec(x_327); +x_333 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_333, 0, x_331); +x_252 = x_333; +x_253 = x_332; +goto block_306; +} +} +block_306: +{ +if (lean_obj_tag(x_252) == 0) +{ +lean_object* x_254; lean_object* x_255; uint8_t x_256; +x_254 = lean_ctor_get(x_253, 2); +lean_inc(x_254); +x_255 = lean_ctor_get(x_252, 0); +lean_inc(x_255); +lean_dec(x_252); +x_256 = !lean_is_exclusive(x_253); +if (x_256 == 0) +{ +lean_object* x_257; uint8_t x_258; +x_257 = lean_ctor_get(x_253, 2); +lean_dec(x_257); +x_258 = !lean_is_exclusive(x_254); +if (x_258 == 0) +{ +lean_object* x_259; lean_object* x_260; +x_259 = lean_ctor_get(x_254, 2); +lean_dec(x_259); +lean_ctor_set(x_254, 2, x_251); +if (lean_is_scalar(x_244)) { + x_260 = lean_alloc_ctor(1, 2, 0); +} else { + x_260 = x_244; + lean_ctor_set_tag(x_260, 1); +} +lean_ctor_set(x_260, 0, x_255); +lean_ctor_set(x_260, 1, x_253); +return x_260; +} +else +{ +lean_object* x_261; lean_object* x_262; lean_object* x_263; lean_object* x_264; lean_object* x_265; lean_object* x_266; +x_261 = lean_ctor_get(x_254, 0); +x_262 = lean_ctor_get(x_254, 1); +x_263 = lean_ctor_get(x_254, 3); +x_264 = lean_ctor_get(x_254, 4); +lean_inc(x_264); lean_inc(x_263); -if (lean_is_exclusive(x_244)) { - lean_ctor_release(x_244, 0); - lean_ctor_release(x_244, 1); - lean_ctor_release(x_244, 2); - lean_ctor_release(x_244, 3); - x_264 = x_244; -} else { - lean_dec_ref(x_244); - x_264 = lean_box(0); -} -if (lean_is_scalar(x_264)) { - x_265 = lean_alloc_ctor(0, 4, 0); -} else { - x_265 = x_264; -} +lean_inc(x_262); +lean_inc(x_261); +lean_dec(x_254); +x_265 = lean_alloc_ctor(0, 5, 0); lean_ctor_set(x_265, 0, x_261); lean_ctor_set(x_265, 1, x_262); -lean_ctor_set(x_265, 2, x_241); +lean_ctor_set(x_265, 2, x_251); lean_ctor_set(x_265, 3, x_263); -x_266 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_266, 0, x_256); -lean_ctor_set(x_266, 1, x_257); -lean_ctor_set(x_266, 2, x_265); -lean_ctor_set(x_266, 3, x_258); -lean_ctor_set(x_266, 4, x_259); -lean_ctor_set(x_266, 5, x_260); -if (lean_is_scalar(x_234)) { - x_267 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_265, 4, x_264); +lean_ctor_set(x_253, 2, x_265); +if (lean_is_scalar(x_244)) { + x_266 = lean_alloc_ctor(1, 2, 0); } else { - x_267 = x_234; - lean_ctor_set_tag(x_267, 1); + x_266 = x_244; + lean_ctor_set_tag(x_266, 1); } -lean_ctor_set(x_267, 0, x_245); -lean_ctor_set(x_267, 1, x_266); -return x_267; +lean_ctor_set(x_266, 0, x_255); +lean_ctor_set(x_266, 1, x_253); +return x_266; } } else { -lean_object* x_268; lean_object* x_269; uint8_t x_270; -x_268 = lean_ctor_get(x_243, 2); -lean_inc(x_268); -x_269 = lean_ctor_get(x_242, 0); +lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_object* x_270; lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_object* x_276; lean_object* x_277; lean_object* x_278; lean_object* x_279; +x_267 = lean_ctor_get(x_253, 0); +x_268 = lean_ctor_get(x_253, 1); +x_269 = lean_ctor_get(x_253, 3); +x_270 = lean_ctor_get(x_253, 4); +x_271 = lean_ctor_get(x_253, 5); +lean_inc(x_271); +lean_inc(x_270); lean_inc(x_269); -lean_dec(x_242); -x_270 = !lean_is_exclusive(x_243); -if (x_270 == 0) -{ -lean_object* x_271; uint8_t x_272; -x_271 = lean_ctor_get(x_243, 2); -lean_dec(x_271); -x_272 = !lean_is_exclusive(x_268); -if (x_272 == 0) -{ -lean_object* x_273; lean_object* x_274; -x_273 = lean_ctor_get(x_268, 2); -lean_dec(x_273); -lean_ctor_set(x_268, 2, x_241); -if (lean_is_scalar(x_234)) { - x_274 = lean_alloc_ctor(0, 2, 0); -} else { - x_274 = x_234; -} -lean_ctor_set(x_274, 0, x_269); -lean_ctor_set(x_274, 1, x_243); -return x_274; -} -else -{ -lean_object* x_275; lean_object* x_276; lean_object* x_277; lean_object* x_278; lean_object* x_279; -x_275 = lean_ctor_get(x_268, 0); -x_276 = lean_ctor_get(x_268, 1); -x_277 = lean_ctor_get(x_268, 3); -lean_inc(x_277); -lean_inc(x_276); +lean_inc(x_268); +lean_inc(x_267); +lean_dec(x_253); +x_272 = lean_ctor_get(x_254, 0); +lean_inc(x_272); +x_273 = lean_ctor_get(x_254, 1); +lean_inc(x_273); +x_274 = lean_ctor_get(x_254, 3); +lean_inc(x_274); +x_275 = lean_ctor_get(x_254, 4); lean_inc(x_275); -lean_dec(x_268); -x_278 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_278, 0, x_275); -lean_ctor_set(x_278, 1, x_276); -lean_ctor_set(x_278, 2, x_241); -lean_ctor_set(x_278, 3, x_277); -lean_ctor_set(x_243, 2, x_278); -if (lean_is_scalar(x_234)) { - x_279 = lean_alloc_ctor(0, 2, 0); +if (lean_is_exclusive(x_254)) { + lean_ctor_release(x_254, 0); + lean_ctor_release(x_254, 1); + lean_ctor_release(x_254, 2); + lean_ctor_release(x_254, 3); + lean_ctor_release(x_254, 4); + x_276 = x_254; } else { - x_279 = x_234; + lean_dec_ref(x_254); + x_276 = lean_box(0); } -lean_ctor_set(x_279, 0, x_269); -lean_ctor_set(x_279, 1, x_243); +if (lean_is_scalar(x_276)) { + x_277 = lean_alloc_ctor(0, 5, 0); +} else { + x_277 = x_276; +} +lean_ctor_set(x_277, 0, x_272); +lean_ctor_set(x_277, 1, x_273); +lean_ctor_set(x_277, 2, x_251); +lean_ctor_set(x_277, 3, x_274); +lean_ctor_set(x_277, 4, x_275); +x_278 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_278, 0, x_267); +lean_ctor_set(x_278, 1, x_268); +lean_ctor_set(x_278, 2, x_277); +lean_ctor_set(x_278, 3, x_269); +lean_ctor_set(x_278, 4, x_270); +lean_ctor_set(x_278, 5, x_271); +if (lean_is_scalar(x_244)) { + x_279 = lean_alloc_ctor(1, 2, 0); +} else { + x_279 = x_244; + lean_ctor_set_tag(x_279, 1); +} +lean_ctor_set(x_279, 0, x_255); +lean_ctor_set(x_279, 1, x_278); return x_279; } } else { -lean_object* x_280; lean_object* x_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; lean_object* x_289; lean_object* x_290; lean_object* x_291; -x_280 = lean_ctor_get(x_243, 0); -x_281 = lean_ctor_get(x_243, 1); -x_282 = lean_ctor_get(x_243, 3); -x_283 = lean_ctor_get(x_243, 4); -x_284 = lean_ctor_get(x_243, 5); -lean_inc(x_284); -lean_inc(x_283); -lean_inc(x_282); -lean_inc(x_281); +lean_object* x_280; lean_object* x_281; uint8_t x_282; +x_280 = lean_ctor_get(x_253, 2); lean_inc(x_280); -lean_dec(x_243); -x_285 = lean_ctor_get(x_268, 0); -lean_inc(x_285); -x_286 = lean_ctor_get(x_268, 1); -lean_inc(x_286); -x_287 = lean_ctor_get(x_268, 3); +x_281 = lean_ctor_get(x_252, 0); +lean_inc(x_281); +lean_dec(x_252); +x_282 = !lean_is_exclusive(x_253); +if (x_282 == 0) +{ +lean_object* x_283; uint8_t x_284; +x_283 = lean_ctor_get(x_253, 2); +lean_dec(x_283); +x_284 = !lean_is_exclusive(x_280); +if (x_284 == 0) +{ +lean_object* x_285; lean_object* x_286; +x_285 = lean_ctor_get(x_280, 2); +lean_dec(x_285); +lean_ctor_set(x_280, 2, x_251); +if (lean_is_scalar(x_244)) { + x_286 = lean_alloc_ctor(0, 2, 0); +} else { + x_286 = x_244; +} +lean_ctor_set(x_286, 0, x_281); +lean_ctor_set(x_286, 1, x_253); +return x_286; +} +else +{ +lean_object* x_287; lean_object* x_288; lean_object* x_289; lean_object* x_290; lean_object* x_291; lean_object* x_292; +x_287 = lean_ctor_get(x_280, 0); +x_288 = lean_ctor_get(x_280, 1); +x_289 = lean_ctor_get(x_280, 3); +x_290 = lean_ctor_get(x_280, 4); +lean_inc(x_290); +lean_inc(x_289); +lean_inc(x_288); lean_inc(x_287); -if (lean_is_exclusive(x_268)) { - lean_ctor_release(x_268, 0); - lean_ctor_release(x_268, 1); - lean_ctor_release(x_268, 2); - lean_ctor_release(x_268, 3); - x_288 = x_268; +lean_dec(x_280); +x_291 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_291, 0, x_287); +lean_ctor_set(x_291, 1, x_288); +lean_ctor_set(x_291, 2, x_251); +lean_ctor_set(x_291, 3, x_289); +lean_ctor_set(x_291, 4, x_290); +lean_ctor_set(x_253, 2, x_291); +if (lean_is_scalar(x_244)) { + x_292 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_268); - x_288 = lean_box(0); + x_292 = x_244; } -if (lean_is_scalar(x_288)) { - x_289 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_292, 0, x_281); +lean_ctor_set(x_292, 1, x_253); +return x_292; +} +} +else +{ +lean_object* x_293; lean_object* x_294; lean_object* x_295; lean_object* x_296; lean_object* x_297; lean_object* x_298; lean_object* x_299; lean_object* x_300; lean_object* x_301; lean_object* x_302; lean_object* x_303; lean_object* x_304; lean_object* x_305; +x_293 = lean_ctor_get(x_253, 0); +x_294 = lean_ctor_get(x_253, 1); +x_295 = lean_ctor_get(x_253, 3); +x_296 = lean_ctor_get(x_253, 4); +x_297 = lean_ctor_get(x_253, 5); +lean_inc(x_297); +lean_inc(x_296); +lean_inc(x_295); +lean_inc(x_294); +lean_inc(x_293); +lean_dec(x_253); +x_298 = lean_ctor_get(x_280, 0); +lean_inc(x_298); +x_299 = lean_ctor_get(x_280, 1); +lean_inc(x_299); +x_300 = lean_ctor_get(x_280, 3); +lean_inc(x_300); +x_301 = lean_ctor_get(x_280, 4); +lean_inc(x_301); +if (lean_is_exclusive(x_280)) { + lean_ctor_release(x_280, 0); + lean_ctor_release(x_280, 1); + lean_ctor_release(x_280, 2); + lean_ctor_release(x_280, 3); + lean_ctor_release(x_280, 4); + x_302 = x_280; } else { - x_289 = x_288; + lean_dec_ref(x_280); + x_302 = lean_box(0); } -lean_ctor_set(x_289, 0, x_285); -lean_ctor_set(x_289, 1, x_286); -lean_ctor_set(x_289, 2, x_241); -lean_ctor_set(x_289, 3, x_287); -x_290 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_290, 0, x_280); -lean_ctor_set(x_290, 1, x_281); -lean_ctor_set(x_290, 2, x_289); -lean_ctor_set(x_290, 3, x_282); -lean_ctor_set(x_290, 4, x_283); -lean_ctor_set(x_290, 5, x_284); -if (lean_is_scalar(x_234)) { - x_291 = lean_alloc_ctor(0, 2, 0); +if (lean_is_scalar(x_302)) { + x_303 = lean_alloc_ctor(0, 5, 0); } else { - x_291 = x_234; + x_303 = x_302; } -lean_ctor_set(x_291, 0, x_269); -lean_ctor_set(x_291, 1, x_290); -return x_291; +lean_ctor_set(x_303, 0, x_298); +lean_ctor_set(x_303, 1, x_299); +lean_ctor_set(x_303, 2, x_251); +lean_ctor_set(x_303, 3, x_300); +lean_ctor_set(x_303, 4, x_301); +x_304 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_304, 0, x_293); +lean_ctor_set(x_304, 1, x_294); +lean_ctor_set(x_304, 2, x_303); +lean_ctor_set(x_304, 3, x_295); +lean_ctor_set(x_304, 4, x_296); +lean_ctor_set(x_304, 5, x_297); +if (lean_is_scalar(x_244)) { + x_305 = lean_alloc_ctor(0, 2, 0); +} else { + x_305 = x_244; +} +lean_ctor_set(x_305, 0, x_281); +lean_ctor_set(x_305, 1, x_304); +return x_305; } } } } else { -lean_object* x_320; lean_object* x_321; lean_object* x_322; lean_object* x_323; lean_object* x_324; lean_object* x_325; lean_object* x_357; 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; -x_320 = lean_ctor_get(x_239, 0); -x_321 = lean_ctor_get(x_239, 1); -x_322 = lean_ctor_get(x_239, 2); -x_323 = lean_ctor_get(x_239, 3); -lean_inc(x_323); -lean_inc(x_322); -lean_inc(x_321); -lean_inc(x_320); -lean_dec(x_239); -x_357 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_358 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_358, 0, x_320); -lean_ctor_set(x_358, 1, x_321); -lean_ctor_set(x_358, 2, x_357); -lean_ctor_set(x_358, 3, x_323); -lean_ctor_set(x_233, 2, x_358); -x_359 = lean_ctor_get(x_5, 0); -lean_inc(x_359); -x_360 = lean_ctor_get(x_5, 1); -lean_inc(x_360); -x_361 = lean_ctor_get(x_5, 2); -lean_inc(x_361); -x_362 = lean_ctor_get(x_5, 3); -lean_inc(x_362); -x_363 = lean_ctor_get(x_5, 4); -lean_inc(x_363); +lean_object* x_334; lean_object* x_335; lean_object* x_336; lean_object* x_337; lean_object* x_338; lean_object* x_339; lean_object* x_340; lean_object* x_374; lean_object* x_375; 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; +x_334 = lean_ctor_get(x_249, 0); +x_335 = lean_ctor_get(x_249, 1); +x_336 = lean_ctor_get(x_249, 2); +x_337 = lean_ctor_get(x_249, 3); +x_338 = lean_ctor_get(x_249, 4); +lean_inc(x_338); +lean_inc(x_337); +lean_inc(x_336); +lean_inc(x_335); +lean_inc(x_334); +lean_dec(x_249); +x_374 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_375 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_375, 0, x_334); +lean_ctor_set(x_375, 1, x_335); +lean_ctor_set(x_375, 2, x_374); +lean_ctor_set(x_375, 3, x_337); +lean_ctor_set(x_375, 4, x_338); +lean_ctor_set(x_243, 2, x_375); +x_376 = lean_ctor_get(x_5, 0); +lean_inc(x_376); +x_377 = lean_ctor_get(x_5, 1); +lean_inc(x_377); +x_378 = lean_ctor_get(x_5, 2); +lean_inc(x_378); +x_379 = lean_ctor_get(x_5, 3); +lean_inc(x_379); +x_380 = lean_ctor_get(x_5, 4); +lean_inc(x_380); if (lean_is_exclusive(x_5)) { lean_ctor_release(x_5, 0); lean_ctor_release(x_5, 1); lean_ctor_release(x_5, 2); lean_ctor_release(x_5, 3); lean_ctor_release(x_5, 4); - x_364 = x_5; + x_381 = x_5; } else { lean_dec_ref(x_5); - x_364 = lean_box(0); + x_381 = lean_box(0); } -x_365 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_365, 0, x_235); -lean_ctor_set(x_365, 1, x_10); -x_366 = lean_array_push(x_361, x_365); -if (lean_is_scalar(x_364)) { - x_367 = lean_alloc_ctor(0, 5, 0); +x_382 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_382, 0, x_245); +lean_ctor_set(x_382, 1, x_10); +x_383 = lean_array_push(x_378, x_382); +if (lean_is_scalar(x_381)) { + x_384 = lean_alloc_ctor(0, 5, 0); } else { - x_367 = x_364; + x_384 = x_381; } -lean_ctor_set(x_367, 0, x_359); -lean_ctor_set(x_367, 1, x_360); -lean_ctor_set(x_367, 2, x_366); -lean_ctor_set(x_367, 3, x_362); -lean_ctor_set(x_367, 4, x_363); -x_368 = l_Lean_Meta_withNewLocalInstances___main___rarg(x_1, x_2, x_237, x_4, x_367, x_233); -if (lean_obj_tag(x_368) == 0) +lean_ctor_set(x_384, 0, x_376); +lean_ctor_set(x_384, 1, x_377); +lean_ctor_set(x_384, 2, x_383); +lean_ctor_set(x_384, 3, x_379); +lean_ctor_set(x_384, 4, x_380); +x_385 = l_Lean_Meta_withNewLocalInstances___main___rarg(x_1, x_2, x_247, x_4, x_384, x_243); +if (lean_obj_tag(x_385) == 0) { -lean_object* x_369; lean_object* x_370; lean_object* x_371; -x_369 = lean_ctor_get(x_368, 0); -lean_inc(x_369); -x_370 = lean_ctor_get(x_368, 1); -lean_inc(x_370); -lean_dec(x_368); -x_371 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_371, 0, x_369); -x_324 = x_371; -x_325 = x_370; -goto block_356; +lean_object* x_386; lean_object* x_387; lean_object* x_388; +x_386 = lean_ctor_get(x_385, 0); +lean_inc(x_386); +x_387 = lean_ctor_get(x_385, 1); +lean_inc(x_387); +lean_dec(x_385); +x_388 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_388, 0, x_386); +x_339 = x_388; +x_340 = x_387; +goto block_373; } else { -lean_object* x_372; lean_object* x_373; lean_object* x_374; -x_372 = lean_ctor_get(x_368, 0); -lean_inc(x_372); -x_373 = lean_ctor_get(x_368, 1); -lean_inc(x_373); -lean_dec(x_368); -x_374 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_374, 0, x_372); -x_324 = x_374; -x_325 = x_373; -goto block_356; +lean_object* x_389; lean_object* x_390; lean_object* x_391; +x_389 = lean_ctor_get(x_385, 0); +lean_inc(x_389); +x_390 = lean_ctor_get(x_385, 1); +lean_inc(x_390); +lean_dec(x_385); +x_391 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_391, 0, x_389); +x_339 = x_391; +x_340 = x_390; +goto block_373; } -block_356: +block_373: { -if (lean_obj_tag(x_324) == 0) +if (lean_obj_tag(x_339) == 0) { -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; lean_object* x_339; lean_object* x_340; -x_326 = lean_ctor_get(x_325, 2); -lean_inc(x_326); -x_327 = lean_ctor_get(x_324, 0); -lean_inc(x_327); -lean_dec(x_324); -x_328 = lean_ctor_get(x_325, 0); -lean_inc(x_328); -x_329 = lean_ctor_get(x_325, 1); -lean_inc(x_329); -x_330 = lean_ctor_get(x_325, 3); -lean_inc(x_330); -x_331 = lean_ctor_get(x_325, 4); -lean_inc(x_331); -x_332 = lean_ctor_get(x_325, 5); -lean_inc(x_332); -if (lean_is_exclusive(x_325)) { - lean_ctor_release(x_325, 0); - lean_ctor_release(x_325, 1); - lean_ctor_release(x_325, 2); - lean_ctor_release(x_325, 3); - lean_ctor_release(x_325, 4); - lean_ctor_release(x_325, 5); - x_333 = x_325; -} else { - lean_dec_ref(x_325); - x_333 = lean_box(0); -} -x_334 = lean_ctor_get(x_326, 0); -lean_inc(x_334); -x_335 = lean_ctor_get(x_326, 1); -lean_inc(x_335); -x_336 = lean_ctor_get(x_326, 3); -lean_inc(x_336); -if (lean_is_exclusive(x_326)) { - lean_ctor_release(x_326, 0); - lean_ctor_release(x_326, 1); - lean_ctor_release(x_326, 2); - lean_ctor_release(x_326, 3); - x_337 = x_326; -} else { - lean_dec_ref(x_326); - x_337 = lean_box(0); -} -if (lean_is_scalar(x_337)) { - x_338 = lean_alloc_ctor(0, 4, 0); -} else { - x_338 = x_337; -} -lean_ctor_set(x_338, 0, x_334); -lean_ctor_set(x_338, 1, x_335); -lean_ctor_set(x_338, 2, x_322); -lean_ctor_set(x_338, 3, x_336); -if (lean_is_scalar(x_333)) { - x_339 = lean_alloc_ctor(0, 6, 0); -} else { - x_339 = x_333; -} -lean_ctor_set(x_339, 0, x_328); -lean_ctor_set(x_339, 1, x_329); -lean_ctor_set(x_339, 2, x_338); -lean_ctor_set(x_339, 3, x_330); -lean_ctor_set(x_339, 4, x_331); -lean_ctor_set(x_339, 5, x_332); -if (lean_is_scalar(x_234)) { - x_340 = lean_alloc_ctor(1, 2, 0); -} else { - x_340 = x_234; - lean_ctor_set_tag(x_340, 1); -} -lean_ctor_set(x_340, 0, x_327); -lean_ctor_set(x_340, 1, x_339); -return x_340; -} -else -{ -lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; lean_object* x_350; lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; -x_341 = lean_ctor_get(x_325, 2); +lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; lean_object* x_350; lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; +x_341 = lean_ctor_get(x_340, 2); lean_inc(x_341); -x_342 = lean_ctor_get(x_324, 0); +x_342 = lean_ctor_get(x_339, 0); lean_inc(x_342); -lean_dec(x_324); -x_343 = lean_ctor_get(x_325, 0); +lean_dec(x_339); +x_343 = lean_ctor_get(x_340, 0); lean_inc(x_343); -x_344 = lean_ctor_get(x_325, 1); +x_344 = lean_ctor_get(x_340, 1); lean_inc(x_344); -x_345 = lean_ctor_get(x_325, 3); +x_345 = lean_ctor_get(x_340, 3); lean_inc(x_345); -x_346 = lean_ctor_get(x_325, 4); +x_346 = lean_ctor_get(x_340, 4); lean_inc(x_346); -x_347 = lean_ctor_get(x_325, 5); +x_347 = lean_ctor_get(x_340, 5); lean_inc(x_347); -if (lean_is_exclusive(x_325)) { - lean_ctor_release(x_325, 0); - lean_ctor_release(x_325, 1); - lean_ctor_release(x_325, 2); - lean_ctor_release(x_325, 3); - lean_ctor_release(x_325, 4); - lean_ctor_release(x_325, 5); - x_348 = x_325; +if (lean_is_exclusive(x_340)) { + lean_ctor_release(x_340, 0); + lean_ctor_release(x_340, 1); + lean_ctor_release(x_340, 2); + lean_ctor_release(x_340, 3); + lean_ctor_release(x_340, 4); + lean_ctor_release(x_340, 5); + x_348 = x_340; } else { - lean_dec_ref(x_325); + lean_dec_ref(x_340); x_348 = lean_box(0); } x_349 = lean_ctor_get(x_341, 0); @@ -9957,315 +10115,411 @@ x_350 = lean_ctor_get(x_341, 1); lean_inc(x_350); x_351 = lean_ctor_get(x_341, 3); lean_inc(x_351); +x_352 = lean_ctor_get(x_341, 4); +lean_inc(x_352); if (lean_is_exclusive(x_341)) { lean_ctor_release(x_341, 0); lean_ctor_release(x_341, 1); lean_ctor_release(x_341, 2); lean_ctor_release(x_341, 3); - x_352 = x_341; + lean_ctor_release(x_341, 4); + x_353 = x_341; } else { lean_dec_ref(x_341); - x_352 = lean_box(0); + x_353 = lean_box(0); } -if (lean_is_scalar(x_352)) { - x_353 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_353)) { + x_354 = lean_alloc_ctor(0, 5, 0); } else { - x_353 = x_352; + x_354 = x_353; } -lean_ctor_set(x_353, 0, x_349); -lean_ctor_set(x_353, 1, x_350); -lean_ctor_set(x_353, 2, x_322); -lean_ctor_set(x_353, 3, x_351); +lean_ctor_set(x_354, 0, x_349); +lean_ctor_set(x_354, 1, x_350); +lean_ctor_set(x_354, 2, x_336); +lean_ctor_set(x_354, 3, x_351); +lean_ctor_set(x_354, 4, x_352); if (lean_is_scalar(x_348)) { - x_354 = lean_alloc_ctor(0, 6, 0); + x_355 = lean_alloc_ctor(0, 6, 0); } else { - x_354 = x_348; + x_355 = x_348; } -lean_ctor_set(x_354, 0, x_343); -lean_ctor_set(x_354, 1, x_344); -lean_ctor_set(x_354, 2, x_353); -lean_ctor_set(x_354, 3, x_345); -lean_ctor_set(x_354, 4, x_346); -lean_ctor_set(x_354, 5, x_347); -if (lean_is_scalar(x_234)) { - x_355 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_355, 0, x_343); +lean_ctor_set(x_355, 1, x_344); +lean_ctor_set(x_355, 2, x_354); +lean_ctor_set(x_355, 3, x_345); +lean_ctor_set(x_355, 4, x_346); +lean_ctor_set(x_355, 5, x_347); +if (lean_is_scalar(x_244)) { + x_356 = lean_alloc_ctor(1, 2, 0); } else { - x_355 = x_234; + x_356 = x_244; + lean_ctor_set_tag(x_356, 1); } -lean_ctor_set(x_355, 0, x_342); -lean_ctor_set(x_355, 1, x_354); -return x_355; +lean_ctor_set(x_356, 0, x_342); +lean_ctor_set(x_356, 1, x_355); +return x_356; +} +else +{ +lean_object* x_357; lean_object* x_358; lean_object* x_359; lean_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; +x_357 = lean_ctor_get(x_340, 2); +lean_inc(x_357); +x_358 = lean_ctor_get(x_339, 0); +lean_inc(x_358); +lean_dec(x_339); +x_359 = lean_ctor_get(x_340, 0); +lean_inc(x_359); +x_360 = lean_ctor_get(x_340, 1); +lean_inc(x_360); +x_361 = lean_ctor_get(x_340, 3); +lean_inc(x_361); +x_362 = lean_ctor_get(x_340, 4); +lean_inc(x_362); +x_363 = lean_ctor_get(x_340, 5); +lean_inc(x_363); +if (lean_is_exclusive(x_340)) { + lean_ctor_release(x_340, 0); + lean_ctor_release(x_340, 1); + lean_ctor_release(x_340, 2); + lean_ctor_release(x_340, 3); + lean_ctor_release(x_340, 4); + lean_ctor_release(x_340, 5); + x_364 = x_340; +} else { + lean_dec_ref(x_340); + x_364 = lean_box(0); +} +x_365 = lean_ctor_get(x_357, 0); +lean_inc(x_365); +x_366 = lean_ctor_get(x_357, 1); +lean_inc(x_366); +x_367 = lean_ctor_get(x_357, 3); +lean_inc(x_367); +x_368 = lean_ctor_get(x_357, 4); +lean_inc(x_368); +if (lean_is_exclusive(x_357)) { + lean_ctor_release(x_357, 0); + lean_ctor_release(x_357, 1); + lean_ctor_release(x_357, 2); + lean_ctor_release(x_357, 3); + lean_ctor_release(x_357, 4); + x_369 = x_357; +} else { + lean_dec_ref(x_357); + x_369 = lean_box(0); +} +if (lean_is_scalar(x_369)) { + x_370 = lean_alloc_ctor(0, 5, 0); +} else { + x_370 = x_369; +} +lean_ctor_set(x_370, 0, x_365); +lean_ctor_set(x_370, 1, x_366); +lean_ctor_set(x_370, 2, x_336); +lean_ctor_set(x_370, 3, x_367); +lean_ctor_set(x_370, 4, x_368); +if (lean_is_scalar(x_364)) { + x_371 = lean_alloc_ctor(0, 6, 0); +} else { + x_371 = x_364; +} +lean_ctor_set(x_371, 0, x_359); +lean_ctor_set(x_371, 1, x_360); +lean_ctor_set(x_371, 2, x_370); +lean_ctor_set(x_371, 3, x_361); +lean_ctor_set(x_371, 4, x_362); +lean_ctor_set(x_371, 5, x_363); +if (lean_is_scalar(x_244)) { + x_372 = lean_alloc_ctor(0, 2, 0); +} else { + x_372 = x_244; +} +lean_ctor_set(x_372, 0, x_358); +lean_ctor_set(x_372, 1, x_371); +return x_372; } } } } else { -lean_object* x_375; 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_419; lean_object* x_420; lean_object* x_421; lean_object* x_422; lean_object* x_423; lean_object* x_424; lean_object* x_425; lean_object* x_426; lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; -x_375 = lean_ctor_get(x_233, 2); -x_376 = lean_ctor_get(x_233, 0); -x_377 = lean_ctor_get(x_233, 1); -x_378 = lean_ctor_get(x_233, 3); -x_379 = lean_ctor_get(x_233, 4); -x_380 = lean_ctor_get(x_233, 5); -lean_inc(x_380); -lean_inc(x_379); -lean_inc(x_378); -lean_inc(x_375); -lean_inc(x_377); -lean_inc(x_376); -lean_dec(x_233); -x_381 = lean_ctor_get(x_375, 0); -lean_inc(x_381); -x_382 = lean_ctor_get(x_375, 1); -lean_inc(x_382); -x_383 = lean_ctor_get(x_375, 2); -lean_inc(x_383); -x_384 = lean_ctor_get(x_375, 3); -lean_inc(x_384); -if (lean_is_exclusive(x_375)) { - lean_ctor_release(x_375, 0); - lean_ctor_release(x_375, 1); - lean_ctor_release(x_375, 2); - lean_ctor_release(x_375, 3); - x_385 = x_375; +lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; lean_object* x_400; lean_object* x_401; lean_object* x_402; lean_object* x_403; lean_object* x_404; lean_object* x_405; lean_object* x_439; lean_object* x_440; lean_object* x_441; lean_object* x_442; lean_object* x_443; lean_object* x_444; lean_object* x_445; lean_object* x_446; lean_object* x_447; lean_object* x_448; lean_object* x_449; lean_object* x_450; lean_object* x_451; +x_392 = lean_ctor_get(x_243, 2); +x_393 = lean_ctor_get(x_243, 0); +x_394 = lean_ctor_get(x_243, 1); +x_395 = lean_ctor_get(x_243, 3); +x_396 = lean_ctor_get(x_243, 4); +x_397 = lean_ctor_get(x_243, 5); +lean_inc(x_397); +lean_inc(x_396); +lean_inc(x_395); +lean_inc(x_392); +lean_inc(x_394); +lean_inc(x_393); +lean_dec(x_243); +x_398 = lean_ctor_get(x_392, 0); +lean_inc(x_398); +x_399 = lean_ctor_get(x_392, 1); +lean_inc(x_399); +x_400 = lean_ctor_get(x_392, 2); +lean_inc(x_400); +x_401 = lean_ctor_get(x_392, 3); +lean_inc(x_401); +x_402 = lean_ctor_get(x_392, 4); +lean_inc(x_402); +if (lean_is_exclusive(x_392)) { + lean_ctor_release(x_392, 0); + lean_ctor_release(x_392, 1); + lean_ctor_release(x_392, 2); + lean_ctor_release(x_392, 3); + lean_ctor_release(x_392, 4); + x_403 = x_392; } else { - lean_dec_ref(x_375); - x_385 = lean_box(0); + lean_dec_ref(x_392); + x_403 = lean_box(0); } -x_419 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_385)) { - x_420 = lean_alloc_ctor(0, 4, 0); +x_439 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_403)) { + x_440 = lean_alloc_ctor(0, 5, 0); } else { - x_420 = x_385; + x_440 = x_403; } -lean_ctor_set(x_420, 0, x_381); -lean_ctor_set(x_420, 1, x_382); -lean_ctor_set(x_420, 2, x_419); -lean_ctor_set(x_420, 3, x_384); -x_421 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_421, 0, x_376); -lean_ctor_set(x_421, 1, x_377); -lean_ctor_set(x_421, 2, x_420); -lean_ctor_set(x_421, 3, x_378); -lean_ctor_set(x_421, 4, x_379); -lean_ctor_set(x_421, 5, x_380); -x_422 = lean_ctor_get(x_5, 0); -lean_inc(x_422); -x_423 = lean_ctor_get(x_5, 1); -lean_inc(x_423); -x_424 = lean_ctor_get(x_5, 2); -lean_inc(x_424); -x_425 = lean_ctor_get(x_5, 3); -lean_inc(x_425); -x_426 = lean_ctor_get(x_5, 4); -lean_inc(x_426); +lean_ctor_set(x_440, 0, x_398); +lean_ctor_set(x_440, 1, x_399); +lean_ctor_set(x_440, 2, x_439); +lean_ctor_set(x_440, 3, x_401); +lean_ctor_set(x_440, 4, x_402); +x_441 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_441, 0, x_393); +lean_ctor_set(x_441, 1, x_394); +lean_ctor_set(x_441, 2, x_440); +lean_ctor_set(x_441, 3, x_395); +lean_ctor_set(x_441, 4, x_396); +lean_ctor_set(x_441, 5, x_397); +x_442 = lean_ctor_get(x_5, 0); +lean_inc(x_442); +x_443 = lean_ctor_get(x_5, 1); +lean_inc(x_443); +x_444 = lean_ctor_get(x_5, 2); +lean_inc(x_444); +x_445 = lean_ctor_get(x_5, 3); +lean_inc(x_445); +x_446 = lean_ctor_get(x_5, 4); +lean_inc(x_446); if (lean_is_exclusive(x_5)) { lean_ctor_release(x_5, 0); lean_ctor_release(x_5, 1); lean_ctor_release(x_5, 2); lean_ctor_release(x_5, 3); lean_ctor_release(x_5, 4); - x_427 = x_5; + x_447 = x_5; } else { lean_dec_ref(x_5); - x_427 = lean_box(0); + x_447 = lean_box(0); } -x_428 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_428, 0, x_235); -lean_ctor_set(x_428, 1, x_10); -x_429 = lean_array_push(x_424, x_428); -if (lean_is_scalar(x_427)) { - x_430 = lean_alloc_ctor(0, 5, 0); +x_448 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_448, 0, x_245); +lean_ctor_set(x_448, 1, x_10); +x_449 = lean_array_push(x_444, x_448); +if (lean_is_scalar(x_447)) { + x_450 = lean_alloc_ctor(0, 5, 0); } else { - x_430 = x_427; + x_450 = x_447; } -lean_ctor_set(x_430, 0, x_422); -lean_ctor_set(x_430, 1, x_423); -lean_ctor_set(x_430, 2, x_429); -lean_ctor_set(x_430, 3, x_425); -lean_ctor_set(x_430, 4, x_426); -x_431 = l_Lean_Meta_withNewLocalInstances___main___rarg(x_1, x_2, x_237, x_4, x_430, x_421); -if (lean_obj_tag(x_431) == 0) +lean_ctor_set(x_450, 0, x_442); +lean_ctor_set(x_450, 1, x_443); +lean_ctor_set(x_450, 2, x_449); +lean_ctor_set(x_450, 3, x_445); +lean_ctor_set(x_450, 4, x_446); +x_451 = l_Lean_Meta_withNewLocalInstances___main___rarg(x_1, x_2, x_247, x_4, x_450, x_441); +if (lean_obj_tag(x_451) == 0) { -lean_object* x_432; lean_object* x_433; lean_object* x_434; -x_432 = lean_ctor_get(x_431, 0); -lean_inc(x_432); -x_433 = lean_ctor_get(x_431, 1); -lean_inc(x_433); -lean_dec(x_431); -x_434 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_434, 0, x_432); -x_386 = x_434; -x_387 = x_433; -goto block_418; +lean_object* x_452; lean_object* x_453; lean_object* x_454; +x_452 = lean_ctor_get(x_451, 0); +lean_inc(x_452); +x_453 = lean_ctor_get(x_451, 1); +lean_inc(x_453); +lean_dec(x_451); +x_454 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_454, 0, x_452); +x_404 = x_454; +x_405 = x_453; +goto block_438; } else { -lean_object* x_435; lean_object* x_436; lean_object* x_437; -x_435 = lean_ctor_get(x_431, 0); -lean_inc(x_435); -x_436 = lean_ctor_get(x_431, 1); -lean_inc(x_436); -lean_dec(x_431); -x_437 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_437, 0, x_435); -x_386 = x_437; -x_387 = x_436; -goto block_418; +lean_object* x_455; lean_object* x_456; lean_object* x_457; +x_455 = lean_ctor_get(x_451, 0); +lean_inc(x_455); +x_456 = lean_ctor_get(x_451, 1); +lean_inc(x_456); +lean_dec(x_451); +x_457 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_457, 0, x_455); +x_404 = x_457; +x_405 = x_456; +goto block_438; } -block_418: +block_438: { -if (lean_obj_tag(x_386) == 0) +if (lean_obj_tag(x_404) == 0) { -lean_object* x_388; lean_object* x_389; lean_object* x_390; lean_object* x_391; lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; lean_object* x_400; lean_object* x_401; lean_object* x_402; -x_388 = lean_ctor_get(x_387, 2); -lean_inc(x_388); -x_389 = lean_ctor_get(x_386, 0); -lean_inc(x_389); -lean_dec(x_386); -x_390 = lean_ctor_get(x_387, 0); -lean_inc(x_390); -x_391 = lean_ctor_get(x_387, 1); -lean_inc(x_391); -x_392 = lean_ctor_get(x_387, 3); -lean_inc(x_392); -x_393 = lean_ctor_get(x_387, 4); -lean_inc(x_393); -x_394 = lean_ctor_get(x_387, 5); -lean_inc(x_394); -if (lean_is_exclusive(x_387)) { - lean_ctor_release(x_387, 0); - lean_ctor_release(x_387, 1); - lean_ctor_release(x_387, 2); - lean_ctor_release(x_387, 3); - lean_ctor_release(x_387, 4); - lean_ctor_release(x_387, 5); - x_395 = x_387; -} else { - lean_dec_ref(x_387); - x_395 = lean_box(0); -} -x_396 = lean_ctor_get(x_388, 0); -lean_inc(x_396); -x_397 = lean_ctor_get(x_388, 1); -lean_inc(x_397); -x_398 = lean_ctor_get(x_388, 3); -lean_inc(x_398); -if (lean_is_exclusive(x_388)) { - lean_ctor_release(x_388, 0); - lean_ctor_release(x_388, 1); - lean_ctor_release(x_388, 2); - lean_ctor_release(x_388, 3); - x_399 = x_388; -} else { - lean_dec_ref(x_388); - x_399 = lean_box(0); -} -if (lean_is_scalar(x_399)) { - x_400 = lean_alloc_ctor(0, 4, 0); -} else { - x_400 = x_399; -} -lean_ctor_set(x_400, 0, x_396); -lean_ctor_set(x_400, 1, x_397); -lean_ctor_set(x_400, 2, x_383); -lean_ctor_set(x_400, 3, x_398); -if (lean_is_scalar(x_395)) { - x_401 = lean_alloc_ctor(0, 6, 0); -} else { - x_401 = x_395; -} -lean_ctor_set(x_401, 0, x_390); -lean_ctor_set(x_401, 1, x_391); -lean_ctor_set(x_401, 2, x_400); -lean_ctor_set(x_401, 3, x_392); -lean_ctor_set(x_401, 4, x_393); -lean_ctor_set(x_401, 5, x_394); -if (lean_is_scalar(x_234)) { - x_402 = lean_alloc_ctor(1, 2, 0); -} else { - x_402 = x_234; - lean_ctor_set_tag(x_402, 1); -} -lean_ctor_set(x_402, 0, x_389); -lean_ctor_set(x_402, 1, x_401); -return x_402; -} -else -{ -lean_object* x_403; lean_object* x_404; lean_object* x_405; lean_object* x_406; lean_object* x_407; lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_object* x_412; lean_object* x_413; lean_object* x_414; lean_object* x_415; lean_object* x_416; lean_object* x_417; -x_403 = lean_ctor_get(x_387, 2); -lean_inc(x_403); -x_404 = lean_ctor_get(x_386, 0); -lean_inc(x_404); -lean_dec(x_386); -x_405 = lean_ctor_get(x_387, 0); -lean_inc(x_405); -x_406 = lean_ctor_get(x_387, 1); +lean_object* x_406; lean_object* x_407; lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_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; +x_406 = lean_ctor_get(x_405, 2); lean_inc(x_406); -x_407 = lean_ctor_get(x_387, 3); +x_407 = lean_ctor_get(x_404, 0); lean_inc(x_407); -x_408 = lean_ctor_get(x_387, 4); +lean_dec(x_404); +x_408 = lean_ctor_get(x_405, 0); lean_inc(x_408); -x_409 = lean_ctor_get(x_387, 5); +x_409 = lean_ctor_get(x_405, 1); lean_inc(x_409); -if (lean_is_exclusive(x_387)) { - lean_ctor_release(x_387, 0); - lean_ctor_release(x_387, 1); - lean_ctor_release(x_387, 2); - lean_ctor_release(x_387, 3); - lean_ctor_release(x_387, 4); - lean_ctor_release(x_387, 5); - x_410 = x_387; -} else { - lean_dec_ref(x_387); - x_410 = lean_box(0); -} -x_411 = lean_ctor_get(x_403, 0); +x_410 = lean_ctor_get(x_405, 3); +lean_inc(x_410); +x_411 = lean_ctor_get(x_405, 4); lean_inc(x_411); -x_412 = lean_ctor_get(x_403, 1); +x_412 = lean_ctor_get(x_405, 5); lean_inc(x_412); -x_413 = lean_ctor_get(x_403, 3); -lean_inc(x_413); -if (lean_is_exclusive(x_403)) { - lean_ctor_release(x_403, 0); - lean_ctor_release(x_403, 1); - lean_ctor_release(x_403, 2); - lean_ctor_release(x_403, 3); - x_414 = x_403; +if (lean_is_exclusive(x_405)) { + lean_ctor_release(x_405, 0); + lean_ctor_release(x_405, 1); + lean_ctor_release(x_405, 2); + lean_ctor_release(x_405, 3); + lean_ctor_release(x_405, 4); + lean_ctor_release(x_405, 5); + x_413 = x_405; } else { - lean_dec_ref(x_403); - x_414 = lean_box(0); + lean_dec_ref(x_405); + x_413 = lean_box(0); } -if (lean_is_scalar(x_414)) { - x_415 = lean_alloc_ctor(0, 4, 0); +x_414 = lean_ctor_get(x_406, 0); +lean_inc(x_414); +x_415 = lean_ctor_get(x_406, 1); +lean_inc(x_415); +x_416 = lean_ctor_get(x_406, 3); +lean_inc(x_416); +x_417 = lean_ctor_get(x_406, 4); +lean_inc(x_417); +if (lean_is_exclusive(x_406)) { + lean_ctor_release(x_406, 0); + lean_ctor_release(x_406, 1); + lean_ctor_release(x_406, 2); + lean_ctor_release(x_406, 3); + lean_ctor_release(x_406, 4); + x_418 = x_406; } else { - x_415 = x_414; + lean_dec_ref(x_406); + x_418 = lean_box(0); } -lean_ctor_set(x_415, 0, x_411); -lean_ctor_set(x_415, 1, x_412); -lean_ctor_set(x_415, 2, x_383); -lean_ctor_set(x_415, 3, x_413); -if (lean_is_scalar(x_410)) { - x_416 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_418)) { + x_419 = lean_alloc_ctor(0, 5, 0); } else { - x_416 = x_410; + x_419 = x_418; } -lean_ctor_set(x_416, 0, x_405); -lean_ctor_set(x_416, 1, x_406); -lean_ctor_set(x_416, 2, x_415); -lean_ctor_set(x_416, 3, x_407); -lean_ctor_set(x_416, 4, x_408); -lean_ctor_set(x_416, 5, x_409); -if (lean_is_scalar(x_234)) { - x_417 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_419, 0, x_414); +lean_ctor_set(x_419, 1, x_415); +lean_ctor_set(x_419, 2, x_400); +lean_ctor_set(x_419, 3, x_416); +lean_ctor_set(x_419, 4, x_417); +if (lean_is_scalar(x_413)) { + x_420 = lean_alloc_ctor(0, 6, 0); } else { - x_417 = x_234; + x_420 = x_413; } -lean_ctor_set(x_417, 0, x_404); -lean_ctor_set(x_417, 1, x_416); -return x_417; +lean_ctor_set(x_420, 0, x_408); +lean_ctor_set(x_420, 1, x_409); +lean_ctor_set(x_420, 2, x_419); +lean_ctor_set(x_420, 3, x_410); +lean_ctor_set(x_420, 4, x_411); +lean_ctor_set(x_420, 5, x_412); +if (lean_is_scalar(x_244)) { + x_421 = lean_alloc_ctor(1, 2, 0); +} else { + x_421 = x_244; + lean_ctor_set_tag(x_421, 1); +} +lean_ctor_set(x_421, 0, x_407); +lean_ctor_set(x_421, 1, x_420); +return x_421; +} +else +{ +lean_object* x_422; lean_object* x_423; lean_object* x_424; lean_object* x_425; lean_object* x_426; lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; lean_object* x_432; lean_object* x_433; lean_object* x_434; lean_object* x_435; lean_object* x_436; lean_object* x_437; +x_422 = lean_ctor_get(x_405, 2); +lean_inc(x_422); +x_423 = lean_ctor_get(x_404, 0); +lean_inc(x_423); +lean_dec(x_404); +x_424 = lean_ctor_get(x_405, 0); +lean_inc(x_424); +x_425 = lean_ctor_get(x_405, 1); +lean_inc(x_425); +x_426 = lean_ctor_get(x_405, 3); +lean_inc(x_426); +x_427 = lean_ctor_get(x_405, 4); +lean_inc(x_427); +x_428 = lean_ctor_get(x_405, 5); +lean_inc(x_428); +if (lean_is_exclusive(x_405)) { + lean_ctor_release(x_405, 0); + lean_ctor_release(x_405, 1); + lean_ctor_release(x_405, 2); + lean_ctor_release(x_405, 3); + lean_ctor_release(x_405, 4); + lean_ctor_release(x_405, 5); + x_429 = x_405; +} else { + lean_dec_ref(x_405); + x_429 = lean_box(0); +} +x_430 = lean_ctor_get(x_422, 0); +lean_inc(x_430); +x_431 = lean_ctor_get(x_422, 1); +lean_inc(x_431); +x_432 = lean_ctor_get(x_422, 3); +lean_inc(x_432); +x_433 = lean_ctor_get(x_422, 4); +lean_inc(x_433); +if (lean_is_exclusive(x_422)) { + lean_ctor_release(x_422, 0); + lean_ctor_release(x_422, 1); + lean_ctor_release(x_422, 2); + lean_ctor_release(x_422, 3); + lean_ctor_release(x_422, 4); + x_434 = x_422; +} else { + lean_dec_ref(x_422); + x_434 = lean_box(0); +} +if (lean_is_scalar(x_434)) { + x_435 = lean_alloc_ctor(0, 5, 0); +} else { + x_435 = x_434; +} +lean_ctor_set(x_435, 0, x_430); +lean_ctor_set(x_435, 1, x_431); +lean_ctor_set(x_435, 2, x_400); +lean_ctor_set(x_435, 3, x_432); +lean_ctor_set(x_435, 4, x_433); +if (lean_is_scalar(x_429)) { + x_436 = lean_alloc_ctor(0, 6, 0); +} else { + x_436 = x_429; +} +lean_ctor_set(x_436, 0, x_424); +lean_ctor_set(x_436, 1, x_425); +lean_ctor_set(x_436, 2, x_435); +lean_ctor_set(x_436, 3, x_426); +lean_ctor_set(x_436, 4, x_427); +lean_ctor_set(x_436, 5, x_428); +if (lean_is_scalar(x_244)) { + x_437 = lean_alloc_ctor(0, 2, 0); +} else { + x_437 = x_244; +} +lean_ctor_set(x_437, 0, x_423); +lean_ctor_set(x_437, 1, x_436); +return x_437; } } } @@ -10273,29 +10527,29 @@ return x_417; } else { -uint8_t x_438; +uint8_t x_458; lean_dec(x_10); lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_438 = !lean_is_exclusive(x_227); -if (x_438 == 0) +x_458 = !lean_is_exclusive(x_237); +if (x_458 == 0) { -return x_227; +return x_237; } else { -lean_object* x_439; lean_object* x_440; lean_object* x_441; -x_439 = lean_ctor_get(x_227, 0); -x_440 = lean_ctor_get(x_227, 1); -lean_inc(x_440); -lean_inc(x_439); -lean_dec(x_227); -x_441 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_441, 0, x_439); -lean_ctor_set(x_441, 1, x_440); -return x_441; +lean_object* x_459; lean_object* x_460; lean_object* x_461; +x_459 = lean_ctor_get(x_237, 0); +x_460 = lean_ctor_get(x_237, 1); +lean_inc(x_460); +lean_inc(x_459); +lean_dec(x_237); +x_461 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_461, 0, x_459); +lean_ctor_set(x_461, 1, x_460); +return x_461; } } } @@ -10303,58 +10557,58 @@ return x_441; } else { -uint8_t x_442; +uint8_t x_462; lean_dec(x_14); lean_dec(x_10); lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_442 = !lean_is_exclusive(x_15); -if (x_442 == 0) +x_462 = !lean_is_exclusive(x_15); +if (x_462 == 0) { return x_15; } else { -lean_object* x_443; lean_object* x_444; lean_object* x_445; -x_443 = lean_ctor_get(x_15, 0); -x_444 = lean_ctor_get(x_15, 1); -lean_inc(x_444); -lean_inc(x_443); +lean_object* x_463; lean_object* x_464; lean_object* x_465; +x_463 = lean_ctor_get(x_15, 0); +x_464 = lean_ctor_get(x_15, 1); +lean_inc(x_464); +lean_inc(x_463); lean_dec(x_15); -x_445 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_445, 0, x_443); -lean_ctor_set(x_445, 1, x_444); -return x_445; +x_465 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_465, 0, x_463); +lean_ctor_set(x_465, 1, x_464); +return x_465; } } } else { -uint8_t x_446; +uint8_t x_466; lean_dec(x_10); lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_446 = !lean_is_exclusive(x_11); -if (x_446 == 0) +x_466 = !lean_is_exclusive(x_11); +if (x_466 == 0) { return x_11; } else { -lean_object* x_447; lean_object* x_448; lean_object* x_449; -x_447 = lean_ctor_get(x_11, 0); -x_448 = lean_ctor_get(x_11, 1); -lean_inc(x_448); -lean_inc(x_447); +lean_object* x_467; lean_object* x_468; lean_object* x_469; +x_467 = lean_ctor_get(x_11, 0); +x_468 = lean_ctor_get(x_11, 1); +lean_inc(x_468); +lean_inc(x_467); lean_dec(x_11); -x_449 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_449, 0, x_447); -lean_ctor_set(x_449, 1, x_448); -return x_449; +x_469 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_469, 0, x_467); +lean_ctor_set(x_469, 1, x_468); +return x_469; } } } @@ -10933,105 +11187,105 @@ x_35 = lean_ctor_get(x_29, 2); x_36 = !lean_is_exclusive(x_35); if (x_36 == 0) { -lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_89; uint8_t x_90; +lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_93; uint8_t x_94; x_37 = lean_ctor_get(x_35, 2); -x_89 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_35, 2, x_89); -x_90 = !lean_is_exclusive(x_4); -if (x_90 == 0) +x_93 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_35, 2, x_93); +x_94 = !lean_is_exclusive(x_4); +if (x_94 == 0) { -lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; -x_91 = lean_ctor_get(x_4, 2); -x_92 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_92, 0, x_31); -lean_ctor_set(x_92, 1, x_18); -x_93 = lean_array_push(x_91, x_92); -lean_ctor_set(x_4, 2, x_93); -x_94 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__3(x_1, x_2, x_33, x_4, x_29); -if (lean_obj_tag(x_94) == 0) +lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; +x_95 = lean_ctor_get(x_4, 2); +x_96 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_96, 0, x_31); +lean_ctor_set(x_96, 1, x_18); +x_97 = lean_array_push(x_95, x_96); +lean_ctor_set(x_4, 2, x_97); +x_98 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__3(x_1, x_2, x_33, x_4, x_29); +if (lean_obj_tag(x_98) == 0) { -lean_object* x_95; lean_object* x_96; lean_object* x_97; -x_95 = lean_ctor_get(x_94, 0); -lean_inc(x_95); -x_96 = lean_ctor_get(x_94, 1); -lean_inc(x_96); -lean_dec(x_94); -x_97 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_97, 0, x_95); -x_38 = x_97; -x_39 = x_96; -goto block_88; -} -else -{ -lean_object* x_98; lean_object* x_99; lean_object* x_100; -x_98 = lean_ctor_get(x_94, 0); -lean_inc(x_98); -x_99 = lean_ctor_get(x_94, 1); +lean_object* x_99; lean_object* x_100; lean_object* x_101; +x_99 = lean_ctor_get(x_98, 0); lean_inc(x_99); -lean_dec(x_94); -x_100 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_100, 0, x_98); -x_38 = x_100; -x_39 = x_99; -goto block_88; -} +x_100 = lean_ctor_get(x_98, 1); +lean_inc(x_100); +lean_dec(x_98); +x_101 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_101, 0, x_99); +x_38 = x_101; +x_39 = x_100; +goto block_92; } 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; -x_101 = lean_ctor_get(x_4, 0); -x_102 = lean_ctor_get(x_4, 1); -x_103 = lean_ctor_get(x_4, 2); -x_104 = lean_ctor_get(x_4, 3); -x_105 = lean_ctor_get(x_4, 4); -lean_inc(x_105); -lean_inc(x_104); -lean_inc(x_103); +lean_object* x_102; lean_object* x_103; lean_object* x_104; +x_102 = lean_ctor_get(x_98, 0); lean_inc(x_102); -lean_inc(x_101); -lean_dec(x_4); -x_106 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_106, 0, x_31); -lean_ctor_set(x_106, 1, x_18); -x_107 = lean_array_push(x_103, x_106); -x_108 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_108, 0, x_101); -lean_ctor_set(x_108, 1, x_102); -lean_ctor_set(x_108, 2, x_107); -lean_ctor_set(x_108, 3, x_104); -lean_ctor_set(x_108, 4, x_105); -x_109 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__3(x_1, x_2, x_33, x_108, x_29); -if (lean_obj_tag(x_109) == 0) -{ -lean_object* x_110; lean_object* x_111; lean_object* x_112; -x_110 = lean_ctor_get(x_109, 0); -lean_inc(x_110); -x_111 = lean_ctor_get(x_109, 1); -lean_inc(x_111); -lean_dec(x_109); -x_112 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_112, 0, x_110); -x_38 = x_112; -x_39 = x_111; -goto block_88; +x_103 = lean_ctor_get(x_98, 1); +lean_inc(x_103); +lean_dec(x_98); +x_104 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_104, 0, x_102); +x_38 = x_104; +x_39 = x_103; +goto block_92; +} } else { -lean_object* x_113; lean_object* x_114; lean_object* x_115; -x_113 = lean_ctor_get(x_109, 0); -lean_inc(x_113); -x_114 = lean_ctor_get(x_109, 1); +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_105 = lean_ctor_get(x_4, 0); +x_106 = lean_ctor_get(x_4, 1); +x_107 = lean_ctor_get(x_4, 2); +x_108 = lean_ctor_get(x_4, 3); +x_109 = lean_ctor_get(x_4, 4); +lean_inc(x_109); +lean_inc(x_108); +lean_inc(x_107); +lean_inc(x_106); +lean_inc(x_105); +lean_dec(x_4); +x_110 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_110, 0, x_31); +lean_ctor_set(x_110, 1, x_18); +x_111 = lean_array_push(x_107, x_110); +x_112 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_112, 0, x_105); +lean_ctor_set(x_112, 1, x_106); +lean_ctor_set(x_112, 2, x_111); +lean_ctor_set(x_112, 3, x_108); +lean_ctor_set(x_112, 4, x_109); +x_113 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__3(x_1, x_2, x_33, x_112, x_29); +if (lean_obj_tag(x_113) == 0) +{ +lean_object* x_114; lean_object* x_115; lean_object* x_116; +x_114 = lean_ctor_get(x_113, 0); lean_inc(x_114); -lean_dec(x_109); -x_115 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_115, 0, x_113); -x_38 = x_115; -x_39 = x_114; -goto block_88; +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_114); +x_38 = x_116; +x_39 = x_115; +goto block_92; +} +else +{ +lean_object* x_117; lean_object* x_118; lean_object* x_119; +x_117 = lean_ctor_get(x_113, 0); +lean_inc(x_117); +x_118 = lean_ctor_get(x_113, 1); +lean_inc(x_118); +lean_dec(x_113); +x_119 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_119, 0, x_117); +x_38 = x_119; +x_39 = x_118; +goto block_92; } } -block_88: +block_92: { if (lean_obj_tag(x_38) == 0) { @@ -11066,1284 +11320,1262 @@ return x_46; } else { -lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; +lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; x_47 = lean_ctor_get(x_40, 0); x_48 = lean_ctor_get(x_40, 1); x_49 = lean_ctor_get(x_40, 3); +x_50 = lean_ctor_get(x_40, 4); +lean_inc(x_50); lean_inc(x_49); lean_inc(x_48); lean_inc(x_47); lean_dec(x_40); -x_50 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_50, 0, x_47); -lean_ctor_set(x_50, 1, x_48); -lean_ctor_set(x_50, 2, x_37); -lean_ctor_set(x_50, 3, x_49); -lean_ctor_set(x_39, 2, x_50); +x_51 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_51, 0, x_47); +lean_ctor_set(x_51, 1, x_48); +lean_ctor_set(x_51, 2, x_37); +lean_ctor_set(x_51, 3, x_49); +lean_ctor_set(x_51, 4, x_50); +lean_ctor_set(x_39, 2, x_51); if (lean_is_scalar(x_30)) { - x_51 = lean_alloc_ctor(1, 2, 0); + x_52 = lean_alloc_ctor(1, 2, 0); } else { - x_51 = x_30; - lean_ctor_set_tag(x_51, 1); + x_52 = x_30; + lean_ctor_set_tag(x_52, 1); } -lean_ctor_set(x_51, 0, x_41); -lean_ctor_set(x_51, 1, x_39); -return x_51; +lean_ctor_set(x_52, 0, x_41); +lean_ctor_set(x_52, 1, x_39); +return x_52; } } else { -lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; -x_52 = lean_ctor_get(x_39, 0); -x_53 = lean_ctor_get(x_39, 1); -x_54 = lean_ctor_get(x_39, 3); -x_55 = lean_ctor_get(x_39, 4); -x_56 = lean_ctor_get(x_39, 5); +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_object* x_63; lean_object* x_64; lean_object* x_65; +x_53 = lean_ctor_get(x_39, 0); +x_54 = lean_ctor_get(x_39, 1); +x_55 = lean_ctor_get(x_39, 3); +x_56 = lean_ctor_get(x_39, 4); +x_57 = lean_ctor_get(x_39, 5); +lean_inc(x_57); lean_inc(x_56); lean_inc(x_55); lean_inc(x_54); lean_inc(x_53); -lean_inc(x_52); lean_dec(x_39); -x_57 = lean_ctor_get(x_40, 0); -lean_inc(x_57); -x_58 = lean_ctor_get(x_40, 1); +x_58 = lean_ctor_get(x_40, 0); lean_inc(x_58); -x_59 = lean_ctor_get(x_40, 3); +x_59 = lean_ctor_get(x_40, 1); lean_inc(x_59); +x_60 = lean_ctor_get(x_40, 3); +lean_inc(x_60); +x_61 = lean_ctor_get(x_40, 4); +lean_inc(x_61); if (lean_is_exclusive(x_40)) { lean_ctor_release(x_40, 0); lean_ctor_release(x_40, 1); lean_ctor_release(x_40, 2); lean_ctor_release(x_40, 3); - x_60 = x_40; + lean_ctor_release(x_40, 4); + x_62 = x_40; } else { lean_dec_ref(x_40); - x_60 = lean_box(0); + x_62 = lean_box(0); } -if (lean_is_scalar(x_60)) { - x_61 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_62)) { + x_63 = lean_alloc_ctor(0, 5, 0); } else { - x_61 = x_60; + x_63 = x_62; } -lean_ctor_set(x_61, 0, x_57); -lean_ctor_set(x_61, 1, x_58); -lean_ctor_set(x_61, 2, x_37); -lean_ctor_set(x_61, 3, x_59); -x_62 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_62, 0, x_52); -lean_ctor_set(x_62, 1, x_53); -lean_ctor_set(x_62, 2, x_61); -lean_ctor_set(x_62, 3, x_54); -lean_ctor_set(x_62, 4, x_55); -lean_ctor_set(x_62, 5, x_56); +lean_ctor_set(x_63, 0, x_58); +lean_ctor_set(x_63, 1, x_59); +lean_ctor_set(x_63, 2, x_37); +lean_ctor_set(x_63, 3, x_60); +lean_ctor_set(x_63, 4, x_61); +x_64 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_64, 0, x_53); +lean_ctor_set(x_64, 1, x_54); +lean_ctor_set(x_64, 2, x_63); +lean_ctor_set(x_64, 3, x_55); +lean_ctor_set(x_64, 4, x_56); +lean_ctor_set(x_64, 5, x_57); if (lean_is_scalar(x_30)) { - x_63 = lean_alloc_ctor(1, 2, 0); + x_65 = lean_alloc_ctor(1, 2, 0); } else { - x_63 = x_30; - lean_ctor_set_tag(x_63, 1); + x_65 = x_30; + lean_ctor_set_tag(x_65, 1); } -lean_ctor_set(x_63, 0, x_41); -lean_ctor_set(x_63, 1, x_62); -return x_63; +lean_ctor_set(x_65, 0, x_41); +lean_ctor_set(x_65, 1, x_64); +return x_65; } } else { -lean_object* x_64; lean_object* x_65; uint8_t x_66; -x_64 = lean_ctor_get(x_39, 2); -lean_inc(x_64); -x_65 = lean_ctor_get(x_38, 0); -lean_inc(x_65); +lean_object* x_66; lean_object* x_67; uint8_t x_68; +x_66 = lean_ctor_get(x_39, 2); +lean_inc(x_66); +x_67 = lean_ctor_get(x_38, 0); +lean_inc(x_67); lean_dec(x_38); -x_66 = !lean_is_exclusive(x_39); -if (x_66 == 0) -{ -lean_object* x_67; uint8_t x_68; -x_67 = lean_ctor_get(x_39, 2); -lean_dec(x_67); -x_68 = !lean_is_exclusive(x_64); +x_68 = !lean_is_exclusive(x_39); if (x_68 == 0) { -lean_object* x_69; lean_object* x_70; -x_69 = lean_ctor_get(x_64, 2); +lean_object* x_69; uint8_t x_70; +x_69 = lean_ctor_get(x_39, 2); lean_dec(x_69); -lean_ctor_set(x_64, 2, x_37); +x_70 = !lean_is_exclusive(x_66); +if (x_70 == 0) +{ +lean_object* x_71; lean_object* x_72; +x_71 = lean_ctor_get(x_66, 2); +lean_dec(x_71); +lean_ctor_set(x_66, 2, x_37); if (lean_is_scalar(x_30)) { - x_70 = lean_alloc_ctor(0, 2, 0); + x_72 = lean_alloc_ctor(0, 2, 0); } else { - x_70 = x_30; + x_72 = x_30; } -lean_ctor_set(x_70, 0, x_65); -lean_ctor_set(x_70, 1, x_39); -return x_70; +lean_ctor_set(x_72, 0, x_67); +lean_ctor_set(x_72, 1, x_39); +return x_72; } else { -lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; -x_71 = lean_ctor_get(x_64, 0); -x_72 = lean_ctor_get(x_64, 1); -x_73 = lean_ctor_get(x_64, 3); +lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; +x_73 = lean_ctor_get(x_66, 0); +x_74 = lean_ctor_get(x_66, 1); +x_75 = lean_ctor_get(x_66, 3); +x_76 = lean_ctor_get(x_66, 4); +lean_inc(x_76); +lean_inc(x_75); +lean_inc(x_74); lean_inc(x_73); -lean_inc(x_72); -lean_inc(x_71); -lean_dec(x_64); -x_74 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_74, 0, x_71); -lean_ctor_set(x_74, 1, x_72); -lean_ctor_set(x_74, 2, x_37); -lean_ctor_set(x_74, 3, x_73); -lean_ctor_set(x_39, 2, x_74); +lean_dec(x_66); +x_77 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_77, 0, x_73); +lean_ctor_set(x_77, 1, x_74); +lean_ctor_set(x_77, 2, x_37); +lean_ctor_set(x_77, 3, x_75); +lean_ctor_set(x_77, 4, x_76); +lean_ctor_set(x_39, 2, x_77); if (lean_is_scalar(x_30)) { - x_75 = lean_alloc_ctor(0, 2, 0); + x_78 = lean_alloc_ctor(0, 2, 0); } else { - x_75 = x_30; + x_78 = x_30; } -lean_ctor_set(x_75, 0, x_65); -lean_ctor_set(x_75, 1, x_39); -return x_75; +lean_ctor_set(x_78, 0, x_67); +lean_ctor_set(x_78, 1, x_39); +return x_78; } } else { -lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; -x_76 = lean_ctor_get(x_39, 0); -x_77 = lean_ctor_get(x_39, 1); -x_78 = lean_ctor_get(x_39, 3); -x_79 = lean_ctor_get(x_39, 4); -x_80 = lean_ctor_get(x_39, 5); +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; +x_79 = lean_ctor_get(x_39, 0); +x_80 = lean_ctor_get(x_39, 1); +x_81 = lean_ctor_get(x_39, 3); +x_82 = lean_ctor_get(x_39, 4); +x_83 = lean_ctor_get(x_39, 5); +lean_inc(x_83); +lean_inc(x_82); +lean_inc(x_81); lean_inc(x_80); lean_inc(x_79); -lean_inc(x_78); -lean_inc(x_77); -lean_inc(x_76); lean_dec(x_39); -x_81 = lean_ctor_get(x_64, 0); -lean_inc(x_81); -x_82 = lean_ctor_get(x_64, 1); -lean_inc(x_82); -x_83 = lean_ctor_get(x_64, 3); -lean_inc(x_83); -if (lean_is_exclusive(x_64)) { - lean_ctor_release(x_64, 0); - lean_ctor_release(x_64, 1); - lean_ctor_release(x_64, 2); - lean_ctor_release(x_64, 3); - x_84 = x_64; +x_84 = lean_ctor_get(x_66, 0); +lean_inc(x_84); +x_85 = lean_ctor_get(x_66, 1); +lean_inc(x_85); +x_86 = lean_ctor_get(x_66, 3); +lean_inc(x_86); +x_87 = lean_ctor_get(x_66, 4); +lean_inc(x_87); +if (lean_is_exclusive(x_66)) { + lean_ctor_release(x_66, 0); + lean_ctor_release(x_66, 1); + lean_ctor_release(x_66, 2); + lean_ctor_release(x_66, 3); + lean_ctor_release(x_66, 4); + x_88 = x_66; } else { - lean_dec_ref(x_64); - x_84 = lean_box(0); + lean_dec_ref(x_66); + x_88 = lean_box(0); } -if (lean_is_scalar(x_84)) { - x_85 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_88)) { + x_89 = lean_alloc_ctor(0, 5, 0); } else { - x_85 = x_84; + x_89 = x_88; } -lean_ctor_set(x_85, 0, x_81); -lean_ctor_set(x_85, 1, x_82); -lean_ctor_set(x_85, 2, x_37); -lean_ctor_set(x_85, 3, x_83); -x_86 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_86, 0, x_76); -lean_ctor_set(x_86, 1, x_77); -lean_ctor_set(x_86, 2, x_85); -lean_ctor_set(x_86, 3, x_78); -lean_ctor_set(x_86, 4, x_79); -lean_ctor_set(x_86, 5, x_80); +lean_ctor_set(x_89, 0, x_84); +lean_ctor_set(x_89, 1, x_85); +lean_ctor_set(x_89, 2, x_37); +lean_ctor_set(x_89, 3, x_86); +lean_ctor_set(x_89, 4, x_87); +x_90 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_90, 0, x_79); +lean_ctor_set(x_90, 1, x_80); +lean_ctor_set(x_90, 2, x_89); +lean_ctor_set(x_90, 3, x_81); +lean_ctor_set(x_90, 4, x_82); +lean_ctor_set(x_90, 5, x_83); if (lean_is_scalar(x_30)) { - x_87 = lean_alloc_ctor(0, 2, 0); + x_91 = lean_alloc_ctor(0, 2, 0); } else { - x_87 = x_30; + x_91 = x_30; } -lean_ctor_set(x_87, 0, x_65); -lean_ctor_set(x_87, 1, x_86); -return x_87; +lean_ctor_set(x_91, 0, x_67); +lean_ctor_set(x_91, 1, x_90); +return x_91; } } } } else { -lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_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; -x_116 = lean_ctor_get(x_35, 0); -x_117 = lean_ctor_get(x_35, 1); -x_118 = lean_ctor_get(x_35, 2); -x_119 = lean_ctor_get(x_35, 3); -lean_inc(x_119); -lean_inc(x_118); -lean_inc(x_117); -lean_inc(x_116); -lean_dec(x_35); -x_153 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_154 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_154, 0, x_116); -lean_ctor_set(x_154, 1, x_117); -lean_ctor_set(x_154, 2, x_153); -lean_ctor_set(x_154, 3, x_119); -lean_ctor_set(x_29, 2, x_154); -x_155 = lean_ctor_get(x_4, 0); -lean_inc(x_155); -x_156 = lean_ctor_get(x_4, 1); -lean_inc(x_156); -x_157 = lean_ctor_get(x_4, 2); -lean_inc(x_157); -x_158 = lean_ctor_get(x_4, 3); -lean_inc(x_158); -x_159 = lean_ctor_get(x_4, 4); -lean_inc(x_159); -if (lean_is_exclusive(x_4)) { - lean_ctor_release(x_4, 0); - lean_ctor_release(x_4, 1); - lean_ctor_release(x_4, 2); - lean_ctor_release(x_4, 3); - lean_ctor_release(x_4, 4); - x_160 = x_4; -} else { - lean_dec_ref(x_4); - x_160 = lean_box(0); -} -x_161 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_161, 0, x_31); -lean_ctor_set(x_161, 1, x_18); -x_162 = lean_array_push(x_157, x_161); -if (lean_is_scalar(x_160)) { - x_163 = lean_alloc_ctor(0, 5, 0); -} else { - x_163 = x_160; -} -lean_ctor_set(x_163, 0, x_155); -lean_ctor_set(x_163, 1, x_156); -lean_ctor_set(x_163, 2, x_162); -lean_ctor_set(x_163, 3, x_158); -lean_ctor_set(x_163, 4, x_159); -x_164 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__3(x_1, x_2, x_33, x_163, x_29); -if (lean_obj_tag(x_164) == 0) -{ -lean_object* x_165; lean_object* x_166; lean_object* x_167; -x_165 = lean_ctor_get(x_164, 0); -lean_inc(x_165); -x_166 = lean_ctor_get(x_164, 1); -lean_inc(x_166); -lean_dec(x_164); -x_167 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_167, 0, x_165); -x_120 = x_167; -x_121 = x_166; -goto block_152; -} -else -{ -lean_object* x_168; lean_object* x_169; lean_object* x_170; -x_168 = lean_ctor_get(x_164, 0); -lean_inc(x_168); -x_169 = lean_ctor_get(x_164, 1); -lean_inc(x_169); -lean_dec(x_164); -x_170 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_170, 0, x_168); -x_120 = x_170; -x_121 = x_169; -goto block_152; -} -block_152: -{ -if (lean_obj_tag(x_120) == 0) -{ -lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; -x_122 = lean_ctor_get(x_121, 2); -lean_inc(x_122); -x_123 = lean_ctor_get(x_120, 0); -lean_inc(x_123); -lean_dec(x_120); -x_124 = lean_ctor_get(x_121, 0); +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_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; +x_120 = lean_ctor_get(x_35, 0); +x_121 = lean_ctor_get(x_35, 1); +x_122 = lean_ctor_get(x_35, 2); +x_123 = lean_ctor_get(x_35, 3); +x_124 = lean_ctor_get(x_35, 4); lean_inc(x_124); -x_125 = lean_ctor_get(x_121, 1); -lean_inc(x_125); -x_126 = lean_ctor_get(x_121, 3); -lean_inc(x_126); -x_127 = lean_ctor_get(x_121, 4); -lean_inc(x_127); -x_128 = lean_ctor_get(x_121, 5); -lean_inc(x_128); -if (lean_is_exclusive(x_121)) { - lean_ctor_release(x_121, 0); - lean_ctor_release(x_121, 1); - lean_ctor_release(x_121, 2); - lean_ctor_release(x_121, 3); - lean_ctor_release(x_121, 4); - lean_ctor_release(x_121, 5); - x_129 = x_121; -} else { - lean_dec_ref(x_121); - x_129 = lean_box(0); -} -x_130 = lean_ctor_get(x_122, 0); -lean_inc(x_130); -x_131 = lean_ctor_get(x_122, 1); -lean_inc(x_131); -x_132 = lean_ctor_get(x_122, 3); -lean_inc(x_132); -if (lean_is_exclusive(x_122)) { - lean_ctor_release(x_122, 0); - lean_ctor_release(x_122, 1); - lean_ctor_release(x_122, 2); - lean_ctor_release(x_122, 3); - x_133 = x_122; -} else { - lean_dec_ref(x_122); - x_133 = lean_box(0); -} -if (lean_is_scalar(x_133)) { - x_134 = lean_alloc_ctor(0, 4, 0); -} else { - x_134 = x_133; -} -lean_ctor_set(x_134, 0, x_130); -lean_ctor_set(x_134, 1, x_131); -lean_ctor_set(x_134, 2, x_118); -lean_ctor_set(x_134, 3, x_132); -if (lean_is_scalar(x_129)) { - x_135 = lean_alloc_ctor(0, 6, 0); -} else { - x_135 = x_129; -} -lean_ctor_set(x_135, 0, x_124); -lean_ctor_set(x_135, 1, x_125); -lean_ctor_set(x_135, 2, x_134); -lean_ctor_set(x_135, 3, x_126); -lean_ctor_set(x_135, 4, x_127); -lean_ctor_set(x_135, 5, x_128); -if (lean_is_scalar(x_30)) { - x_136 = lean_alloc_ctor(1, 2, 0); -} else { - x_136 = x_30; - lean_ctor_set_tag(x_136, 1); -} -lean_ctor_set(x_136, 0, x_123); -lean_ctor_set(x_136, 1, x_135); -return x_136; -} -else -{ -lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; -x_137 = lean_ctor_get(x_121, 2); -lean_inc(x_137); -x_138 = lean_ctor_get(x_120, 0); -lean_inc(x_138); -lean_dec(x_120); -x_139 = lean_ctor_get(x_121, 0); -lean_inc(x_139); -x_140 = lean_ctor_get(x_121, 1); -lean_inc(x_140); -x_141 = lean_ctor_get(x_121, 3); -lean_inc(x_141); -x_142 = lean_ctor_get(x_121, 4); -lean_inc(x_142); -x_143 = lean_ctor_get(x_121, 5); -lean_inc(x_143); -if (lean_is_exclusive(x_121)) { - lean_ctor_release(x_121, 0); - lean_ctor_release(x_121, 1); - lean_ctor_release(x_121, 2); - lean_ctor_release(x_121, 3); - lean_ctor_release(x_121, 4); - lean_ctor_release(x_121, 5); - x_144 = x_121; -} else { - lean_dec_ref(x_121); - x_144 = lean_box(0); -} -x_145 = lean_ctor_get(x_137, 0); -lean_inc(x_145); -x_146 = lean_ctor_get(x_137, 1); -lean_inc(x_146); -x_147 = lean_ctor_get(x_137, 3); -lean_inc(x_147); -if (lean_is_exclusive(x_137)) { - lean_ctor_release(x_137, 0); - lean_ctor_release(x_137, 1); - lean_ctor_release(x_137, 2); - lean_ctor_release(x_137, 3); - x_148 = x_137; -} else { - lean_dec_ref(x_137); - x_148 = lean_box(0); -} -if (lean_is_scalar(x_148)) { - x_149 = lean_alloc_ctor(0, 4, 0); -} else { - x_149 = x_148; -} -lean_ctor_set(x_149, 0, x_145); -lean_ctor_set(x_149, 1, x_146); -lean_ctor_set(x_149, 2, x_118); -lean_ctor_set(x_149, 3, x_147); -if (lean_is_scalar(x_144)) { - x_150 = lean_alloc_ctor(0, 6, 0); -} else { - x_150 = x_144; -} -lean_ctor_set(x_150, 0, x_139); -lean_ctor_set(x_150, 1, x_140); -lean_ctor_set(x_150, 2, x_149); -lean_ctor_set(x_150, 3, x_141); -lean_ctor_set(x_150, 4, x_142); -lean_ctor_set(x_150, 5, x_143); -if (lean_is_scalar(x_30)) { - x_151 = lean_alloc_ctor(0, 2, 0); -} else { - x_151 = x_30; -} -lean_ctor_set(x_151, 0, x_138); -lean_ctor_set(x_151, 1, x_150); -return x_151; -} -} -} -} -else -{ -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; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; lean_object* x_224; lean_object* x_225; lean_object* x_226; lean_object* x_227; -x_171 = lean_ctor_get(x_29, 2); -x_172 = lean_ctor_get(x_29, 0); -x_173 = lean_ctor_get(x_29, 1); -x_174 = lean_ctor_get(x_29, 3); -x_175 = lean_ctor_get(x_29, 4); -x_176 = lean_ctor_get(x_29, 5); -lean_inc(x_176); -lean_inc(x_175); -lean_inc(x_174); -lean_inc(x_171); -lean_inc(x_173); -lean_inc(x_172); -lean_dec(x_29); -x_177 = lean_ctor_get(x_171, 0); -lean_inc(x_177); -x_178 = lean_ctor_get(x_171, 1); -lean_inc(x_178); -x_179 = lean_ctor_get(x_171, 2); -lean_inc(x_179); -x_180 = lean_ctor_get(x_171, 3); -lean_inc(x_180); -if (lean_is_exclusive(x_171)) { - lean_ctor_release(x_171, 0); - lean_ctor_release(x_171, 1); - lean_ctor_release(x_171, 2); - lean_ctor_release(x_171, 3); - x_181 = x_171; -} else { - lean_dec_ref(x_171); - x_181 = lean_box(0); -} -x_215 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_181)) { - x_216 = lean_alloc_ctor(0, 4, 0); -} else { - x_216 = x_181; -} -lean_ctor_set(x_216, 0, x_177); -lean_ctor_set(x_216, 1, x_178); -lean_ctor_set(x_216, 2, x_215); -lean_ctor_set(x_216, 3, x_180); -x_217 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_217, 0, x_172); -lean_ctor_set(x_217, 1, x_173); -lean_ctor_set(x_217, 2, x_216); -lean_ctor_set(x_217, 3, x_174); -lean_ctor_set(x_217, 4, x_175); -lean_ctor_set(x_217, 5, x_176); -x_218 = lean_ctor_get(x_4, 0); -lean_inc(x_218); -x_219 = lean_ctor_get(x_4, 1); -lean_inc(x_219); -x_220 = lean_ctor_get(x_4, 2); -lean_inc(x_220); -x_221 = lean_ctor_get(x_4, 3); -lean_inc(x_221); -x_222 = lean_ctor_get(x_4, 4); -lean_inc(x_222); +lean_inc(x_123); +lean_inc(x_122); +lean_inc(x_121); +lean_inc(x_120); +lean_dec(x_35); +x_160 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_161 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_161, 0, x_120); +lean_ctor_set(x_161, 1, x_121); +lean_ctor_set(x_161, 2, x_160); +lean_ctor_set(x_161, 3, x_123); +lean_ctor_set(x_161, 4, x_124); +lean_ctor_set(x_29, 2, x_161); +x_162 = lean_ctor_get(x_4, 0); +lean_inc(x_162); +x_163 = lean_ctor_get(x_4, 1); +lean_inc(x_163); +x_164 = lean_ctor_get(x_4, 2); +lean_inc(x_164); +x_165 = lean_ctor_get(x_4, 3); +lean_inc(x_165); +x_166 = lean_ctor_get(x_4, 4); +lean_inc(x_166); if (lean_is_exclusive(x_4)) { lean_ctor_release(x_4, 0); lean_ctor_release(x_4, 1); lean_ctor_release(x_4, 2); lean_ctor_release(x_4, 3); lean_ctor_release(x_4, 4); - x_223 = x_4; + x_167 = x_4; } else { lean_dec_ref(x_4); - x_223 = lean_box(0); + x_167 = lean_box(0); } -x_224 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_224, 0, x_31); -lean_ctor_set(x_224, 1, x_18); -x_225 = lean_array_push(x_220, x_224); -if (lean_is_scalar(x_223)) { +x_168 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_168, 0, x_31); +lean_ctor_set(x_168, 1, x_18); +x_169 = lean_array_push(x_164, x_168); +if (lean_is_scalar(x_167)) { + x_170 = lean_alloc_ctor(0, 5, 0); +} else { + x_170 = x_167; +} +lean_ctor_set(x_170, 0, x_162); +lean_ctor_set(x_170, 1, x_163); +lean_ctor_set(x_170, 2, x_169); +lean_ctor_set(x_170, 3, x_165); +lean_ctor_set(x_170, 4, x_166); +x_171 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__3(x_1, x_2, x_33, x_170, x_29); +if (lean_obj_tag(x_171) == 0) +{ +lean_object* x_172; lean_object* x_173; lean_object* x_174; +x_172 = lean_ctor_get(x_171, 0); +lean_inc(x_172); +x_173 = lean_ctor_get(x_171, 1); +lean_inc(x_173); +lean_dec(x_171); +x_174 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_174, 0, x_172); +x_125 = x_174; +x_126 = x_173; +goto block_159; +} +else +{ +lean_object* x_175; lean_object* x_176; lean_object* x_177; +x_175 = lean_ctor_get(x_171, 0); +lean_inc(x_175); +x_176 = lean_ctor_get(x_171, 1); +lean_inc(x_176); +lean_dec(x_171); +x_177 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_177, 0, x_175); +x_125 = x_177; +x_126 = x_176; +goto block_159; +} +block_159: +{ +if (lean_obj_tag(x_125) == 0) +{ +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; +x_127 = lean_ctor_get(x_126, 2); +lean_inc(x_127); +x_128 = lean_ctor_get(x_125, 0); +lean_inc(x_128); +lean_dec(x_125); +x_129 = lean_ctor_get(x_126, 0); +lean_inc(x_129); +x_130 = lean_ctor_get(x_126, 1); +lean_inc(x_130); +x_131 = lean_ctor_get(x_126, 3); +lean_inc(x_131); +x_132 = lean_ctor_get(x_126, 4); +lean_inc(x_132); +x_133 = lean_ctor_get(x_126, 5); +lean_inc(x_133); +if (lean_is_exclusive(x_126)) { + lean_ctor_release(x_126, 0); + lean_ctor_release(x_126, 1); + lean_ctor_release(x_126, 2); + lean_ctor_release(x_126, 3); + lean_ctor_release(x_126, 4); + lean_ctor_release(x_126, 5); + x_134 = x_126; +} else { + lean_dec_ref(x_126); + x_134 = lean_box(0); +} +x_135 = lean_ctor_get(x_127, 0); +lean_inc(x_135); +x_136 = lean_ctor_get(x_127, 1); +lean_inc(x_136); +x_137 = lean_ctor_get(x_127, 3); +lean_inc(x_137); +x_138 = lean_ctor_get(x_127, 4); +lean_inc(x_138); +if (lean_is_exclusive(x_127)) { + lean_ctor_release(x_127, 0); + lean_ctor_release(x_127, 1); + lean_ctor_release(x_127, 2); + lean_ctor_release(x_127, 3); + lean_ctor_release(x_127, 4); + x_139 = x_127; +} else { + lean_dec_ref(x_127); + x_139 = lean_box(0); +} +if (lean_is_scalar(x_139)) { + x_140 = lean_alloc_ctor(0, 5, 0); +} else { + x_140 = x_139; +} +lean_ctor_set(x_140, 0, x_135); +lean_ctor_set(x_140, 1, x_136); +lean_ctor_set(x_140, 2, x_122); +lean_ctor_set(x_140, 3, x_137); +lean_ctor_set(x_140, 4, x_138); +if (lean_is_scalar(x_134)) { + x_141 = lean_alloc_ctor(0, 6, 0); +} else { + x_141 = x_134; +} +lean_ctor_set(x_141, 0, x_129); +lean_ctor_set(x_141, 1, x_130); +lean_ctor_set(x_141, 2, x_140); +lean_ctor_set(x_141, 3, x_131); +lean_ctor_set(x_141, 4, x_132); +lean_ctor_set(x_141, 5, x_133); +if (lean_is_scalar(x_30)) { + x_142 = lean_alloc_ctor(1, 2, 0); +} else { + x_142 = x_30; + lean_ctor_set_tag(x_142, 1); +} +lean_ctor_set(x_142, 0, x_128); +lean_ctor_set(x_142, 1, x_141); +return x_142; +} +else +{ +lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; 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; +x_143 = lean_ctor_get(x_126, 2); +lean_inc(x_143); +x_144 = lean_ctor_get(x_125, 0); +lean_inc(x_144); +lean_dec(x_125); +x_145 = lean_ctor_get(x_126, 0); +lean_inc(x_145); +x_146 = lean_ctor_get(x_126, 1); +lean_inc(x_146); +x_147 = lean_ctor_get(x_126, 3); +lean_inc(x_147); +x_148 = lean_ctor_get(x_126, 4); +lean_inc(x_148); +x_149 = lean_ctor_get(x_126, 5); +lean_inc(x_149); +if (lean_is_exclusive(x_126)) { + lean_ctor_release(x_126, 0); + lean_ctor_release(x_126, 1); + lean_ctor_release(x_126, 2); + lean_ctor_release(x_126, 3); + lean_ctor_release(x_126, 4); + lean_ctor_release(x_126, 5); + x_150 = x_126; +} else { + lean_dec_ref(x_126); + x_150 = lean_box(0); +} +x_151 = lean_ctor_get(x_143, 0); +lean_inc(x_151); +x_152 = lean_ctor_get(x_143, 1); +lean_inc(x_152); +x_153 = lean_ctor_get(x_143, 3); +lean_inc(x_153); +x_154 = lean_ctor_get(x_143, 4); +lean_inc(x_154); +if (lean_is_exclusive(x_143)) { + lean_ctor_release(x_143, 0); + lean_ctor_release(x_143, 1); + lean_ctor_release(x_143, 2); + lean_ctor_release(x_143, 3); + lean_ctor_release(x_143, 4); + x_155 = x_143; +} else { + lean_dec_ref(x_143); + x_155 = lean_box(0); +} +if (lean_is_scalar(x_155)) { + x_156 = lean_alloc_ctor(0, 5, 0); +} else { + x_156 = x_155; +} +lean_ctor_set(x_156, 0, x_151); +lean_ctor_set(x_156, 1, x_152); +lean_ctor_set(x_156, 2, x_122); +lean_ctor_set(x_156, 3, x_153); +lean_ctor_set(x_156, 4, x_154); +if (lean_is_scalar(x_150)) { + x_157 = lean_alloc_ctor(0, 6, 0); +} else { + x_157 = x_150; +} +lean_ctor_set(x_157, 0, x_145); +lean_ctor_set(x_157, 1, x_146); +lean_ctor_set(x_157, 2, x_156); +lean_ctor_set(x_157, 3, x_147); +lean_ctor_set(x_157, 4, x_148); +lean_ctor_set(x_157, 5, x_149); +if (lean_is_scalar(x_30)) { + x_158 = lean_alloc_ctor(0, 2, 0); +} else { + x_158 = x_30; +} +lean_ctor_set(x_158, 0, x_144); +lean_ctor_set(x_158, 1, x_157); +return x_158; +} +} +} +} +else +{ +lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_225; lean_object* x_226; lean_object* x_227; lean_object* x_228; lean_object* x_229; lean_object* x_230; lean_object* x_231; lean_object* x_232; lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_object* x_236; lean_object* x_237; +x_178 = lean_ctor_get(x_29, 2); +x_179 = lean_ctor_get(x_29, 0); +x_180 = lean_ctor_get(x_29, 1); +x_181 = lean_ctor_get(x_29, 3); +x_182 = lean_ctor_get(x_29, 4); +x_183 = lean_ctor_get(x_29, 5); +lean_inc(x_183); +lean_inc(x_182); +lean_inc(x_181); +lean_inc(x_178); +lean_inc(x_180); +lean_inc(x_179); +lean_dec(x_29); +x_184 = lean_ctor_get(x_178, 0); +lean_inc(x_184); +x_185 = lean_ctor_get(x_178, 1); +lean_inc(x_185); +x_186 = lean_ctor_get(x_178, 2); +lean_inc(x_186); +x_187 = lean_ctor_get(x_178, 3); +lean_inc(x_187); +x_188 = lean_ctor_get(x_178, 4); +lean_inc(x_188); +if (lean_is_exclusive(x_178)) { + lean_ctor_release(x_178, 0); + lean_ctor_release(x_178, 1); + lean_ctor_release(x_178, 2); + lean_ctor_release(x_178, 3); + lean_ctor_release(x_178, 4); + x_189 = x_178; +} else { + lean_dec_ref(x_178); + x_189 = lean_box(0); +} +x_225 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_189)) { x_226 = lean_alloc_ctor(0, 5, 0); } else { - x_226 = x_223; + x_226 = x_189; } -lean_ctor_set(x_226, 0, x_218); -lean_ctor_set(x_226, 1, x_219); +lean_ctor_set(x_226, 0, x_184); +lean_ctor_set(x_226, 1, x_185); lean_ctor_set(x_226, 2, x_225); -lean_ctor_set(x_226, 3, x_221); -lean_ctor_set(x_226, 4, x_222); -x_227 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__3(x_1, x_2, x_33, x_226, x_217); -if (lean_obj_tag(x_227) == 0) -{ -lean_object* x_228; lean_object* x_229; lean_object* x_230; -x_228 = lean_ctor_get(x_227, 0); +lean_ctor_set(x_226, 3, x_187); +lean_ctor_set(x_226, 4, x_188); +x_227 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_227, 0, x_179); +lean_ctor_set(x_227, 1, x_180); +lean_ctor_set(x_227, 2, x_226); +lean_ctor_set(x_227, 3, x_181); +lean_ctor_set(x_227, 4, x_182); +lean_ctor_set(x_227, 5, x_183); +x_228 = lean_ctor_get(x_4, 0); lean_inc(x_228); -x_229 = lean_ctor_get(x_227, 1); +x_229 = lean_ctor_get(x_4, 1); lean_inc(x_229); -lean_dec(x_227); -x_230 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_230, 0, x_228); -x_182 = x_230; -x_183 = x_229; -goto block_214; -} -else -{ -lean_object* x_231; lean_object* x_232; lean_object* x_233; -x_231 = lean_ctor_get(x_227, 0); +x_230 = lean_ctor_get(x_4, 2); +lean_inc(x_230); +x_231 = lean_ctor_get(x_4, 3); lean_inc(x_231); -x_232 = lean_ctor_get(x_227, 1); +x_232 = lean_ctor_get(x_4, 4); lean_inc(x_232); -lean_dec(x_227); -x_233 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_233, 0, x_231); -x_182 = x_233; -x_183 = x_232; -goto block_214; +if (lean_is_exclusive(x_4)) { + lean_ctor_release(x_4, 0); + lean_ctor_release(x_4, 1); + lean_ctor_release(x_4, 2); + lean_ctor_release(x_4, 3); + lean_ctor_release(x_4, 4); + x_233 = x_4; +} else { + lean_dec_ref(x_4); + x_233 = lean_box(0); } -block_214: +x_234 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_234, 0, x_31); +lean_ctor_set(x_234, 1, x_18); +x_235 = lean_array_push(x_230, x_234); +if (lean_is_scalar(x_233)) { + x_236 = lean_alloc_ctor(0, 5, 0); +} else { + x_236 = x_233; +} +lean_ctor_set(x_236, 0, x_228); +lean_ctor_set(x_236, 1, x_229); +lean_ctor_set(x_236, 2, x_235); +lean_ctor_set(x_236, 3, x_231); +lean_ctor_set(x_236, 4, x_232); +x_237 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__3(x_1, x_2, x_33, x_236, x_227); +if (lean_obj_tag(x_237) == 0) { -if (lean_obj_tag(x_182) == 0) -{ -lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; -x_184 = lean_ctor_get(x_183, 2); -lean_inc(x_184); -x_185 = lean_ctor_get(x_182, 0); -lean_inc(x_185); -lean_dec(x_182); -x_186 = lean_ctor_get(x_183, 0); -lean_inc(x_186); -x_187 = lean_ctor_get(x_183, 1); -lean_inc(x_187); -x_188 = lean_ctor_get(x_183, 3); -lean_inc(x_188); -x_189 = lean_ctor_get(x_183, 4); -lean_inc(x_189); -x_190 = lean_ctor_get(x_183, 5); -lean_inc(x_190); -if (lean_is_exclusive(x_183)) { - lean_ctor_release(x_183, 0); - lean_ctor_release(x_183, 1); - lean_ctor_release(x_183, 2); - lean_ctor_release(x_183, 3); - lean_ctor_release(x_183, 4); - lean_ctor_release(x_183, 5); - x_191 = x_183; -} else { - lean_dec_ref(x_183); - x_191 = lean_box(0); -} -x_192 = lean_ctor_get(x_184, 0); -lean_inc(x_192); -x_193 = lean_ctor_get(x_184, 1); -lean_inc(x_193); -x_194 = lean_ctor_get(x_184, 3); -lean_inc(x_194); -if (lean_is_exclusive(x_184)) { - lean_ctor_release(x_184, 0); - lean_ctor_release(x_184, 1); - lean_ctor_release(x_184, 2); - lean_ctor_release(x_184, 3); - x_195 = x_184; -} else { - lean_dec_ref(x_184); - x_195 = lean_box(0); -} -if (lean_is_scalar(x_195)) { - x_196 = lean_alloc_ctor(0, 4, 0); -} else { - x_196 = x_195; -} -lean_ctor_set(x_196, 0, x_192); -lean_ctor_set(x_196, 1, x_193); -lean_ctor_set(x_196, 2, x_179); -lean_ctor_set(x_196, 3, x_194); -if (lean_is_scalar(x_191)) { - x_197 = lean_alloc_ctor(0, 6, 0); -} else { - x_197 = x_191; -} -lean_ctor_set(x_197, 0, x_186); -lean_ctor_set(x_197, 1, x_187); -lean_ctor_set(x_197, 2, x_196); -lean_ctor_set(x_197, 3, x_188); -lean_ctor_set(x_197, 4, x_189); -lean_ctor_set(x_197, 5, x_190); -if (lean_is_scalar(x_30)) { - x_198 = lean_alloc_ctor(1, 2, 0); -} else { - x_198 = x_30; - lean_ctor_set_tag(x_198, 1); -} -lean_ctor_set(x_198, 0, x_185); -lean_ctor_set(x_198, 1, x_197); -return x_198; +lean_object* x_238; lean_object* x_239; lean_object* x_240; +x_238 = lean_ctor_get(x_237, 0); +lean_inc(x_238); +x_239 = lean_ctor_get(x_237, 1); +lean_inc(x_239); +lean_dec(x_237); +x_240 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_240, 0, x_238); +x_190 = x_240; +x_191 = x_239; +goto block_224; } else { -lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; -x_199 = lean_ctor_get(x_183, 2); -lean_inc(x_199); -x_200 = lean_ctor_get(x_182, 0); +lean_object* x_241; lean_object* x_242; lean_object* x_243; +x_241 = lean_ctor_get(x_237, 0); +lean_inc(x_241); +x_242 = lean_ctor_get(x_237, 1); +lean_inc(x_242); +lean_dec(x_237); +x_243 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_243, 0, x_241); +x_190 = x_243; +x_191 = x_242; +goto block_224; +} +block_224: +{ +if (lean_obj_tag(x_190) == 0) +{ +lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; +x_192 = lean_ctor_get(x_191, 2); +lean_inc(x_192); +x_193 = lean_ctor_get(x_190, 0); +lean_inc(x_193); +lean_dec(x_190); +x_194 = lean_ctor_get(x_191, 0); +lean_inc(x_194); +x_195 = lean_ctor_get(x_191, 1); +lean_inc(x_195); +x_196 = lean_ctor_get(x_191, 3); +lean_inc(x_196); +x_197 = lean_ctor_get(x_191, 4); +lean_inc(x_197); +x_198 = lean_ctor_get(x_191, 5); +lean_inc(x_198); +if (lean_is_exclusive(x_191)) { + lean_ctor_release(x_191, 0); + lean_ctor_release(x_191, 1); + lean_ctor_release(x_191, 2); + lean_ctor_release(x_191, 3); + lean_ctor_release(x_191, 4); + lean_ctor_release(x_191, 5); + x_199 = x_191; +} else { + lean_dec_ref(x_191); + x_199 = lean_box(0); +} +x_200 = lean_ctor_get(x_192, 0); lean_inc(x_200); -lean_dec(x_182); -x_201 = lean_ctor_get(x_183, 0); +x_201 = lean_ctor_get(x_192, 1); lean_inc(x_201); -x_202 = lean_ctor_get(x_183, 1); +x_202 = lean_ctor_get(x_192, 3); lean_inc(x_202); -x_203 = lean_ctor_get(x_183, 3); +x_203 = lean_ctor_get(x_192, 4); lean_inc(x_203); -x_204 = lean_ctor_get(x_183, 4); -lean_inc(x_204); -x_205 = lean_ctor_get(x_183, 5); -lean_inc(x_205); -if (lean_is_exclusive(x_183)) { - lean_ctor_release(x_183, 0); - lean_ctor_release(x_183, 1); - lean_ctor_release(x_183, 2); - lean_ctor_release(x_183, 3); - lean_ctor_release(x_183, 4); - lean_ctor_release(x_183, 5); - x_206 = x_183; +if (lean_is_exclusive(x_192)) { + lean_ctor_release(x_192, 0); + lean_ctor_release(x_192, 1); + lean_ctor_release(x_192, 2); + lean_ctor_release(x_192, 3); + lean_ctor_release(x_192, 4); + x_204 = x_192; } else { - lean_dec_ref(x_183); - x_206 = lean_box(0); + lean_dec_ref(x_192); + x_204 = lean_box(0); } -x_207 = lean_ctor_get(x_199, 0); -lean_inc(x_207); -x_208 = lean_ctor_get(x_199, 1); -lean_inc(x_208); -x_209 = lean_ctor_get(x_199, 3); -lean_inc(x_209); -if (lean_is_exclusive(x_199)) { - lean_ctor_release(x_199, 0); - lean_ctor_release(x_199, 1); - lean_ctor_release(x_199, 2); - lean_ctor_release(x_199, 3); - x_210 = x_199; +if (lean_is_scalar(x_204)) { + x_205 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_199); - x_210 = lean_box(0); + x_205 = x_204; } -if (lean_is_scalar(x_210)) { - x_211 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_205, 0, x_200); +lean_ctor_set(x_205, 1, x_201); +lean_ctor_set(x_205, 2, x_186); +lean_ctor_set(x_205, 3, x_202); +lean_ctor_set(x_205, 4, x_203); +if (lean_is_scalar(x_199)) { + x_206 = lean_alloc_ctor(0, 6, 0); } else { - x_211 = x_210; + x_206 = x_199; } -lean_ctor_set(x_211, 0, x_207); -lean_ctor_set(x_211, 1, x_208); -lean_ctor_set(x_211, 2, x_179); -lean_ctor_set(x_211, 3, x_209); -if (lean_is_scalar(x_206)) { - x_212 = lean_alloc_ctor(0, 6, 0); -} else { - x_212 = x_206; -} -lean_ctor_set(x_212, 0, x_201); -lean_ctor_set(x_212, 1, x_202); -lean_ctor_set(x_212, 2, x_211); -lean_ctor_set(x_212, 3, x_203); -lean_ctor_set(x_212, 4, x_204); -lean_ctor_set(x_212, 5, x_205); +lean_ctor_set(x_206, 0, x_194); +lean_ctor_set(x_206, 1, x_195); +lean_ctor_set(x_206, 2, x_205); +lean_ctor_set(x_206, 3, x_196); +lean_ctor_set(x_206, 4, x_197); +lean_ctor_set(x_206, 5, x_198); if (lean_is_scalar(x_30)) { - x_213 = lean_alloc_ctor(0, 2, 0); + x_207 = lean_alloc_ctor(1, 2, 0); } else { - x_213 = x_30; + x_207 = x_30; + lean_ctor_set_tag(x_207, 1); } -lean_ctor_set(x_213, 0, x_200); -lean_ctor_set(x_213, 1, x_212); -return x_213; +lean_ctor_set(x_207, 0, x_193); +lean_ctor_set(x_207, 1, x_206); +return x_207; +} +else +{ +lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; +x_208 = lean_ctor_get(x_191, 2); +lean_inc(x_208); +x_209 = lean_ctor_get(x_190, 0); +lean_inc(x_209); +lean_dec(x_190); +x_210 = lean_ctor_get(x_191, 0); +lean_inc(x_210); +x_211 = lean_ctor_get(x_191, 1); +lean_inc(x_211); +x_212 = lean_ctor_get(x_191, 3); +lean_inc(x_212); +x_213 = lean_ctor_get(x_191, 4); +lean_inc(x_213); +x_214 = lean_ctor_get(x_191, 5); +lean_inc(x_214); +if (lean_is_exclusive(x_191)) { + lean_ctor_release(x_191, 0); + lean_ctor_release(x_191, 1); + lean_ctor_release(x_191, 2); + lean_ctor_release(x_191, 3); + lean_ctor_release(x_191, 4); + lean_ctor_release(x_191, 5); + x_215 = x_191; +} else { + lean_dec_ref(x_191); + x_215 = lean_box(0); +} +x_216 = lean_ctor_get(x_208, 0); +lean_inc(x_216); +x_217 = lean_ctor_get(x_208, 1); +lean_inc(x_217); +x_218 = lean_ctor_get(x_208, 3); +lean_inc(x_218); +x_219 = lean_ctor_get(x_208, 4); +lean_inc(x_219); +if (lean_is_exclusive(x_208)) { + lean_ctor_release(x_208, 0); + lean_ctor_release(x_208, 1); + lean_ctor_release(x_208, 2); + lean_ctor_release(x_208, 3); + lean_ctor_release(x_208, 4); + x_220 = x_208; +} else { + lean_dec_ref(x_208); + x_220 = lean_box(0); +} +if (lean_is_scalar(x_220)) { + x_221 = lean_alloc_ctor(0, 5, 0); +} else { + x_221 = x_220; +} +lean_ctor_set(x_221, 0, x_216); +lean_ctor_set(x_221, 1, x_217); +lean_ctor_set(x_221, 2, x_186); +lean_ctor_set(x_221, 3, x_218); +lean_ctor_set(x_221, 4, x_219); +if (lean_is_scalar(x_215)) { + x_222 = lean_alloc_ctor(0, 6, 0); +} else { + x_222 = x_215; +} +lean_ctor_set(x_222, 0, x_210); +lean_ctor_set(x_222, 1, x_211); +lean_ctor_set(x_222, 2, x_221); +lean_ctor_set(x_222, 3, x_212); +lean_ctor_set(x_222, 4, x_213); +lean_ctor_set(x_222, 5, x_214); +if (lean_is_scalar(x_30)) { + x_223 = lean_alloc_ctor(0, 2, 0); +} else { + x_223 = x_30; +} +lean_ctor_set(x_223, 0, x_209); +lean_ctor_set(x_223, 1, x_222); +return x_223; } } } } default: { -lean_object* x_234; lean_object* x_235; -x_234 = lean_ctor_get(x_23, 1); -lean_inc(x_234); +lean_object* x_244; lean_object* x_245; +x_244 = lean_ctor_get(x_23, 1); +lean_inc(x_244); lean_dec(x_23); lean_inc(x_4); -x_235 = l_Lean_Meta_isClassExpensive___main(x_22, x_4, x_234); -if (lean_obj_tag(x_235) == 0) +x_245 = l_Lean_Meta_isClassExpensive___main(x_22, x_4, x_244); +if (lean_obj_tag(x_245) == 0) { -lean_object* x_236; -x_236 = lean_ctor_get(x_235, 0); -lean_inc(x_236); -if (lean_obj_tag(x_236) == 0) +lean_object* x_246; +x_246 = lean_ctor_get(x_245, 0); +lean_inc(x_246); +if (lean_obj_tag(x_246) == 0) { -lean_object* x_237; lean_object* x_238; lean_object* x_239; +lean_object* x_247; lean_object* x_248; lean_object* x_249; lean_dec(x_18); -x_237 = lean_ctor_get(x_235, 1); -lean_inc(x_237); -lean_dec(x_235); -x_238 = lean_unsigned_to_nat(1u); -x_239 = lean_nat_add(x_3, x_238); +x_247 = lean_ctor_get(x_245, 1); +lean_inc(x_247); +lean_dec(x_245); +x_248 = lean_unsigned_to_nat(1u); +x_249 = lean_nat_add(x_3, x_248); lean_dec(x_3); -x_3 = x_239; -x_5 = x_237; +x_3 = x_249; +x_5 = x_247; goto _start; } else { -lean_object* x_241; lean_object* x_242; lean_object* x_243; lean_object* x_244; lean_object* x_245; uint8_t x_246; -x_241 = lean_ctor_get(x_235, 1); -lean_inc(x_241); -if (lean_is_exclusive(x_235)) { - lean_ctor_release(x_235, 0); - lean_ctor_release(x_235, 1); - x_242 = x_235; +lean_object* x_251; lean_object* x_252; lean_object* x_253; lean_object* x_254; lean_object* x_255; uint8_t x_256; +x_251 = lean_ctor_get(x_245, 1); +lean_inc(x_251); +if (lean_is_exclusive(x_245)) { + lean_ctor_release(x_245, 0); + lean_ctor_release(x_245, 1); + x_252 = x_245; } else { - lean_dec_ref(x_235); - x_242 = lean_box(0); + lean_dec_ref(x_245); + x_252 = lean_box(0); } -x_243 = lean_ctor_get(x_236, 0); -lean_inc(x_243); -lean_dec(x_236); -x_244 = lean_unsigned_to_nat(1u); -x_245 = lean_nat_add(x_3, x_244); -lean_dec(x_3); -x_246 = !lean_is_exclusive(x_241); -if (x_246 == 0) -{ -lean_object* x_247; uint8_t x_248; -x_247 = lean_ctor_get(x_241, 2); -x_248 = !lean_is_exclusive(x_247); -if (x_248 == 0) -{ -lean_object* x_249; lean_object* x_250; lean_object* x_251; lean_object* x_301; uint8_t x_302; -x_249 = lean_ctor_get(x_247, 2); -x_301 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_247, 2, x_301); -x_302 = !lean_is_exclusive(x_4); -if (x_302 == 0) -{ -lean_object* x_303; lean_object* x_304; lean_object* x_305; lean_object* x_306; -x_303 = lean_ctor_get(x_4, 2); -x_304 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_304, 0, x_243); -lean_ctor_set(x_304, 1, x_18); -x_305 = lean_array_push(x_303, x_304); -lean_ctor_set(x_4, 2, x_305); -x_306 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__3(x_1, x_2, x_245, x_4, x_241); -if (lean_obj_tag(x_306) == 0) -{ -lean_object* x_307; lean_object* x_308; lean_object* x_309; -x_307 = lean_ctor_get(x_306, 0); -lean_inc(x_307); -x_308 = lean_ctor_get(x_306, 1); -lean_inc(x_308); -lean_dec(x_306); -x_309 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_309, 0, x_307); -x_250 = x_309; -x_251 = x_308; -goto block_300; -} -else -{ -lean_object* x_310; lean_object* x_311; lean_object* x_312; -x_310 = lean_ctor_get(x_306, 0); -lean_inc(x_310); -x_311 = lean_ctor_get(x_306, 1); -lean_inc(x_311); -lean_dec(x_306); -x_312 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_312, 0, x_310); -x_250 = x_312; -x_251 = x_311; -goto block_300; -} -} -else -{ -lean_object* x_313; lean_object* x_314; lean_object* x_315; lean_object* x_316; lean_object* x_317; lean_object* x_318; lean_object* x_319; lean_object* x_320; lean_object* x_321; -x_313 = lean_ctor_get(x_4, 0); -x_314 = lean_ctor_get(x_4, 1); -x_315 = lean_ctor_get(x_4, 2); -x_316 = lean_ctor_get(x_4, 3); -x_317 = lean_ctor_get(x_4, 4); -lean_inc(x_317); -lean_inc(x_316); -lean_inc(x_315); -lean_inc(x_314); -lean_inc(x_313); -lean_dec(x_4); -x_318 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_318, 0, x_243); -lean_ctor_set(x_318, 1, x_18); -x_319 = lean_array_push(x_315, x_318); -x_320 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_320, 0, x_313); -lean_ctor_set(x_320, 1, x_314); -lean_ctor_set(x_320, 2, x_319); -lean_ctor_set(x_320, 3, x_316); -lean_ctor_set(x_320, 4, x_317); -x_321 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__3(x_1, x_2, x_245, x_320, x_241); -if (lean_obj_tag(x_321) == 0) -{ -lean_object* x_322; lean_object* x_323; lean_object* x_324; -x_322 = lean_ctor_get(x_321, 0); -lean_inc(x_322); -x_323 = lean_ctor_get(x_321, 1); -lean_inc(x_323); -lean_dec(x_321); -x_324 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_324, 0, x_322); -x_250 = x_324; -x_251 = x_323; -goto block_300; -} -else -{ -lean_object* x_325; lean_object* x_326; lean_object* x_327; -x_325 = lean_ctor_get(x_321, 0); -lean_inc(x_325); -x_326 = lean_ctor_get(x_321, 1); -lean_inc(x_326); -lean_dec(x_321); -x_327 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_327, 0, x_325); -x_250 = x_327; -x_251 = x_326; -goto block_300; -} -} -block_300: -{ -if (lean_obj_tag(x_250) == 0) -{ -lean_object* x_252; lean_object* x_253; uint8_t x_254; -x_252 = lean_ctor_get(x_251, 2); -lean_inc(x_252); -x_253 = lean_ctor_get(x_250, 0); +x_253 = lean_ctor_get(x_246, 0); lean_inc(x_253); -lean_dec(x_250); -x_254 = !lean_is_exclusive(x_251); -if (x_254 == 0) -{ -lean_object* x_255; uint8_t x_256; -x_255 = lean_ctor_get(x_251, 2); -lean_dec(x_255); -x_256 = !lean_is_exclusive(x_252); +lean_dec(x_246); +x_254 = lean_unsigned_to_nat(1u); +x_255 = lean_nat_add(x_3, x_254); +lean_dec(x_3); +x_256 = !lean_is_exclusive(x_251); if (x_256 == 0) { -lean_object* x_257; lean_object* x_258; -x_257 = lean_ctor_get(x_252, 2); -lean_dec(x_257); -lean_ctor_set(x_252, 2, x_249); -if (lean_is_scalar(x_242)) { - x_258 = lean_alloc_ctor(1, 2, 0); -} else { - x_258 = x_242; - lean_ctor_set_tag(x_258, 1); -} -lean_ctor_set(x_258, 0, x_253); -lean_ctor_set(x_258, 1, x_251); -return x_258; +lean_object* x_257; uint8_t x_258; +x_257 = lean_ctor_get(x_251, 2); +x_258 = !lean_is_exclusive(x_257); +if (x_258 == 0) +{ +lean_object* x_259; lean_object* x_260; lean_object* x_261; lean_object* x_315; uint8_t x_316; +x_259 = lean_ctor_get(x_257, 2); +x_315 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_257, 2, x_315); +x_316 = !lean_is_exclusive(x_4); +if (x_316 == 0) +{ +lean_object* x_317; lean_object* x_318; lean_object* x_319; lean_object* x_320; +x_317 = lean_ctor_get(x_4, 2); +x_318 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_318, 0, x_253); +lean_ctor_set(x_318, 1, x_18); +x_319 = lean_array_push(x_317, x_318); +lean_ctor_set(x_4, 2, x_319); +x_320 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__3(x_1, x_2, x_255, x_4, x_251); +if (lean_obj_tag(x_320) == 0) +{ +lean_object* x_321; lean_object* x_322; lean_object* x_323; +x_321 = lean_ctor_get(x_320, 0); +lean_inc(x_321); +x_322 = lean_ctor_get(x_320, 1); +lean_inc(x_322); +lean_dec(x_320); +x_323 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_323, 0, x_321); +x_260 = x_323; +x_261 = x_322; +goto block_314; } else { -lean_object* x_259; lean_object* x_260; lean_object* x_261; lean_object* x_262; lean_object* x_263; -x_259 = lean_ctor_get(x_252, 0); -x_260 = lean_ctor_get(x_252, 1); -x_261 = lean_ctor_get(x_252, 3); -lean_inc(x_261); -lean_inc(x_260); -lean_inc(x_259); -lean_dec(x_252); -x_262 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_262, 0, x_259); -lean_ctor_set(x_262, 1, x_260); -lean_ctor_set(x_262, 2, x_249); -lean_ctor_set(x_262, 3, x_261); -lean_ctor_set(x_251, 2, x_262); -if (lean_is_scalar(x_242)) { - x_263 = lean_alloc_ctor(1, 2, 0); -} else { - x_263 = x_242; - lean_ctor_set_tag(x_263, 1); -} -lean_ctor_set(x_263, 0, x_253); -lean_ctor_set(x_263, 1, x_251); -return x_263; +lean_object* x_324; lean_object* x_325; lean_object* x_326; +x_324 = lean_ctor_get(x_320, 0); +lean_inc(x_324); +x_325 = lean_ctor_get(x_320, 1); +lean_inc(x_325); +lean_dec(x_320); +x_326 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_326, 0, x_324); +x_260 = x_326; +x_261 = x_325; +goto block_314; } } else { -lean_object* x_264; lean_object* x_265; lean_object* x_266; lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_object* x_270; lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; lean_object* x_275; -x_264 = lean_ctor_get(x_251, 0); -x_265 = lean_ctor_get(x_251, 1); -x_266 = lean_ctor_get(x_251, 3); -x_267 = lean_ctor_get(x_251, 4); -x_268 = lean_ctor_get(x_251, 5); -lean_inc(x_268); -lean_inc(x_267); -lean_inc(x_266); -lean_inc(x_265); -lean_inc(x_264); -lean_dec(x_251); -x_269 = lean_ctor_get(x_252, 0); -lean_inc(x_269); -x_270 = lean_ctor_get(x_252, 1); -lean_inc(x_270); -x_271 = lean_ctor_get(x_252, 3); +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; +x_327 = lean_ctor_get(x_4, 0); +x_328 = lean_ctor_get(x_4, 1); +x_329 = lean_ctor_get(x_4, 2); +x_330 = lean_ctor_get(x_4, 3); +x_331 = lean_ctor_get(x_4, 4); +lean_inc(x_331); +lean_inc(x_330); +lean_inc(x_329); +lean_inc(x_328); +lean_inc(x_327); +lean_dec(x_4); +x_332 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_332, 0, x_253); +lean_ctor_set(x_332, 1, x_18); +x_333 = lean_array_push(x_329, x_332); +x_334 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_334, 0, x_327); +lean_ctor_set(x_334, 1, x_328); +lean_ctor_set(x_334, 2, x_333); +lean_ctor_set(x_334, 3, x_330); +lean_ctor_set(x_334, 4, x_331); +x_335 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__3(x_1, x_2, x_255, x_334, x_251); +if (lean_obj_tag(x_335) == 0) +{ +lean_object* x_336; lean_object* x_337; lean_object* x_338; +x_336 = lean_ctor_get(x_335, 0); +lean_inc(x_336); +x_337 = lean_ctor_get(x_335, 1); +lean_inc(x_337); +lean_dec(x_335); +x_338 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_338, 0, x_336); +x_260 = x_338; +x_261 = x_337; +goto block_314; +} +else +{ +lean_object* x_339; lean_object* x_340; lean_object* x_341; +x_339 = lean_ctor_get(x_335, 0); +lean_inc(x_339); +x_340 = lean_ctor_get(x_335, 1); +lean_inc(x_340); +lean_dec(x_335); +x_341 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_341, 0, x_339); +x_260 = x_341; +x_261 = x_340; +goto block_314; +} +} +block_314: +{ +if (lean_obj_tag(x_260) == 0) +{ +lean_object* x_262; lean_object* x_263; uint8_t x_264; +x_262 = lean_ctor_get(x_261, 2); +lean_inc(x_262); +x_263 = lean_ctor_get(x_260, 0); +lean_inc(x_263); +lean_dec(x_260); +x_264 = !lean_is_exclusive(x_261); +if (x_264 == 0) +{ +lean_object* x_265; uint8_t x_266; +x_265 = lean_ctor_get(x_261, 2); +lean_dec(x_265); +x_266 = !lean_is_exclusive(x_262); +if (x_266 == 0) +{ +lean_object* x_267; lean_object* x_268; +x_267 = lean_ctor_get(x_262, 2); +lean_dec(x_267); +lean_ctor_set(x_262, 2, x_259); +if (lean_is_scalar(x_252)) { + x_268 = lean_alloc_ctor(1, 2, 0); +} else { + x_268 = x_252; + lean_ctor_set_tag(x_268, 1); +} +lean_ctor_set(x_268, 0, x_263); +lean_ctor_set(x_268, 1, x_261); +return x_268; +} +else +{ +lean_object* x_269; lean_object* x_270; lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; +x_269 = lean_ctor_get(x_262, 0); +x_270 = lean_ctor_get(x_262, 1); +x_271 = lean_ctor_get(x_262, 3); +x_272 = lean_ctor_get(x_262, 4); +lean_inc(x_272); lean_inc(x_271); -if (lean_is_exclusive(x_252)) { - lean_ctor_release(x_252, 0); - lean_ctor_release(x_252, 1); - lean_ctor_release(x_252, 2); - lean_ctor_release(x_252, 3); - x_272 = x_252; -} else { - lean_dec_ref(x_252); - x_272 = lean_box(0); -} -if (lean_is_scalar(x_272)) { - x_273 = lean_alloc_ctor(0, 4, 0); -} else { - x_273 = x_272; -} +lean_inc(x_270); +lean_inc(x_269); +lean_dec(x_262); +x_273 = lean_alloc_ctor(0, 5, 0); lean_ctor_set(x_273, 0, x_269); lean_ctor_set(x_273, 1, x_270); -lean_ctor_set(x_273, 2, x_249); +lean_ctor_set(x_273, 2, x_259); lean_ctor_set(x_273, 3, x_271); -x_274 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_274, 0, x_264); -lean_ctor_set(x_274, 1, x_265); -lean_ctor_set(x_274, 2, x_273); -lean_ctor_set(x_274, 3, x_266); -lean_ctor_set(x_274, 4, x_267); -lean_ctor_set(x_274, 5, x_268); -if (lean_is_scalar(x_242)) { - x_275 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_273, 4, x_272); +lean_ctor_set(x_261, 2, x_273); +if (lean_is_scalar(x_252)) { + x_274 = lean_alloc_ctor(1, 2, 0); } else { - x_275 = x_242; - lean_ctor_set_tag(x_275, 1); + x_274 = x_252; + lean_ctor_set_tag(x_274, 1); } -lean_ctor_set(x_275, 0, x_253); -lean_ctor_set(x_275, 1, x_274); -return x_275; +lean_ctor_set(x_274, 0, x_263); +lean_ctor_set(x_274, 1, x_261); +return x_274; } } else { -lean_object* x_276; lean_object* x_277; uint8_t x_278; -x_276 = lean_ctor_get(x_251, 2); -lean_inc(x_276); -x_277 = lean_ctor_get(x_250, 0); +lean_object* x_275; lean_object* x_276; lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; lean_object* x_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; lean_object* x_285; lean_object* x_286; lean_object* x_287; +x_275 = lean_ctor_get(x_261, 0); +x_276 = lean_ctor_get(x_261, 1); +x_277 = lean_ctor_get(x_261, 3); +x_278 = lean_ctor_get(x_261, 4); +x_279 = lean_ctor_get(x_261, 5); +lean_inc(x_279); +lean_inc(x_278); lean_inc(x_277); -lean_dec(x_250); -x_278 = !lean_is_exclusive(x_251); -if (x_278 == 0) -{ -lean_object* x_279; uint8_t x_280; -x_279 = lean_ctor_get(x_251, 2); -lean_dec(x_279); -x_280 = !lean_is_exclusive(x_276); -if (x_280 == 0) -{ -lean_object* x_281; lean_object* x_282; -x_281 = lean_ctor_get(x_276, 2); -lean_dec(x_281); -lean_ctor_set(x_276, 2, x_249); -if (lean_is_scalar(x_242)) { - x_282 = lean_alloc_ctor(0, 2, 0); -} else { - x_282 = x_242; -} -lean_ctor_set(x_282, 0, x_277); -lean_ctor_set(x_282, 1, x_251); -return x_282; -} -else -{ -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_276, 0); -x_284 = lean_ctor_get(x_276, 1); -x_285 = lean_ctor_get(x_276, 3); -lean_inc(x_285); -lean_inc(x_284); +lean_inc(x_276); +lean_inc(x_275); +lean_dec(x_261); +x_280 = lean_ctor_get(x_262, 0); +lean_inc(x_280); +x_281 = lean_ctor_get(x_262, 1); +lean_inc(x_281); +x_282 = lean_ctor_get(x_262, 3); +lean_inc(x_282); +x_283 = lean_ctor_get(x_262, 4); lean_inc(x_283); -lean_dec(x_276); -x_286 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_286, 0, x_283); -lean_ctor_set(x_286, 1, x_284); -lean_ctor_set(x_286, 2, x_249); -lean_ctor_set(x_286, 3, x_285); -lean_ctor_set(x_251, 2, x_286); -if (lean_is_scalar(x_242)) { - x_287 = lean_alloc_ctor(0, 2, 0); +if (lean_is_exclusive(x_262)) { + lean_ctor_release(x_262, 0); + lean_ctor_release(x_262, 1); + lean_ctor_release(x_262, 2); + lean_ctor_release(x_262, 3); + lean_ctor_release(x_262, 4); + x_284 = x_262; } else { - x_287 = x_242; + lean_dec_ref(x_262); + x_284 = lean_box(0); } -lean_ctor_set(x_287, 0, x_277); -lean_ctor_set(x_287, 1, x_251); +if (lean_is_scalar(x_284)) { + x_285 = lean_alloc_ctor(0, 5, 0); +} else { + x_285 = x_284; +} +lean_ctor_set(x_285, 0, x_280); +lean_ctor_set(x_285, 1, x_281); +lean_ctor_set(x_285, 2, x_259); +lean_ctor_set(x_285, 3, x_282); +lean_ctor_set(x_285, 4, x_283); +x_286 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_286, 0, x_275); +lean_ctor_set(x_286, 1, x_276); +lean_ctor_set(x_286, 2, x_285); +lean_ctor_set(x_286, 3, x_277); +lean_ctor_set(x_286, 4, x_278); +lean_ctor_set(x_286, 5, x_279); +if (lean_is_scalar(x_252)) { + x_287 = lean_alloc_ctor(1, 2, 0); +} else { + x_287 = x_252; + lean_ctor_set_tag(x_287, 1); +} +lean_ctor_set(x_287, 0, x_263); +lean_ctor_set(x_287, 1, x_286); return x_287; } } else { -lean_object* x_288; lean_object* x_289; lean_object* x_290; lean_object* x_291; lean_object* x_292; lean_object* x_293; lean_object* x_294; lean_object* x_295; lean_object* x_296; lean_object* x_297; lean_object* x_298; lean_object* x_299; -x_288 = lean_ctor_get(x_251, 0); -x_289 = lean_ctor_get(x_251, 1); -x_290 = lean_ctor_get(x_251, 3); -x_291 = lean_ctor_get(x_251, 4); -x_292 = lean_ctor_get(x_251, 5); -lean_inc(x_292); -lean_inc(x_291); -lean_inc(x_290); -lean_inc(x_289); +lean_object* x_288; lean_object* x_289; uint8_t x_290; +x_288 = lean_ctor_get(x_261, 2); lean_inc(x_288); -lean_dec(x_251); -x_293 = lean_ctor_get(x_276, 0); -lean_inc(x_293); -x_294 = lean_ctor_get(x_276, 1); -lean_inc(x_294); -x_295 = lean_ctor_get(x_276, 3); +x_289 = lean_ctor_get(x_260, 0); +lean_inc(x_289); +lean_dec(x_260); +x_290 = !lean_is_exclusive(x_261); +if (x_290 == 0) +{ +lean_object* x_291; uint8_t x_292; +x_291 = lean_ctor_get(x_261, 2); +lean_dec(x_291); +x_292 = !lean_is_exclusive(x_288); +if (x_292 == 0) +{ +lean_object* x_293; lean_object* x_294; +x_293 = lean_ctor_get(x_288, 2); +lean_dec(x_293); +lean_ctor_set(x_288, 2, x_259); +if (lean_is_scalar(x_252)) { + x_294 = lean_alloc_ctor(0, 2, 0); +} else { + x_294 = x_252; +} +lean_ctor_set(x_294, 0, x_289); +lean_ctor_set(x_294, 1, x_261); +return x_294; +} +else +{ +lean_object* x_295; lean_object* x_296; lean_object* x_297; lean_object* x_298; lean_object* x_299; lean_object* x_300; +x_295 = lean_ctor_get(x_288, 0); +x_296 = lean_ctor_get(x_288, 1); +x_297 = lean_ctor_get(x_288, 3); +x_298 = lean_ctor_get(x_288, 4); +lean_inc(x_298); +lean_inc(x_297); +lean_inc(x_296); lean_inc(x_295); -if (lean_is_exclusive(x_276)) { - lean_ctor_release(x_276, 0); - lean_ctor_release(x_276, 1); - lean_ctor_release(x_276, 2); - lean_ctor_release(x_276, 3); - x_296 = x_276; +lean_dec(x_288); +x_299 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_299, 0, x_295); +lean_ctor_set(x_299, 1, x_296); +lean_ctor_set(x_299, 2, x_259); +lean_ctor_set(x_299, 3, x_297); +lean_ctor_set(x_299, 4, x_298); +lean_ctor_set(x_261, 2, x_299); +if (lean_is_scalar(x_252)) { + x_300 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_276); - x_296 = lean_box(0); + x_300 = x_252; } -if (lean_is_scalar(x_296)) { - x_297 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_300, 0, x_289); +lean_ctor_set(x_300, 1, x_261); +return x_300; +} +} +else +{ +lean_object* x_301; lean_object* x_302; lean_object* x_303; lean_object* x_304; lean_object* x_305; lean_object* x_306; lean_object* x_307; lean_object* x_308; lean_object* x_309; lean_object* x_310; lean_object* x_311; lean_object* x_312; lean_object* x_313; +x_301 = lean_ctor_get(x_261, 0); +x_302 = lean_ctor_get(x_261, 1); +x_303 = lean_ctor_get(x_261, 3); +x_304 = lean_ctor_get(x_261, 4); +x_305 = lean_ctor_get(x_261, 5); +lean_inc(x_305); +lean_inc(x_304); +lean_inc(x_303); +lean_inc(x_302); +lean_inc(x_301); +lean_dec(x_261); +x_306 = lean_ctor_get(x_288, 0); +lean_inc(x_306); +x_307 = lean_ctor_get(x_288, 1); +lean_inc(x_307); +x_308 = lean_ctor_get(x_288, 3); +lean_inc(x_308); +x_309 = lean_ctor_get(x_288, 4); +lean_inc(x_309); +if (lean_is_exclusive(x_288)) { + lean_ctor_release(x_288, 0); + lean_ctor_release(x_288, 1); + lean_ctor_release(x_288, 2); + lean_ctor_release(x_288, 3); + lean_ctor_release(x_288, 4); + x_310 = x_288; } else { - x_297 = x_296; + lean_dec_ref(x_288); + x_310 = lean_box(0); } -lean_ctor_set(x_297, 0, x_293); -lean_ctor_set(x_297, 1, x_294); -lean_ctor_set(x_297, 2, x_249); -lean_ctor_set(x_297, 3, x_295); -x_298 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_298, 0, x_288); -lean_ctor_set(x_298, 1, x_289); -lean_ctor_set(x_298, 2, x_297); -lean_ctor_set(x_298, 3, x_290); -lean_ctor_set(x_298, 4, x_291); -lean_ctor_set(x_298, 5, x_292); -if (lean_is_scalar(x_242)) { - x_299 = lean_alloc_ctor(0, 2, 0); +if (lean_is_scalar(x_310)) { + x_311 = lean_alloc_ctor(0, 5, 0); } else { - x_299 = x_242; + x_311 = x_310; } -lean_ctor_set(x_299, 0, x_277); -lean_ctor_set(x_299, 1, x_298); -return x_299; +lean_ctor_set(x_311, 0, x_306); +lean_ctor_set(x_311, 1, x_307); +lean_ctor_set(x_311, 2, x_259); +lean_ctor_set(x_311, 3, x_308); +lean_ctor_set(x_311, 4, x_309); +x_312 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_312, 0, x_301); +lean_ctor_set(x_312, 1, x_302); +lean_ctor_set(x_312, 2, x_311); +lean_ctor_set(x_312, 3, x_303); +lean_ctor_set(x_312, 4, x_304); +lean_ctor_set(x_312, 5, x_305); +if (lean_is_scalar(x_252)) { + x_313 = lean_alloc_ctor(0, 2, 0); +} else { + x_313 = x_252; +} +lean_ctor_set(x_313, 0, x_289); +lean_ctor_set(x_313, 1, x_312); +return x_313; } } } } else { -lean_object* x_328; lean_object* x_329; lean_object* x_330; lean_object* x_331; lean_object* x_332; lean_object* x_333; lean_object* x_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; lean_object* x_374; lean_object* x_375; lean_object* x_376; -x_328 = lean_ctor_get(x_247, 0); -x_329 = lean_ctor_get(x_247, 1); -x_330 = lean_ctor_get(x_247, 2); -x_331 = lean_ctor_get(x_247, 3); -lean_inc(x_331); -lean_inc(x_330); -lean_inc(x_329); -lean_inc(x_328); -lean_dec(x_247); -x_365 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_366 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_366, 0, x_328); -lean_ctor_set(x_366, 1, x_329); -lean_ctor_set(x_366, 2, x_365); -lean_ctor_set(x_366, 3, x_331); -lean_ctor_set(x_241, 2, x_366); -x_367 = lean_ctor_get(x_4, 0); -lean_inc(x_367); -x_368 = lean_ctor_get(x_4, 1); -lean_inc(x_368); -x_369 = lean_ctor_get(x_4, 2); -lean_inc(x_369); -x_370 = lean_ctor_get(x_4, 3); -lean_inc(x_370); -x_371 = lean_ctor_get(x_4, 4); -lean_inc(x_371); +lean_object* x_342; lean_object* x_343; lean_object* x_344; lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; 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; lean_object* x_391; lean_object* x_392; lean_object* x_393; +x_342 = lean_ctor_get(x_257, 0); +x_343 = lean_ctor_get(x_257, 1); +x_344 = lean_ctor_get(x_257, 2); +x_345 = lean_ctor_get(x_257, 3); +x_346 = lean_ctor_get(x_257, 4); +lean_inc(x_346); +lean_inc(x_345); +lean_inc(x_344); +lean_inc(x_343); +lean_inc(x_342); +lean_dec(x_257); +x_382 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_383 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_383, 0, x_342); +lean_ctor_set(x_383, 1, x_343); +lean_ctor_set(x_383, 2, x_382); +lean_ctor_set(x_383, 3, x_345); +lean_ctor_set(x_383, 4, x_346); +lean_ctor_set(x_251, 2, x_383); +x_384 = lean_ctor_get(x_4, 0); +lean_inc(x_384); +x_385 = lean_ctor_get(x_4, 1); +lean_inc(x_385); +x_386 = lean_ctor_get(x_4, 2); +lean_inc(x_386); +x_387 = lean_ctor_get(x_4, 3); +lean_inc(x_387); +x_388 = lean_ctor_get(x_4, 4); +lean_inc(x_388); if (lean_is_exclusive(x_4)) { lean_ctor_release(x_4, 0); lean_ctor_release(x_4, 1); lean_ctor_release(x_4, 2); lean_ctor_release(x_4, 3); lean_ctor_release(x_4, 4); - x_372 = x_4; + x_389 = x_4; } else { lean_dec_ref(x_4); - x_372 = lean_box(0); + x_389 = lean_box(0); } -x_373 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_373, 0, x_243); -lean_ctor_set(x_373, 1, x_18); -x_374 = lean_array_push(x_369, x_373); -if (lean_is_scalar(x_372)) { - x_375 = lean_alloc_ctor(0, 5, 0); +x_390 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_390, 0, x_253); +lean_ctor_set(x_390, 1, x_18); +x_391 = lean_array_push(x_386, x_390); +if (lean_is_scalar(x_389)) { + x_392 = lean_alloc_ctor(0, 5, 0); } else { - x_375 = x_372; + x_392 = x_389; } -lean_ctor_set(x_375, 0, x_367); -lean_ctor_set(x_375, 1, x_368); -lean_ctor_set(x_375, 2, x_374); -lean_ctor_set(x_375, 3, x_370); -lean_ctor_set(x_375, 4, x_371); -x_376 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__3(x_1, x_2, x_245, x_375, x_241); -if (lean_obj_tag(x_376) == 0) +lean_ctor_set(x_392, 0, x_384); +lean_ctor_set(x_392, 1, x_385); +lean_ctor_set(x_392, 2, x_391); +lean_ctor_set(x_392, 3, x_387); +lean_ctor_set(x_392, 4, x_388); +x_393 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__3(x_1, x_2, x_255, x_392, x_251); +if (lean_obj_tag(x_393) == 0) { -lean_object* x_377; lean_object* x_378; lean_object* x_379; -x_377 = lean_ctor_get(x_376, 0); -lean_inc(x_377); -x_378 = lean_ctor_get(x_376, 1); -lean_inc(x_378); -lean_dec(x_376); -x_379 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_379, 0, x_377); -x_332 = x_379; -x_333 = x_378; -goto block_364; +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_396 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_396, 0, x_394); +x_347 = x_396; +x_348 = x_395; +goto block_381; } else { -lean_object* x_380; lean_object* x_381; lean_object* x_382; -x_380 = lean_ctor_get(x_376, 0); -lean_inc(x_380); -x_381 = lean_ctor_get(x_376, 1); -lean_inc(x_381); -lean_dec(x_376); -x_382 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_382, 0, x_380); -x_332 = x_382; -x_333 = x_381; -goto block_364; +lean_object* x_397; lean_object* x_398; lean_object* x_399; +x_397 = lean_ctor_get(x_393, 0); +lean_inc(x_397); +x_398 = lean_ctor_get(x_393, 1); +lean_inc(x_398); +lean_dec(x_393); +x_399 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_399, 0, x_397); +x_347 = x_399; +x_348 = x_398; +goto block_381; } -block_364: +block_381: { -if (lean_obj_tag(x_332) == 0) +if (lean_obj_tag(x_347) == 0) { -lean_object* x_334; lean_object* x_335; lean_object* x_336; lean_object* x_337; lean_object* x_338; lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; -x_334 = lean_ctor_get(x_333, 2); -lean_inc(x_334); -x_335 = lean_ctor_get(x_332, 0); -lean_inc(x_335); -lean_dec(x_332); -x_336 = lean_ctor_get(x_333, 0); -lean_inc(x_336); -x_337 = lean_ctor_get(x_333, 1); -lean_inc(x_337); -x_338 = lean_ctor_get(x_333, 3); -lean_inc(x_338); -x_339 = lean_ctor_get(x_333, 4); -lean_inc(x_339); -x_340 = lean_ctor_get(x_333, 5); -lean_inc(x_340); -if (lean_is_exclusive(x_333)) { - lean_ctor_release(x_333, 0); - lean_ctor_release(x_333, 1); - lean_ctor_release(x_333, 2); - lean_ctor_release(x_333, 3); - lean_ctor_release(x_333, 4); - lean_ctor_release(x_333, 5); - x_341 = x_333; -} else { - lean_dec_ref(x_333); - x_341 = lean_box(0); -} -x_342 = lean_ctor_get(x_334, 0); -lean_inc(x_342); -x_343 = lean_ctor_get(x_334, 1); -lean_inc(x_343); -x_344 = lean_ctor_get(x_334, 3); -lean_inc(x_344); -if (lean_is_exclusive(x_334)) { - lean_ctor_release(x_334, 0); - lean_ctor_release(x_334, 1); - lean_ctor_release(x_334, 2); - lean_ctor_release(x_334, 3); - x_345 = x_334; -} else { - lean_dec_ref(x_334); - x_345 = lean_box(0); -} -if (lean_is_scalar(x_345)) { - x_346 = lean_alloc_ctor(0, 4, 0); -} else { - x_346 = x_345; -} -lean_ctor_set(x_346, 0, x_342); -lean_ctor_set(x_346, 1, x_343); -lean_ctor_set(x_346, 2, x_330); -lean_ctor_set(x_346, 3, x_344); -if (lean_is_scalar(x_341)) { - x_347 = lean_alloc_ctor(0, 6, 0); -} else { - x_347 = x_341; -} -lean_ctor_set(x_347, 0, x_336); -lean_ctor_set(x_347, 1, x_337); -lean_ctor_set(x_347, 2, x_346); -lean_ctor_set(x_347, 3, x_338); -lean_ctor_set(x_347, 4, x_339); -lean_ctor_set(x_347, 5, x_340); -if (lean_is_scalar(x_242)) { - x_348 = lean_alloc_ctor(1, 2, 0); -} else { - x_348 = x_242; - lean_ctor_set_tag(x_348, 1); -} -lean_ctor_set(x_348, 0, x_335); -lean_ctor_set(x_348, 1, x_347); -return x_348; -} -else -{ -lean_object* x_349; lean_object* x_350; lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; lean_object* x_358; lean_object* x_359; lean_object* x_360; lean_object* x_361; lean_object* x_362; lean_object* x_363; -x_349 = lean_ctor_get(x_333, 2); +lean_object* x_349; lean_object* x_350; lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; 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; +x_349 = lean_ctor_get(x_348, 2); lean_inc(x_349); -x_350 = lean_ctor_get(x_332, 0); +x_350 = lean_ctor_get(x_347, 0); lean_inc(x_350); -lean_dec(x_332); -x_351 = lean_ctor_get(x_333, 0); +lean_dec(x_347); +x_351 = lean_ctor_get(x_348, 0); lean_inc(x_351); -x_352 = lean_ctor_get(x_333, 1); +x_352 = lean_ctor_get(x_348, 1); lean_inc(x_352); -x_353 = lean_ctor_get(x_333, 3); +x_353 = lean_ctor_get(x_348, 3); lean_inc(x_353); -x_354 = lean_ctor_get(x_333, 4); +x_354 = lean_ctor_get(x_348, 4); lean_inc(x_354); -x_355 = lean_ctor_get(x_333, 5); +x_355 = lean_ctor_get(x_348, 5); lean_inc(x_355); -if (lean_is_exclusive(x_333)) { - lean_ctor_release(x_333, 0); - lean_ctor_release(x_333, 1); - lean_ctor_release(x_333, 2); - lean_ctor_release(x_333, 3); - lean_ctor_release(x_333, 4); - lean_ctor_release(x_333, 5); - x_356 = x_333; +if (lean_is_exclusive(x_348)) { + lean_ctor_release(x_348, 0); + lean_ctor_release(x_348, 1); + lean_ctor_release(x_348, 2); + lean_ctor_release(x_348, 3); + lean_ctor_release(x_348, 4); + lean_ctor_release(x_348, 5); + x_356 = x_348; } else { - lean_dec_ref(x_333); + lean_dec_ref(x_348); x_356 = lean_box(0); } x_357 = lean_ctor_get(x_349, 0); @@ -12352,315 +12584,411 @@ x_358 = lean_ctor_get(x_349, 1); lean_inc(x_358); x_359 = lean_ctor_get(x_349, 3); lean_inc(x_359); +x_360 = lean_ctor_get(x_349, 4); +lean_inc(x_360); if (lean_is_exclusive(x_349)) { lean_ctor_release(x_349, 0); lean_ctor_release(x_349, 1); lean_ctor_release(x_349, 2); lean_ctor_release(x_349, 3); - x_360 = x_349; + lean_ctor_release(x_349, 4); + x_361 = x_349; } else { lean_dec_ref(x_349); - x_360 = lean_box(0); + x_361 = lean_box(0); } -if (lean_is_scalar(x_360)) { - x_361 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_361)) { + x_362 = lean_alloc_ctor(0, 5, 0); } else { - x_361 = x_360; + x_362 = x_361; } -lean_ctor_set(x_361, 0, x_357); -lean_ctor_set(x_361, 1, x_358); -lean_ctor_set(x_361, 2, x_330); -lean_ctor_set(x_361, 3, x_359); +lean_ctor_set(x_362, 0, x_357); +lean_ctor_set(x_362, 1, x_358); +lean_ctor_set(x_362, 2, x_344); +lean_ctor_set(x_362, 3, x_359); +lean_ctor_set(x_362, 4, x_360); if (lean_is_scalar(x_356)) { - x_362 = lean_alloc_ctor(0, 6, 0); + x_363 = lean_alloc_ctor(0, 6, 0); } else { - x_362 = x_356; + x_363 = x_356; } -lean_ctor_set(x_362, 0, x_351); -lean_ctor_set(x_362, 1, x_352); -lean_ctor_set(x_362, 2, x_361); -lean_ctor_set(x_362, 3, x_353); -lean_ctor_set(x_362, 4, x_354); -lean_ctor_set(x_362, 5, x_355); -if (lean_is_scalar(x_242)) { - x_363 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_363, 0, x_351); +lean_ctor_set(x_363, 1, x_352); +lean_ctor_set(x_363, 2, x_362); +lean_ctor_set(x_363, 3, x_353); +lean_ctor_set(x_363, 4, x_354); +lean_ctor_set(x_363, 5, x_355); +if (lean_is_scalar(x_252)) { + x_364 = lean_alloc_ctor(1, 2, 0); } else { - x_363 = x_242; + x_364 = x_252; + lean_ctor_set_tag(x_364, 1); } -lean_ctor_set(x_363, 0, x_350); -lean_ctor_set(x_363, 1, x_362); -return x_363; +lean_ctor_set(x_364, 0, x_350); +lean_ctor_set(x_364, 1, x_363); +return x_364; +} +else +{ +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; lean_object* x_374; lean_object* x_375; lean_object* x_376; lean_object* x_377; lean_object* x_378; lean_object* x_379; lean_object* x_380; +x_365 = lean_ctor_get(x_348, 2); +lean_inc(x_365); +x_366 = lean_ctor_get(x_347, 0); +lean_inc(x_366); +lean_dec(x_347); +x_367 = lean_ctor_get(x_348, 0); +lean_inc(x_367); +x_368 = lean_ctor_get(x_348, 1); +lean_inc(x_368); +x_369 = lean_ctor_get(x_348, 3); +lean_inc(x_369); +x_370 = lean_ctor_get(x_348, 4); +lean_inc(x_370); +x_371 = lean_ctor_get(x_348, 5); +lean_inc(x_371); +if (lean_is_exclusive(x_348)) { + lean_ctor_release(x_348, 0); + lean_ctor_release(x_348, 1); + lean_ctor_release(x_348, 2); + lean_ctor_release(x_348, 3); + lean_ctor_release(x_348, 4); + lean_ctor_release(x_348, 5); + x_372 = x_348; +} else { + lean_dec_ref(x_348); + x_372 = lean_box(0); +} +x_373 = lean_ctor_get(x_365, 0); +lean_inc(x_373); +x_374 = lean_ctor_get(x_365, 1); +lean_inc(x_374); +x_375 = lean_ctor_get(x_365, 3); +lean_inc(x_375); +x_376 = lean_ctor_get(x_365, 4); +lean_inc(x_376); +if (lean_is_exclusive(x_365)) { + lean_ctor_release(x_365, 0); + lean_ctor_release(x_365, 1); + lean_ctor_release(x_365, 2); + lean_ctor_release(x_365, 3); + lean_ctor_release(x_365, 4); + x_377 = x_365; +} else { + lean_dec_ref(x_365); + x_377 = lean_box(0); +} +if (lean_is_scalar(x_377)) { + x_378 = lean_alloc_ctor(0, 5, 0); +} else { + x_378 = x_377; +} +lean_ctor_set(x_378, 0, x_373); +lean_ctor_set(x_378, 1, x_374); +lean_ctor_set(x_378, 2, x_344); +lean_ctor_set(x_378, 3, x_375); +lean_ctor_set(x_378, 4, x_376); +if (lean_is_scalar(x_372)) { + x_379 = lean_alloc_ctor(0, 6, 0); +} else { + x_379 = x_372; +} +lean_ctor_set(x_379, 0, x_367); +lean_ctor_set(x_379, 1, x_368); +lean_ctor_set(x_379, 2, x_378); +lean_ctor_set(x_379, 3, x_369); +lean_ctor_set(x_379, 4, x_370); +lean_ctor_set(x_379, 5, x_371); +if (lean_is_scalar(x_252)) { + x_380 = lean_alloc_ctor(0, 2, 0); +} else { + x_380 = x_252; +} +lean_ctor_set(x_380, 0, x_366); +lean_ctor_set(x_380, 1, x_379); +return x_380; } } } } else { -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; lean_object* x_391; lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_427; 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; -x_383 = lean_ctor_get(x_241, 2); -x_384 = lean_ctor_get(x_241, 0); -x_385 = lean_ctor_get(x_241, 1); -x_386 = lean_ctor_get(x_241, 3); -x_387 = lean_ctor_get(x_241, 4); -x_388 = lean_ctor_get(x_241, 5); -lean_inc(x_388); -lean_inc(x_387); -lean_inc(x_386); -lean_inc(x_383); -lean_inc(x_385); -lean_inc(x_384); -lean_dec(x_241); -x_389 = lean_ctor_get(x_383, 0); -lean_inc(x_389); -x_390 = lean_ctor_get(x_383, 1); -lean_inc(x_390); -x_391 = lean_ctor_get(x_383, 2); -lean_inc(x_391); -x_392 = lean_ctor_get(x_383, 3); -lean_inc(x_392); -if (lean_is_exclusive(x_383)) { - lean_ctor_release(x_383, 0); - lean_ctor_release(x_383, 1); - lean_ctor_release(x_383, 2); - lean_ctor_release(x_383, 3); - x_393 = x_383; +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; lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_object* x_412; lean_object* x_413; lean_object* x_447; lean_object* x_448; lean_object* x_449; lean_object* x_450; lean_object* x_451; lean_object* x_452; lean_object* x_453; lean_object* x_454; lean_object* x_455; lean_object* x_456; lean_object* x_457; lean_object* x_458; lean_object* x_459; +x_400 = lean_ctor_get(x_251, 2); +x_401 = lean_ctor_get(x_251, 0); +x_402 = lean_ctor_get(x_251, 1); +x_403 = lean_ctor_get(x_251, 3); +x_404 = lean_ctor_get(x_251, 4); +x_405 = lean_ctor_get(x_251, 5); +lean_inc(x_405); +lean_inc(x_404); +lean_inc(x_403); +lean_inc(x_400); +lean_inc(x_402); +lean_inc(x_401); +lean_dec(x_251); +x_406 = lean_ctor_get(x_400, 0); +lean_inc(x_406); +x_407 = lean_ctor_get(x_400, 1); +lean_inc(x_407); +x_408 = lean_ctor_get(x_400, 2); +lean_inc(x_408); +x_409 = lean_ctor_get(x_400, 3); +lean_inc(x_409); +x_410 = lean_ctor_get(x_400, 4); +lean_inc(x_410); +if (lean_is_exclusive(x_400)) { + lean_ctor_release(x_400, 0); + lean_ctor_release(x_400, 1); + lean_ctor_release(x_400, 2); + lean_ctor_release(x_400, 3); + lean_ctor_release(x_400, 4); + x_411 = x_400; } else { - lean_dec_ref(x_383); - x_393 = lean_box(0); + lean_dec_ref(x_400); + x_411 = lean_box(0); } -x_427 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_393)) { - x_428 = lean_alloc_ctor(0, 4, 0); +x_447 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_411)) { + x_448 = lean_alloc_ctor(0, 5, 0); } else { - x_428 = x_393; + x_448 = x_411; } -lean_ctor_set(x_428, 0, x_389); -lean_ctor_set(x_428, 1, x_390); -lean_ctor_set(x_428, 2, x_427); -lean_ctor_set(x_428, 3, x_392); -x_429 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_429, 0, x_384); -lean_ctor_set(x_429, 1, x_385); -lean_ctor_set(x_429, 2, x_428); -lean_ctor_set(x_429, 3, x_386); -lean_ctor_set(x_429, 4, x_387); -lean_ctor_set(x_429, 5, x_388); -x_430 = lean_ctor_get(x_4, 0); -lean_inc(x_430); -x_431 = lean_ctor_get(x_4, 1); -lean_inc(x_431); -x_432 = lean_ctor_get(x_4, 2); -lean_inc(x_432); -x_433 = lean_ctor_get(x_4, 3); -lean_inc(x_433); -x_434 = lean_ctor_get(x_4, 4); -lean_inc(x_434); +lean_ctor_set(x_448, 0, x_406); +lean_ctor_set(x_448, 1, x_407); +lean_ctor_set(x_448, 2, x_447); +lean_ctor_set(x_448, 3, x_409); +lean_ctor_set(x_448, 4, x_410); +x_449 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_449, 0, x_401); +lean_ctor_set(x_449, 1, x_402); +lean_ctor_set(x_449, 2, x_448); +lean_ctor_set(x_449, 3, x_403); +lean_ctor_set(x_449, 4, x_404); +lean_ctor_set(x_449, 5, x_405); +x_450 = lean_ctor_get(x_4, 0); +lean_inc(x_450); +x_451 = lean_ctor_get(x_4, 1); +lean_inc(x_451); +x_452 = lean_ctor_get(x_4, 2); +lean_inc(x_452); +x_453 = lean_ctor_get(x_4, 3); +lean_inc(x_453); +x_454 = lean_ctor_get(x_4, 4); +lean_inc(x_454); if (lean_is_exclusive(x_4)) { lean_ctor_release(x_4, 0); lean_ctor_release(x_4, 1); lean_ctor_release(x_4, 2); lean_ctor_release(x_4, 3); lean_ctor_release(x_4, 4); - x_435 = x_4; + x_455 = x_4; } else { lean_dec_ref(x_4); - x_435 = lean_box(0); + x_455 = lean_box(0); } -x_436 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_436, 0, x_243); -lean_ctor_set(x_436, 1, x_18); -x_437 = lean_array_push(x_432, x_436); -if (lean_is_scalar(x_435)) { - x_438 = lean_alloc_ctor(0, 5, 0); +x_456 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_456, 0, x_253); +lean_ctor_set(x_456, 1, x_18); +x_457 = lean_array_push(x_452, x_456); +if (lean_is_scalar(x_455)) { + x_458 = lean_alloc_ctor(0, 5, 0); } else { - x_438 = x_435; + x_458 = x_455; } -lean_ctor_set(x_438, 0, x_430); -lean_ctor_set(x_438, 1, x_431); -lean_ctor_set(x_438, 2, x_437); -lean_ctor_set(x_438, 3, x_433); -lean_ctor_set(x_438, 4, x_434); -x_439 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__3(x_1, x_2, x_245, x_438, x_429); -if (lean_obj_tag(x_439) == 0) +lean_ctor_set(x_458, 0, x_450); +lean_ctor_set(x_458, 1, x_451); +lean_ctor_set(x_458, 2, x_457); +lean_ctor_set(x_458, 3, x_453); +lean_ctor_set(x_458, 4, x_454); +x_459 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__3(x_1, x_2, x_255, x_458, x_449); +if (lean_obj_tag(x_459) == 0) { -lean_object* x_440; lean_object* x_441; lean_object* x_442; -x_440 = lean_ctor_get(x_439, 0); -lean_inc(x_440); -x_441 = lean_ctor_get(x_439, 1); -lean_inc(x_441); -lean_dec(x_439); -x_442 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_442, 0, x_440); -x_394 = x_442; -x_395 = x_441; -goto block_426; +lean_object* x_460; lean_object* x_461; lean_object* x_462; +x_460 = lean_ctor_get(x_459, 0); +lean_inc(x_460); +x_461 = lean_ctor_get(x_459, 1); +lean_inc(x_461); +lean_dec(x_459); +x_462 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_462, 0, x_460); +x_412 = x_462; +x_413 = x_461; +goto block_446; } else { -lean_object* x_443; lean_object* x_444; lean_object* x_445; -x_443 = lean_ctor_get(x_439, 0); -lean_inc(x_443); -x_444 = lean_ctor_get(x_439, 1); -lean_inc(x_444); -lean_dec(x_439); -x_445 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_445, 0, x_443); -x_394 = x_445; -x_395 = x_444; -goto block_426; +lean_object* x_463; lean_object* x_464; lean_object* x_465; +x_463 = lean_ctor_get(x_459, 0); +lean_inc(x_463); +x_464 = lean_ctor_get(x_459, 1); +lean_inc(x_464); +lean_dec(x_459); +x_465 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_465, 0, x_463); +x_412 = x_465; +x_413 = x_464; +goto block_446; } -block_426: +block_446: { -if (lean_obj_tag(x_394) == 0) +if (lean_obj_tag(x_412) == 0) { -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; lean_object* x_408; lean_object* x_409; lean_object* x_410; -x_396 = lean_ctor_get(x_395, 2); -lean_inc(x_396); -x_397 = lean_ctor_get(x_394, 0); -lean_inc(x_397); -lean_dec(x_394); -x_398 = lean_ctor_get(x_395, 0); -lean_inc(x_398); -x_399 = lean_ctor_get(x_395, 1); -lean_inc(x_399); -x_400 = lean_ctor_get(x_395, 3); -lean_inc(x_400); -x_401 = lean_ctor_get(x_395, 4); -lean_inc(x_401); -x_402 = lean_ctor_get(x_395, 5); -lean_inc(x_402); -if (lean_is_exclusive(x_395)) { - lean_ctor_release(x_395, 0); - lean_ctor_release(x_395, 1); - lean_ctor_release(x_395, 2); - lean_ctor_release(x_395, 3); - lean_ctor_release(x_395, 4); - lean_ctor_release(x_395, 5); - x_403 = x_395; -} else { - lean_dec_ref(x_395); - x_403 = lean_box(0); -} -x_404 = lean_ctor_get(x_396, 0); -lean_inc(x_404); -x_405 = lean_ctor_get(x_396, 1); -lean_inc(x_405); -x_406 = lean_ctor_get(x_396, 3); -lean_inc(x_406); -if (lean_is_exclusive(x_396)) { - lean_ctor_release(x_396, 0); - lean_ctor_release(x_396, 1); - lean_ctor_release(x_396, 2); - lean_ctor_release(x_396, 3); - x_407 = x_396; -} else { - lean_dec_ref(x_396); - x_407 = lean_box(0); -} -if (lean_is_scalar(x_407)) { - x_408 = lean_alloc_ctor(0, 4, 0); -} else { - x_408 = x_407; -} -lean_ctor_set(x_408, 0, x_404); -lean_ctor_set(x_408, 1, x_405); -lean_ctor_set(x_408, 2, x_391); -lean_ctor_set(x_408, 3, x_406); -if (lean_is_scalar(x_403)) { - x_409 = lean_alloc_ctor(0, 6, 0); -} else { - x_409 = x_403; -} -lean_ctor_set(x_409, 0, x_398); -lean_ctor_set(x_409, 1, x_399); -lean_ctor_set(x_409, 2, x_408); -lean_ctor_set(x_409, 3, x_400); -lean_ctor_set(x_409, 4, x_401); -lean_ctor_set(x_409, 5, x_402); -if (lean_is_scalar(x_242)) { - x_410 = lean_alloc_ctor(1, 2, 0); -} else { - x_410 = x_242; - lean_ctor_set_tag(x_410, 1); -} -lean_ctor_set(x_410, 0, x_397); -lean_ctor_set(x_410, 1, x_409); -return x_410; -} -else -{ -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_395, 2); -lean_inc(x_411); -x_412 = lean_ctor_get(x_394, 0); -lean_inc(x_412); -lean_dec(x_394); -x_413 = lean_ctor_get(x_395, 0); -lean_inc(x_413); -x_414 = lean_ctor_get(x_395, 1); +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; lean_object* x_426; lean_object* x_427; lean_object* x_428; lean_object* x_429; +x_414 = lean_ctor_get(x_413, 2); lean_inc(x_414); -x_415 = lean_ctor_get(x_395, 3); +x_415 = lean_ctor_get(x_412, 0); lean_inc(x_415); -x_416 = lean_ctor_get(x_395, 4); +lean_dec(x_412); +x_416 = lean_ctor_get(x_413, 0); lean_inc(x_416); -x_417 = lean_ctor_get(x_395, 5); +x_417 = lean_ctor_get(x_413, 1); lean_inc(x_417); -if (lean_is_exclusive(x_395)) { - lean_ctor_release(x_395, 0); - lean_ctor_release(x_395, 1); - lean_ctor_release(x_395, 2); - lean_ctor_release(x_395, 3); - lean_ctor_release(x_395, 4); - lean_ctor_release(x_395, 5); - x_418 = x_395; -} else { - lean_dec_ref(x_395); - x_418 = lean_box(0); -} -x_419 = lean_ctor_get(x_411, 0); +x_418 = lean_ctor_get(x_413, 3); +lean_inc(x_418); +x_419 = lean_ctor_get(x_413, 4); lean_inc(x_419); -x_420 = lean_ctor_get(x_411, 1); +x_420 = lean_ctor_get(x_413, 5); lean_inc(x_420); -x_421 = lean_ctor_get(x_411, 3); -lean_inc(x_421); -if (lean_is_exclusive(x_411)) { - lean_ctor_release(x_411, 0); - lean_ctor_release(x_411, 1); - lean_ctor_release(x_411, 2); - lean_ctor_release(x_411, 3); - x_422 = x_411; +if (lean_is_exclusive(x_413)) { + lean_ctor_release(x_413, 0); + lean_ctor_release(x_413, 1); + lean_ctor_release(x_413, 2); + lean_ctor_release(x_413, 3); + lean_ctor_release(x_413, 4); + lean_ctor_release(x_413, 5); + x_421 = x_413; } else { - lean_dec_ref(x_411); - x_422 = lean_box(0); + lean_dec_ref(x_413); + x_421 = lean_box(0); } -if (lean_is_scalar(x_422)) { - x_423 = lean_alloc_ctor(0, 4, 0); +x_422 = lean_ctor_get(x_414, 0); +lean_inc(x_422); +x_423 = lean_ctor_get(x_414, 1); +lean_inc(x_423); +x_424 = lean_ctor_get(x_414, 3); +lean_inc(x_424); +x_425 = lean_ctor_get(x_414, 4); +lean_inc(x_425); +if (lean_is_exclusive(x_414)) { + lean_ctor_release(x_414, 0); + lean_ctor_release(x_414, 1); + lean_ctor_release(x_414, 2); + lean_ctor_release(x_414, 3); + lean_ctor_release(x_414, 4); + x_426 = x_414; } else { - x_423 = x_422; + lean_dec_ref(x_414); + x_426 = lean_box(0); } -lean_ctor_set(x_423, 0, x_419); -lean_ctor_set(x_423, 1, x_420); -lean_ctor_set(x_423, 2, x_391); -lean_ctor_set(x_423, 3, x_421); -if (lean_is_scalar(x_418)) { - x_424 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_426)) { + x_427 = lean_alloc_ctor(0, 5, 0); } else { - x_424 = x_418; + x_427 = x_426; } -lean_ctor_set(x_424, 0, x_413); -lean_ctor_set(x_424, 1, x_414); -lean_ctor_set(x_424, 2, x_423); -lean_ctor_set(x_424, 3, x_415); -lean_ctor_set(x_424, 4, x_416); -lean_ctor_set(x_424, 5, x_417); -if (lean_is_scalar(x_242)) { - x_425 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_427, 0, x_422); +lean_ctor_set(x_427, 1, x_423); +lean_ctor_set(x_427, 2, x_408); +lean_ctor_set(x_427, 3, x_424); +lean_ctor_set(x_427, 4, x_425); +if (lean_is_scalar(x_421)) { + x_428 = lean_alloc_ctor(0, 6, 0); } else { - x_425 = x_242; + x_428 = x_421; } -lean_ctor_set(x_425, 0, x_412); -lean_ctor_set(x_425, 1, x_424); -return x_425; +lean_ctor_set(x_428, 0, x_416); +lean_ctor_set(x_428, 1, x_417); +lean_ctor_set(x_428, 2, x_427); +lean_ctor_set(x_428, 3, x_418); +lean_ctor_set(x_428, 4, x_419); +lean_ctor_set(x_428, 5, x_420); +if (lean_is_scalar(x_252)) { + x_429 = lean_alloc_ctor(1, 2, 0); +} else { + x_429 = x_252; + lean_ctor_set_tag(x_429, 1); +} +lean_ctor_set(x_429, 0, x_415); +lean_ctor_set(x_429, 1, x_428); +return x_429; +} +else +{ +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; lean_object* x_445; +x_430 = lean_ctor_get(x_413, 2); +lean_inc(x_430); +x_431 = lean_ctor_get(x_412, 0); +lean_inc(x_431); +lean_dec(x_412); +x_432 = lean_ctor_get(x_413, 0); +lean_inc(x_432); +x_433 = lean_ctor_get(x_413, 1); +lean_inc(x_433); +x_434 = lean_ctor_get(x_413, 3); +lean_inc(x_434); +x_435 = lean_ctor_get(x_413, 4); +lean_inc(x_435); +x_436 = lean_ctor_get(x_413, 5); +lean_inc(x_436); +if (lean_is_exclusive(x_413)) { + lean_ctor_release(x_413, 0); + lean_ctor_release(x_413, 1); + lean_ctor_release(x_413, 2); + lean_ctor_release(x_413, 3); + lean_ctor_release(x_413, 4); + lean_ctor_release(x_413, 5); + x_437 = x_413; +} else { + lean_dec_ref(x_413); + x_437 = lean_box(0); +} +x_438 = lean_ctor_get(x_430, 0); +lean_inc(x_438); +x_439 = lean_ctor_get(x_430, 1); +lean_inc(x_439); +x_440 = lean_ctor_get(x_430, 3); +lean_inc(x_440); +x_441 = lean_ctor_get(x_430, 4); +lean_inc(x_441); +if (lean_is_exclusive(x_430)) { + lean_ctor_release(x_430, 0); + lean_ctor_release(x_430, 1); + lean_ctor_release(x_430, 2); + lean_ctor_release(x_430, 3); + lean_ctor_release(x_430, 4); + x_442 = x_430; +} else { + lean_dec_ref(x_430); + x_442 = lean_box(0); +} +if (lean_is_scalar(x_442)) { + x_443 = lean_alloc_ctor(0, 5, 0); +} else { + x_443 = x_442; +} +lean_ctor_set(x_443, 0, x_438); +lean_ctor_set(x_443, 1, x_439); +lean_ctor_set(x_443, 2, x_408); +lean_ctor_set(x_443, 3, x_440); +lean_ctor_set(x_443, 4, x_441); +if (lean_is_scalar(x_437)) { + x_444 = lean_alloc_ctor(0, 6, 0); +} else { + x_444 = x_437; +} +lean_ctor_set(x_444, 0, x_432); +lean_ctor_set(x_444, 1, x_433); +lean_ctor_set(x_444, 2, x_443); +lean_ctor_set(x_444, 3, x_434); +lean_ctor_set(x_444, 4, x_435); +lean_ctor_set(x_444, 5, x_436); +if (lean_is_scalar(x_252)) { + x_445 = lean_alloc_ctor(0, 2, 0); +} else { + x_445 = x_252; +} +lean_ctor_set(x_445, 0, x_431); +lean_ctor_set(x_445, 1, x_444); +return x_445; } } } @@ -12668,27 +12996,27 @@ return x_425; } else { -uint8_t x_446; +uint8_t x_466; lean_dec(x_18); lean_dec(x_4); lean_dec(x_3); -x_446 = !lean_is_exclusive(x_235); -if (x_446 == 0) +x_466 = !lean_is_exclusive(x_245); +if (x_466 == 0) { -return x_235; +return x_245; } else { -lean_object* x_447; lean_object* x_448; lean_object* x_449; -x_447 = lean_ctor_get(x_235, 0); -x_448 = lean_ctor_get(x_235, 1); -lean_inc(x_448); -lean_inc(x_447); -lean_dec(x_235); -x_449 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_449, 0, x_447); -lean_ctor_set(x_449, 1, x_448); -return x_449; +lean_object* x_467; lean_object* x_468; lean_object* x_469; +x_467 = lean_ctor_get(x_245, 0); +x_468 = lean_ctor_get(x_245, 1); +lean_inc(x_468); +lean_inc(x_467); +lean_dec(x_245); +x_469 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_469, 0, x_467); +lean_ctor_set(x_469, 1, x_468); +return x_469; } } } @@ -12696,54 +13024,54 @@ return x_449; } else { -uint8_t x_450; +uint8_t x_470; lean_dec(x_22); lean_dec(x_18); lean_dec(x_4); lean_dec(x_3); -x_450 = !lean_is_exclusive(x_23); -if (x_450 == 0) +x_470 = !lean_is_exclusive(x_23); +if (x_470 == 0) { return x_23; } else { -lean_object* x_451; lean_object* x_452; lean_object* x_453; -x_451 = lean_ctor_get(x_23, 0); -x_452 = lean_ctor_get(x_23, 1); -lean_inc(x_452); -lean_inc(x_451); +lean_object* x_471; lean_object* x_472; lean_object* x_473; +x_471 = lean_ctor_get(x_23, 0); +x_472 = lean_ctor_get(x_23, 1); +lean_inc(x_472); +lean_inc(x_471); lean_dec(x_23); -x_453 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_453, 0, x_451); -lean_ctor_set(x_453, 1, x_452); -return x_453; +x_473 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_473, 0, x_471); +lean_ctor_set(x_473, 1, x_472); +return x_473; } } } else { -uint8_t x_454; +uint8_t x_474; lean_dec(x_18); lean_dec(x_4); lean_dec(x_3); -x_454 = !lean_is_exclusive(x_19); -if (x_454 == 0) +x_474 = !lean_is_exclusive(x_19); +if (x_474 == 0) { return x_19; } else { -lean_object* x_455; lean_object* x_456; lean_object* x_457; -x_455 = lean_ctor_get(x_19, 0); -x_456 = lean_ctor_get(x_19, 1); -lean_inc(x_456); -lean_inc(x_455); +lean_object* x_475; lean_object* x_476; lean_object* x_477; +x_475 = lean_ctor_get(x_19, 0); +x_476 = lean_ctor_get(x_19, 1); +lean_inc(x_476); +lean_inc(x_475); lean_dec(x_19); -x_457 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_457, 0, x_455); -lean_ctor_set(x_457, 1, x_456); -return x_457; +x_477 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_477, 0, x_475); +lean_ctor_set(x_477, 1, x_476); +return x_477; } } } @@ -12970,105 +13298,105 @@ x_36 = lean_ctor_get(x_30, 2); x_37 = !lean_is_exclusive(x_36); if (x_37 == 0) { -lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_90; uint8_t x_91; +lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_94; uint8_t x_95; x_38 = lean_ctor_get(x_36, 2); -x_90 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_36, 2, x_90); -x_91 = !lean_is_exclusive(x_11); -if (x_91 == 0) +x_94 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_36, 2, x_94); +x_95 = !lean_is_exclusive(x_11); +if (x_95 == 0) { -lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; -x_92 = lean_ctor_get(x_11, 2); -x_93 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_93, 0, x_32); -lean_ctor_set(x_93, 1, x_19); -x_94 = lean_array_push(x_92, x_93); -lean_ctor_set(x_11, 2, x_94); -x_95 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_34, x_11, x_30); -if (lean_obj_tag(x_95) == 0) +lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; +x_96 = lean_ctor_get(x_11, 2); +x_97 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_97, 0, x_32); +lean_ctor_set(x_97, 1, x_19); +x_98 = lean_array_push(x_96, x_97); +lean_ctor_set(x_11, 2, x_98); +x_99 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_34, x_11, x_30); +if (lean_obj_tag(x_99) == 0) { -lean_object* x_96; lean_object* x_97; lean_object* x_98; -x_96 = lean_ctor_get(x_95, 0); -lean_inc(x_96); -x_97 = lean_ctor_get(x_95, 1); -lean_inc(x_97); -lean_dec(x_95); -x_98 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_98, 0, x_96); -x_39 = x_98; -x_40 = x_97; -goto block_89; -} -else -{ -lean_object* x_99; lean_object* x_100; lean_object* x_101; -x_99 = lean_ctor_get(x_95, 0); -lean_inc(x_99); -x_100 = lean_ctor_get(x_95, 1); +lean_object* x_100; lean_object* x_101; lean_object* x_102; +x_100 = lean_ctor_get(x_99, 0); lean_inc(x_100); -lean_dec(x_95); -x_101 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_101, 0, x_99); -x_39 = x_101; -x_40 = x_100; -goto block_89; -} +x_101 = lean_ctor_get(x_99, 1); +lean_inc(x_101); +lean_dec(x_99); +x_102 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_102, 0, x_100); +x_39 = x_102; +x_40 = x_101; +goto block_93; } else { -lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; -x_102 = lean_ctor_get(x_11, 0); -x_103 = lean_ctor_get(x_11, 1); -x_104 = lean_ctor_get(x_11, 2); -x_105 = lean_ctor_get(x_11, 3); -x_106 = lean_ctor_get(x_11, 4); -lean_inc(x_106); -lean_inc(x_105); -lean_inc(x_104); +lean_object* x_103; lean_object* x_104; lean_object* x_105; +x_103 = lean_ctor_get(x_99, 0); lean_inc(x_103); -lean_inc(x_102); -lean_dec(x_11); -x_107 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_107, 0, x_32); -lean_ctor_set(x_107, 1, x_19); -x_108 = lean_array_push(x_104, x_107); -x_109 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_109, 0, x_102); -lean_ctor_set(x_109, 1, x_103); -lean_ctor_set(x_109, 2, x_108); -lean_ctor_set(x_109, 3, x_105); -lean_ctor_set(x_109, 4, x_106); -x_110 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_34, x_109, x_30); -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); -x_113 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_113, 0, x_111); -x_39 = x_113; -x_40 = x_112; -goto block_89; +x_104 = lean_ctor_get(x_99, 1); +lean_inc(x_104); +lean_dec(x_99); +x_105 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_105, 0, x_103); +x_39 = x_105; +x_40 = x_104; +goto block_93; +} } else { -lean_object* x_114; lean_object* x_115; lean_object* x_116; -x_114 = lean_ctor_get(x_110, 0); -lean_inc(x_114); -x_115 = lean_ctor_get(x_110, 1); +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; +x_106 = lean_ctor_get(x_11, 0); +x_107 = lean_ctor_get(x_11, 1); +x_108 = lean_ctor_get(x_11, 2); +x_109 = lean_ctor_get(x_11, 3); +x_110 = lean_ctor_get(x_11, 4); +lean_inc(x_110); +lean_inc(x_109); +lean_inc(x_108); +lean_inc(x_107); +lean_inc(x_106); +lean_dec(x_11); +x_111 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_111, 0, x_32); +lean_ctor_set(x_111, 1, x_19); +x_112 = lean_array_push(x_108, x_111); +x_113 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_113, 0, x_106); +lean_ctor_set(x_113, 1, x_107); +lean_ctor_set(x_113, 2, x_112); +lean_ctor_set(x_113, 3, x_109); +lean_ctor_set(x_113, 4, x_110); +x_114 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_34, x_113, x_30); +if (lean_obj_tag(x_114) == 0) +{ +lean_object* x_115; lean_object* x_116; lean_object* x_117; +x_115 = lean_ctor_get(x_114, 0); lean_inc(x_115); -lean_dec(x_110); -x_116 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_116, 0, x_114); -x_39 = x_116; -x_40 = x_115; -goto block_89; +x_116 = lean_ctor_get(x_114, 1); +lean_inc(x_116); +lean_dec(x_114); +x_117 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_117, 0, x_115); +x_39 = x_117; +x_40 = x_116; +goto block_93; +} +else +{ +lean_object* x_118; lean_object* x_119; lean_object* x_120; +x_118 = lean_ctor_get(x_114, 0); +lean_inc(x_118); +x_119 = lean_ctor_get(x_114, 1); +lean_inc(x_119); +lean_dec(x_114); +x_120 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_120, 0, x_118); +x_39 = x_120; +x_40 = x_119; +goto block_93; } } -block_89: +block_93: { if (lean_obj_tag(x_39) == 0) { @@ -13103,1284 +13431,1262 @@ return x_47; } else { -lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; +lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; x_48 = lean_ctor_get(x_41, 0); x_49 = lean_ctor_get(x_41, 1); x_50 = lean_ctor_get(x_41, 3); +x_51 = lean_ctor_get(x_41, 4); +lean_inc(x_51); lean_inc(x_50); lean_inc(x_49); lean_inc(x_48); lean_dec(x_41); -x_51 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_51, 0, x_48); -lean_ctor_set(x_51, 1, x_49); -lean_ctor_set(x_51, 2, x_38); -lean_ctor_set(x_51, 3, x_50); -lean_ctor_set(x_40, 2, x_51); +x_52 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_52, 0, x_48); +lean_ctor_set(x_52, 1, x_49); +lean_ctor_set(x_52, 2, x_38); +lean_ctor_set(x_52, 3, x_50); +lean_ctor_set(x_52, 4, x_51); +lean_ctor_set(x_40, 2, x_52); if (lean_is_scalar(x_31)) { - x_52 = lean_alloc_ctor(1, 2, 0); + x_53 = lean_alloc_ctor(1, 2, 0); } else { - x_52 = x_31; - lean_ctor_set_tag(x_52, 1); + x_53 = x_31; + lean_ctor_set_tag(x_53, 1); } -lean_ctor_set(x_52, 0, x_42); -lean_ctor_set(x_52, 1, x_40); -return x_52; +lean_ctor_set(x_53, 0, x_42); +lean_ctor_set(x_53, 1, x_40); +return x_53; } } else { -lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; -x_53 = lean_ctor_get(x_40, 0); -x_54 = lean_ctor_get(x_40, 1); -x_55 = lean_ctor_get(x_40, 3); -x_56 = lean_ctor_get(x_40, 4); -x_57 = lean_ctor_get(x_40, 5); +lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; +x_54 = lean_ctor_get(x_40, 0); +x_55 = lean_ctor_get(x_40, 1); +x_56 = lean_ctor_get(x_40, 3); +x_57 = lean_ctor_get(x_40, 4); +x_58 = lean_ctor_get(x_40, 5); +lean_inc(x_58); lean_inc(x_57); lean_inc(x_56); lean_inc(x_55); lean_inc(x_54); -lean_inc(x_53); lean_dec(x_40); -x_58 = lean_ctor_get(x_41, 0); -lean_inc(x_58); -x_59 = lean_ctor_get(x_41, 1); +x_59 = lean_ctor_get(x_41, 0); lean_inc(x_59); -x_60 = lean_ctor_get(x_41, 3); +x_60 = lean_ctor_get(x_41, 1); lean_inc(x_60); +x_61 = lean_ctor_get(x_41, 3); +lean_inc(x_61); +x_62 = lean_ctor_get(x_41, 4); +lean_inc(x_62); if (lean_is_exclusive(x_41)) { lean_ctor_release(x_41, 0); lean_ctor_release(x_41, 1); lean_ctor_release(x_41, 2); lean_ctor_release(x_41, 3); - x_61 = x_41; + lean_ctor_release(x_41, 4); + x_63 = x_41; } else { lean_dec_ref(x_41); - x_61 = lean_box(0); + x_63 = lean_box(0); } -if (lean_is_scalar(x_61)) { - x_62 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_63)) { + x_64 = lean_alloc_ctor(0, 5, 0); } else { - x_62 = x_61; + x_64 = x_63; } -lean_ctor_set(x_62, 0, x_58); -lean_ctor_set(x_62, 1, x_59); -lean_ctor_set(x_62, 2, x_38); -lean_ctor_set(x_62, 3, x_60); -x_63 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_63, 0, x_53); -lean_ctor_set(x_63, 1, x_54); -lean_ctor_set(x_63, 2, x_62); -lean_ctor_set(x_63, 3, x_55); -lean_ctor_set(x_63, 4, x_56); -lean_ctor_set(x_63, 5, x_57); +lean_ctor_set(x_64, 0, x_59); +lean_ctor_set(x_64, 1, x_60); +lean_ctor_set(x_64, 2, x_38); +lean_ctor_set(x_64, 3, x_61); +lean_ctor_set(x_64, 4, x_62); +x_65 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_65, 0, x_54); +lean_ctor_set(x_65, 1, x_55); +lean_ctor_set(x_65, 2, x_64); +lean_ctor_set(x_65, 3, x_56); +lean_ctor_set(x_65, 4, x_57); +lean_ctor_set(x_65, 5, x_58); if (lean_is_scalar(x_31)) { - x_64 = lean_alloc_ctor(1, 2, 0); + x_66 = lean_alloc_ctor(1, 2, 0); } else { - x_64 = x_31; - lean_ctor_set_tag(x_64, 1); + x_66 = x_31; + lean_ctor_set_tag(x_66, 1); } -lean_ctor_set(x_64, 0, x_42); -lean_ctor_set(x_64, 1, x_63); -return x_64; +lean_ctor_set(x_66, 0, x_42); +lean_ctor_set(x_66, 1, x_65); +return x_66; } } else { -lean_object* x_65; lean_object* x_66; uint8_t x_67; -x_65 = lean_ctor_get(x_40, 2); -lean_inc(x_65); -x_66 = lean_ctor_get(x_39, 0); -lean_inc(x_66); +lean_object* x_67; lean_object* x_68; uint8_t x_69; +x_67 = lean_ctor_get(x_40, 2); +lean_inc(x_67); +x_68 = lean_ctor_get(x_39, 0); +lean_inc(x_68); lean_dec(x_39); -x_67 = !lean_is_exclusive(x_40); -if (x_67 == 0) -{ -lean_object* x_68; uint8_t x_69; -x_68 = lean_ctor_get(x_40, 2); -lean_dec(x_68); -x_69 = !lean_is_exclusive(x_65); +x_69 = !lean_is_exclusive(x_40); if (x_69 == 0) { -lean_object* x_70; lean_object* x_71; -x_70 = lean_ctor_get(x_65, 2); +lean_object* x_70; uint8_t x_71; +x_70 = lean_ctor_get(x_40, 2); lean_dec(x_70); -lean_ctor_set(x_65, 2, x_38); +x_71 = !lean_is_exclusive(x_67); +if (x_71 == 0) +{ +lean_object* x_72; lean_object* x_73; +x_72 = lean_ctor_get(x_67, 2); +lean_dec(x_72); +lean_ctor_set(x_67, 2, x_38); if (lean_is_scalar(x_31)) { - x_71 = lean_alloc_ctor(0, 2, 0); + x_73 = lean_alloc_ctor(0, 2, 0); } else { - x_71 = x_31; + x_73 = x_31; } -lean_ctor_set(x_71, 0, x_66); -lean_ctor_set(x_71, 1, x_40); -return x_71; +lean_ctor_set(x_73, 0, x_68); +lean_ctor_set(x_73, 1, x_40); +return x_73; } else { -lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; -x_72 = lean_ctor_get(x_65, 0); -x_73 = lean_ctor_get(x_65, 1); -x_74 = lean_ctor_get(x_65, 3); +lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; +x_74 = lean_ctor_get(x_67, 0); +x_75 = lean_ctor_get(x_67, 1); +x_76 = lean_ctor_get(x_67, 3); +x_77 = lean_ctor_get(x_67, 4); +lean_inc(x_77); +lean_inc(x_76); +lean_inc(x_75); lean_inc(x_74); -lean_inc(x_73); -lean_inc(x_72); -lean_dec(x_65); -x_75 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_75, 0, x_72); -lean_ctor_set(x_75, 1, x_73); -lean_ctor_set(x_75, 2, x_38); -lean_ctor_set(x_75, 3, x_74); -lean_ctor_set(x_40, 2, x_75); +lean_dec(x_67); +x_78 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_78, 0, x_74); +lean_ctor_set(x_78, 1, x_75); +lean_ctor_set(x_78, 2, x_38); +lean_ctor_set(x_78, 3, x_76); +lean_ctor_set(x_78, 4, x_77); +lean_ctor_set(x_40, 2, x_78); if (lean_is_scalar(x_31)) { - x_76 = lean_alloc_ctor(0, 2, 0); + x_79 = lean_alloc_ctor(0, 2, 0); } else { - x_76 = x_31; + x_79 = x_31; } -lean_ctor_set(x_76, 0, x_66); -lean_ctor_set(x_76, 1, x_40); -return x_76; +lean_ctor_set(x_79, 0, x_68); +lean_ctor_set(x_79, 1, x_40); +return x_79; } } else { -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; -x_77 = lean_ctor_get(x_40, 0); -x_78 = lean_ctor_get(x_40, 1); -x_79 = lean_ctor_get(x_40, 3); -x_80 = lean_ctor_get(x_40, 4); -x_81 = lean_ctor_get(x_40, 5); +lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; +x_80 = lean_ctor_get(x_40, 0); +x_81 = lean_ctor_get(x_40, 1); +x_82 = lean_ctor_get(x_40, 3); +x_83 = lean_ctor_get(x_40, 4); +x_84 = lean_ctor_get(x_40, 5); +lean_inc(x_84); +lean_inc(x_83); +lean_inc(x_82); lean_inc(x_81); lean_inc(x_80); -lean_inc(x_79); -lean_inc(x_78); -lean_inc(x_77); lean_dec(x_40); -x_82 = lean_ctor_get(x_65, 0); -lean_inc(x_82); -x_83 = lean_ctor_get(x_65, 1); -lean_inc(x_83); -x_84 = lean_ctor_get(x_65, 3); -lean_inc(x_84); -if (lean_is_exclusive(x_65)) { - lean_ctor_release(x_65, 0); - lean_ctor_release(x_65, 1); - lean_ctor_release(x_65, 2); - lean_ctor_release(x_65, 3); - x_85 = x_65; +x_85 = lean_ctor_get(x_67, 0); +lean_inc(x_85); +x_86 = lean_ctor_get(x_67, 1); +lean_inc(x_86); +x_87 = lean_ctor_get(x_67, 3); +lean_inc(x_87); +x_88 = lean_ctor_get(x_67, 4); +lean_inc(x_88); +if (lean_is_exclusive(x_67)) { + lean_ctor_release(x_67, 0); + lean_ctor_release(x_67, 1); + lean_ctor_release(x_67, 2); + lean_ctor_release(x_67, 3); + lean_ctor_release(x_67, 4); + x_89 = x_67; } else { - lean_dec_ref(x_65); - x_85 = lean_box(0); + lean_dec_ref(x_67); + x_89 = lean_box(0); } -if (lean_is_scalar(x_85)) { - x_86 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_89)) { + x_90 = lean_alloc_ctor(0, 5, 0); } else { - x_86 = x_85; + x_90 = x_89; } -lean_ctor_set(x_86, 0, x_82); -lean_ctor_set(x_86, 1, x_83); -lean_ctor_set(x_86, 2, x_38); -lean_ctor_set(x_86, 3, x_84); -x_87 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_87, 0, x_77); -lean_ctor_set(x_87, 1, x_78); -lean_ctor_set(x_87, 2, x_86); -lean_ctor_set(x_87, 3, x_79); -lean_ctor_set(x_87, 4, x_80); -lean_ctor_set(x_87, 5, x_81); +lean_ctor_set(x_90, 0, x_85); +lean_ctor_set(x_90, 1, x_86); +lean_ctor_set(x_90, 2, x_38); +lean_ctor_set(x_90, 3, x_87); +lean_ctor_set(x_90, 4, x_88); +x_91 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_91, 0, x_80); +lean_ctor_set(x_91, 1, x_81); +lean_ctor_set(x_91, 2, x_90); +lean_ctor_set(x_91, 3, x_82); +lean_ctor_set(x_91, 4, x_83); +lean_ctor_set(x_91, 5, x_84); if (lean_is_scalar(x_31)) { - x_88 = lean_alloc_ctor(0, 2, 0); + x_92 = lean_alloc_ctor(0, 2, 0); } else { - x_88 = x_31; + x_92 = x_31; } -lean_ctor_set(x_88, 0, x_66); -lean_ctor_set(x_88, 1, x_87); -return x_88; +lean_ctor_set(x_92, 0, x_68); +lean_ctor_set(x_92, 1, x_91); +return x_92; } } } } else { -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_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; -x_117 = lean_ctor_get(x_36, 0); -x_118 = lean_ctor_get(x_36, 1); -x_119 = lean_ctor_get(x_36, 2); -x_120 = lean_ctor_get(x_36, 3); -lean_inc(x_120); -lean_inc(x_119); -lean_inc(x_118); -lean_inc(x_117); -lean_dec(x_36); -x_154 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_155 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_155, 0, x_117); -lean_ctor_set(x_155, 1, x_118); -lean_ctor_set(x_155, 2, x_154); -lean_ctor_set(x_155, 3, x_120); -lean_ctor_set(x_30, 2, x_155); -x_156 = lean_ctor_get(x_11, 0); -lean_inc(x_156); -x_157 = lean_ctor_get(x_11, 1); -lean_inc(x_157); -x_158 = lean_ctor_get(x_11, 2); -lean_inc(x_158); -x_159 = lean_ctor_get(x_11, 3); -lean_inc(x_159); -x_160 = lean_ctor_get(x_11, 4); -lean_inc(x_160); -if (lean_is_exclusive(x_11)) { - lean_ctor_release(x_11, 0); - lean_ctor_release(x_11, 1); - lean_ctor_release(x_11, 2); - lean_ctor_release(x_11, 3); - lean_ctor_release(x_11, 4); - x_161 = x_11; -} else { - lean_dec_ref(x_11); - x_161 = lean_box(0); -} -x_162 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_162, 0, x_32); -lean_ctor_set(x_162, 1, x_19); -x_163 = lean_array_push(x_158, x_162); -if (lean_is_scalar(x_161)) { - x_164 = lean_alloc_ctor(0, 5, 0); -} else { - x_164 = x_161; -} -lean_ctor_set(x_164, 0, x_156); -lean_ctor_set(x_164, 1, x_157); -lean_ctor_set(x_164, 2, x_163); -lean_ctor_set(x_164, 3, x_159); -lean_ctor_set(x_164, 4, x_160); -x_165 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_34, x_164, x_30); -if (lean_obj_tag(x_165) == 0) -{ -lean_object* x_166; lean_object* x_167; lean_object* x_168; -x_166 = lean_ctor_get(x_165, 0); -lean_inc(x_166); -x_167 = lean_ctor_get(x_165, 1); -lean_inc(x_167); -lean_dec(x_165); -x_168 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_168, 0, x_166); -x_121 = x_168; -x_122 = x_167; -goto block_153; -} -else -{ -lean_object* x_169; lean_object* x_170; lean_object* x_171; -x_169 = lean_ctor_get(x_165, 0); -lean_inc(x_169); -x_170 = lean_ctor_get(x_165, 1); -lean_inc(x_170); -lean_dec(x_165); -x_171 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_171, 0, x_169); -x_121 = x_171; -x_122 = x_170; -goto block_153; -} -block_153: -{ -if (lean_obj_tag(x_121) == 0) -{ -lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; -x_123 = lean_ctor_get(x_122, 2); -lean_inc(x_123); -x_124 = lean_ctor_get(x_121, 0); -lean_inc(x_124); -lean_dec(x_121); -x_125 = lean_ctor_get(x_122, 0); +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_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; +x_121 = lean_ctor_get(x_36, 0); +x_122 = lean_ctor_get(x_36, 1); +x_123 = lean_ctor_get(x_36, 2); +x_124 = lean_ctor_get(x_36, 3); +x_125 = lean_ctor_get(x_36, 4); lean_inc(x_125); -x_126 = lean_ctor_get(x_122, 1); -lean_inc(x_126); -x_127 = lean_ctor_get(x_122, 3); -lean_inc(x_127); -x_128 = lean_ctor_get(x_122, 4); -lean_inc(x_128); -x_129 = lean_ctor_get(x_122, 5); -lean_inc(x_129); -if (lean_is_exclusive(x_122)) { - lean_ctor_release(x_122, 0); - lean_ctor_release(x_122, 1); - lean_ctor_release(x_122, 2); - lean_ctor_release(x_122, 3); - lean_ctor_release(x_122, 4); - lean_ctor_release(x_122, 5); - x_130 = x_122; -} else { - lean_dec_ref(x_122); - x_130 = lean_box(0); -} -x_131 = lean_ctor_get(x_123, 0); -lean_inc(x_131); -x_132 = lean_ctor_get(x_123, 1); -lean_inc(x_132); -x_133 = lean_ctor_get(x_123, 3); -lean_inc(x_133); -if (lean_is_exclusive(x_123)) { - lean_ctor_release(x_123, 0); - lean_ctor_release(x_123, 1); - lean_ctor_release(x_123, 2); - lean_ctor_release(x_123, 3); - x_134 = x_123; -} else { - lean_dec_ref(x_123); - x_134 = lean_box(0); -} -if (lean_is_scalar(x_134)) { - x_135 = lean_alloc_ctor(0, 4, 0); -} else { - x_135 = x_134; -} -lean_ctor_set(x_135, 0, x_131); -lean_ctor_set(x_135, 1, x_132); -lean_ctor_set(x_135, 2, x_119); -lean_ctor_set(x_135, 3, x_133); -if (lean_is_scalar(x_130)) { - x_136 = lean_alloc_ctor(0, 6, 0); -} else { - x_136 = x_130; -} -lean_ctor_set(x_136, 0, x_125); -lean_ctor_set(x_136, 1, x_126); -lean_ctor_set(x_136, 2, x_135); -lean_ctor_set(x_136, 3, x_127); -lean_ctor_set(x_136, 4, x_128); -lean_ctor_set(x_136, 5, x_129); -if (lean_is_scalar(x_31)) { - x_137 = lean_alloc_ctor(1, 2, 0); -} else { - x_137 = x_31; - lean_ctor_set_tag(x_137, 1); -} -lean_ctor_set(x_137, 0, x_124); -lean_ctor_set(x_137, 1, x_136); -return x_137; -} -else -{ -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; -x_138 = lean_ctor_get(x_122, 2); -lean_inc(x_138); -x_139 = lean_ctor_get(x_121, 0); -lean_inc(x_139); -lean_dec(x_121); -x_140 = lean_ctor_get(x_122, 0); -lean_inc(x_140); -x_141 = lean_ctor_get(x_122, 1); -lean_inc(x_141); -x_142 = lean_ctor_get(x_122, 3); -lean_inc(x_142); -x_143 = lean_ctor_get(x_122, 4); -lean_inc(x_143); -x_144 = lean_ctor_get(x_122, 5); -lean_inc(x_144); -if (lean_is_exclusive(x_122)) { - lean_ctor_release(x_122, 0); - lean_ctor_release(x_122, 1); - lean_ctor_release(x_122, 2); - lean_ctor_release(x_122, 3); - lean_ctor_release(x_122, 4); - lean_ctor_release(x_122, 5); - x_145 = x_122; -} else { - lean_dec_ref(x_122); - x_145 = lean_box(0); -} -x_146 = lean_ctor_get(x_138, 0); -lean_inc(x_146); -x_147 = lean_ctor_get(x_138, 1); -lean_inc(x_147); -x_148 = lean_ctor_get(x_138, 3); -lean_inc(x_148); -if (lean_is_exclusive(x_138)) { - lean_ctor_release(x_138, 0); - lean_ctor_release(x_138, 1); - lean_ctor_release(x_138, 2); - lean_ctor_release(x_138, 3); - x_149 = x_138; -} else { - lean_dec_ref(x_138); - x_149 = lean_box(0); -} -if (lean_is_scalar(x_149)) { - x_150 = lean_alloc_ctor(0, 4, 0); -} else { - x_150 = x_149; -} -lean_ctor_set(x_150, 0, x_146); -lean_ctor_set(x_150, 1, x_147); -lean_ctor_set(x_150, 2, x_119); -lean_ctor_set(x_150, 3, x_148); -if (lean_is_scalar(x_145)) { - x_151 = lean_alloc_ctor(0, 6, 0); -} else { - x_151 = x_145; -} -lean_ctor_set(x_151, 0, x_140); -lean_ctor_set(x_151, 1, x_141); -lean_ctor_set(x_151, 2, x_150); -lean_ctor_set(x_151, 3, x_142); -lean_ctor_set(x_151, 4, x_143); -lean_ctor_set(x_151, 5, x_144); -if (lean_is_scalar(x_31)) { - x_152 = lean_alloc_ctor(0, 2, 0); -} else { - x_152 = x_31; -} -lean_ctor_set(x_152, 0, x_139); -lean_ctor_set(x_152, 1, x_151); -return x_152; -} -} -} -} -else -{ -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; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; lean_object* x_224; lean_object* x_225; lean_object* x_226; lean_object* x_227; lean_object* x_228; -x_172 = lean_ctor_get(x_30, 2); -x_173 = lean_ctor_get(x_30, 0); -x_174 = lean_ctor_get(x_30, 1); -x_175 = lean_ctor_get(x_30, 3); -x_176 = lean_ctor_get(x_30, 4); -x_177 = lean_ctor_get(x_30, 5); -lean_inc(x_177); -lean_inc(x_176); -lean_inc(x_175); -lean_inc(x_172); -lean_inc(x_174); -lean_inc(x_173); -lean_dec(x_30); -x_178 = lean_ctor_get(x_172, 0); -lean_inc(x_178); -x_179 = lean_ctor_get(x_172, 1); -lean_inc(x_179); -x_180 = lean_ctor_get(x_172, 2); -lean_inc(x_180); -x_181 = lean_ctor_get(x_172, 3); -lean_inc(x_181); -if (lean_is_exclusive(x_172)) { - lean_ctor_release(x_172, 0); - lean_ctor_release(x_172, 1); - lean_ctor_release(x_172, 2); - lean_ctor_release(x_172, 3); - x_182 = x_172; -} else { - lean_dec_ref(x_172); - x_182 = lean_box(0); -} -x_216 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_182)) { - x_217 = lean_alloc_ctor(0, 4, 0); -} else { - x_217 = x_182; -} -lean_ctor_set(x_217, 0, x_178); -lean_ctor_set(x_217, 1, x_179); -lean_ctor_set(x_217, 2, x_216); -lean_ctor_set(x_217, 3, x_181); -x_218 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_218, 0, x_173); -lean_ctor_set(x_218, 1, x_174); -lean_ctor_set(x_218, 2, x_217); -lean_ctor_set(x_218, 3, x_175); -lean_ctor_set(x_218, 4, x_176); -lean_ctor_set(x_218, 5, x_177); -x_219 = lean_ctor_get(x_11, 0); -lean_inc(x_219); -x_220 = lean_ctor_get(x_11, 1); -lean_inc(x_220); -x_221 = lean_ctor_get(x_11, 2); -lean_inc(x_221); -x_222 = lean_ctor_get(x_11, 3); -lean_inc(x_222); -x_223 = lean_ctor_get(x_11, 4); -lean_inc(x_223); +lean_inc(x_124); +lean_inc(x_123); +lean_inc(x_122); +lean_inc(x_121); +lean_dec(x_36); +x_161 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_162 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_162, 0, x_121); +lean_ctor_set(x_162, 1, x_122); +lean_ctor_set(x_162, 2, x_161); +lean_ctor_set(x_162, 3, x_124); +lean_ctor_set(x_162, 4, x_125); +lean_ctor_set(x_30, 2, x_162); +x_163 = lean_ctor_get(x_11, 0); +lean_inc(x_163); +x_164 = lean_ctor_get(x_11, 1); +lean_inc(x_164); +x_165 = lean_ctor_get(x_11, 2); +lean_inc(x_165); +x_166 = lean_ctor_get(x_11, 3); +lean_inc(x_166); +x_167 = lean_ctor_get(x_11, 4); +lean_inc(x_167); if (lean_is_exclusive(x_11)) { lean_ctor_release(x_11, 0); lean_ctor_release(x_11, 1); lean_ctor_release(x_11, 2); lean_ctor_release(x_11, 3); lean_ctor_release(x_11, 4); - x_224 = x_11; + x_168 = x_11; } else { lean_dec_ref(x_11); - x_224 = lean_box(0); + x_168 = lean_box(0); } -x_225 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_225, 0, x_32); -lean_ctor_set(x_225, 1, x_19); -x_226 = lean_array_push(x_221, x_225); -if (lean_is_scalar(x_224)) { +x_169 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_169, 0, x_32); +lean_ctor_set(x_169, 1, x_19); +x_170 = lean_array_push(x_165, x_169); +if (lean_is_scalar(x_168)) { + x_171 = lean_alloc_ctor(0, 5, 0); +} else { + x_171 = x_168; +} +lean_ctor_set(x_171, 0, x_163); +lean_ctor_set(x_171, 1, x_164); +lean_ctor_set(x_171, 2, x_170); +lean_ctor_set(x_171, 3, x_166); +lean_ctor_set(x_171, 4, x_167); +x_172 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_34, x_171, x_30); +if (lean_obj_tag(x_172) == 0) +{ +lean_object* x_173; lean_object* x_174; lean_object* x_175; +x_173 = lean_ctor_get(x_172, 0); +lean_inc(x_173); +x_174 = lean_ctor_get(x_172, 1); +lean_inc(x_174); +lean_dec(x_172); +x_175 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_175, 0, x_173); +x_126 = x_175; +x_127 = x_174; +goto block_160; +} +else +{ +lean_object* x_176; lean_object* x_177; lean_object* x_178; +x_176 = lean_ctor_get(x_172, 0); +lean_inc(x_176); +x_177 = lean_ctor_get(x_172, 1); +lean_inc(x_177); +lean_dec(x_172); +x_178 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_178, 0, x_176); +x_126 = x_178; +x_127 = x_177; +goto block_160; +} +block_160: +{ +if (lean_obj_tag(x_126) == 0) +{ +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; +x_128 = lean_ctor_get(x_127, 2); +lean_inc(x_128); +x_129 = lean_ctor_get(x_126, 0); +lean_inc(x_129); +lean_dec(x_126); +x_130 = lean_ctor_get(x_127, 0); +lean_inc(x_130); +x_131 = lean_ctor_get(x_127, 1); +lean_inc(x_131); +x_132 = lean_ctor_get(x_127, 3); +lean_inc(x_132); +x_133 = lean_ctor_get(x_127, 4); +lean_inc(x_133); +x_134 = lean_ctor_get(x_127, 5); +lean_inc(x_134); +if (lean_is_exclusive(x_127)) { + lean_ctor_release(x_127, 0); + lean_ctor_release(x_127, 1); + lean_ctor_release(x_127, 2); + lean_ctor_release(x_127, 3); + lean_ctor_release(x_127, 4); + lean_ctor_release(x_127, 5); + x_135 = x_127; +} else { + lean_dec_ref(x_127); + x_135 = lean_box(0); +} +x_136 = lean_ctor_get(x_128, 0); +lean_inc(x_136); +x_137 = lean_ctor_get(x_128, 1); +lean_inc(x_137); +x_138 = lean_ctor_get(x_128, 3); +lean_inc(x_138); +x_139 = lean_ctor_get(x_128, 4); +lean_inc(x_139); +if (lean_is_exclusive(x_128)) { + lean_ctor_release(x_128, 0); + lean_ctor_release(x_128, 1); + lean_ctor_release(x_128, 2); + lean_ctor_release(x_128, 3); + lean_ctor_release(x_128, 4); + x_140 = x_128; +} else { + lean_dec_ref(x_128); + x_140 = lean_box(0); +} +if (lean_is_scalar(x_140)) { + x_141 = lean_alloc_ctor(0, 5, 0); +} else { + x_141 = x_140; +} +lean_ctor_set(x_141, 0, x_136); +lean_ctor_set(x_141, 1, x_137); +lean_ctor_set(x_141, 2, x_123); +lean_ctor_set(x_141, 3, x_138); +lean_ctor_set(x_141, 4, x_139); +if (lean_is_scalar(x_135)) { + x_142 = lean_alloc_ctor(0, 6, 0); +} else { + x_142 = x_135; +} +lean_ctor_set(x_142, 0, x_130); +lean_ctor_set(x_142, 1, x_131); +lean_ctor_set(x_142, 2, x_141); +lean_ctor_set(x_142, 3, x_132); +lean_ctor_set(x_142, 4, x_133); +lean_ctor_set(x_142, 5, x_134); +if (lean_is_scalar(x_31)) { + x_143 = lean_alloc_ctor(1, 2, 0); +} else { + x_143 = x_31; + lean_ctor_set_tag(x_143, 1); +} +lean_ctor_set(x_143, 0, x_129); +lean_ctor_set(x_143, 1, x_142); +return x_143; +} +else +{ +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; +x_144 = lean_ctor_get(x_127, 2); +lean_inc(x_144); +x_145 = lean_ctor_get(x_126, 0); +lean_inc(x_145); +lean_dec(x_126); +x_146 = lean_ctor_get(x_127, 0); +lean_inc(x_146); +x_147 = lean_ctor_get(x_127, 1); +lean_inc(x_147); +x_148 = lean_ctor_get(x_127, 3); +lean_inc(x_148); +x_149 = lean_ctor_get(x_127, 4); +lean_inc(x_149); +x_150 = lean_ctor_get(x_127, 5); +lean_inc(x_150); +if (lean_is_exclusive(x_127)) { + lean_ctor_release(x_127, 0); + lean_ctor_release(x_127, 1); + lean_ctor_release(x_127, 2); + lean_ctor_release(x_127, 3); + lean_ctor_release(x_127, 4); + lean_ctor_release(x_127, 5); + x_151 = x_127; +} else { + lean_dec_ref(x_127); + x_151 = lean_box(0); +} +x_152 = lean_ctor_get(x_144, 0); +lean_inc(x_152); +x_153 = lean_ctor_get(x_144, 1); +lean_inc(x_153); +x_154 = lean_ctor_get(x_144, 3); +lean_inc(x_154); +x_155 = lean_ctor_get(x_144, 4); +lean_inc(x_155); +if (lean_is_exclusive(x_144)) { + lean_ctor_release(x_144, 0); + lean_ctor_release(x_144, 1); + lean_ctor_release(x_144, 2); + lean_ctor_release(x_144, 3); + lean_ctor_release(x_144, 4); + x_156 = x_144; +} else { + lean_dec_ref(x_144); + x_156 = lean_box(0); +} +if (lean_is_scalar(x_156)) { + x_157 = lean_alloc_ctor(0, 5, 0); +} else { + x_157 = x_156; +} +lean_ctor_set(x_157, 0, x_152); +lean_ctor_set(x_157, 1, x_153); +lean_ctor_set(x_157, 2, x_123); +lean_ctor_set(x_157, 3, x_154); +lean_ctor_set(x_157, 4, x_155); +if (lean_is_scalar(x_151)) { + x_158 = lean_alloc_ctor(0, 6, 0); +} else { + x_158 = x_151; +} +lean_ctor_set(x_158, 0, x_146); +lean_ctor_set(x_158, 1, x_147); +lean_ctor_set(x_158, 2, x_157); +lean_ctor_set(x_158, 3, x_148); +lean_ctor_set(x_158, 4, x_149); +lean_ctor_set(x_158, 5, x_150); +if (lean_is_scalar(x_31)) { + x_159 = lean_alloc_ctor(0, 2, 0); +} else { + x_159 = x_31; +} +lean_ctor_set(x_159, 0, x_145); +lean_ctor_set(x_159, 1, x_158); +return x_159; +} +} +} +} +else +{ +lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_226; lean_object* x_227; lean_object* x_228; lean_object* x_229; lean_object* x_230; lean_object* x_231; lean_object* x_232; lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_object* x_236; lean_object* x_237; lean_object* x_238; +x_179 = lean_ctor_get(x_30, 2); +x_180 = lean_ctor_get(x_30, 0); +x_181 = lean_ctor_get(x_30, 1); +x_182 = lean_ctor_get(x_30, 3); +x_183 = lean_ctor_get(x_30, 4); +x_184 = lean_ctor_get(x_30, 5); +lean_inc(x_184); +lean_inc(x_183); +lean_inc(x_182); +lean_inc(x_179); +lean_inc(x_181); +lean_inc(x_180); +lean_dec(x_30); +x_185 = lean_ctor_get(x_179, 0); +lean_inc(x_185); +x_186 = lean_ctor_get(x_179, 1); +lean_inc(x_186); +x_187 = lean_ctor_get(x_179, 2); +lean_inc(x_187); +x_188 = lean_ctor_get(x_179, 3); +lean_inc(x_188); +x_189 = lean_ctor_get(x_179, 4); +lean_inc(x_189); +if (lean_is_exclusive(x_179)) { + lean_ctor_release(x_179, 0); + lean_ctor_release(x_179, 1); + lean_ctor_release(x_179, 2); + lean_ctor_release(x_179, 3); + lean_ctor_release(x_179, 4); + x_190 = x_179; +} else { + lean_dec_ref(x_179); + x_190 = lean_box(0); +} +x_226 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_190)) { x_227 = lean_alloc_ctor(0, 5, 0); } else { - x_227 = x_224; + x_227 = x_190; } -lean_ctor_set(x_227, 0, x_219); -lean_ctor_set(x_227, 1, x_220); +lean_ctor_set(x_227, 0, x_185); +lean_ctor_set(x_227, 1, x_186); lean_ctor_set(x_227, 2, x_226); -lean_ctor_set(x_227, 3, x_222); -lean_ctor_set(x_227, 4, x_223); -x_228 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_34, x_227, x_218); -if (lean_obj_tag(x_228) == 0) -{ -lean_object* x_229; lean_object* x_230; lean_object* x_231; -x_229 = lean_ctor_get(x_228, 0); +lean_ctor_set(x_227, 3, x_188); +lean_ctor_set(x_227, 4, x_189); +x_228 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_228, 0, x_180); +lean_ctor_set(x_228, 1, x_181); +lean_ctor_set(x_228, 2, x_227); +lean_ctor_set(x_228, 3, x_182); +lean_ctor_set(x_228, 4, x_183); +lean_ctor_set(x_228, 5, x_184); +x_229 = lean_ctor_get(x_11, 0); lean_inc(x_229); -x_230 = lean_ctor_get(x_228, 1); +x_230 = lean_ctor_get(x_11, 1); lean_inc(x_230); -lean_dec(x_228); -x_231 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_231, 0, x_229); -x_183 = x_231; -x_184 = x_230; -goto block_215; -} -else -{ -lean_object* x_232; lean_object* x_233; lean_object* x_234; -x_232 = lean_ctor_get(x_228, 0); +x_231 = lean_ctor_get(x_11, 2); +lean_inc(x_231); +x_232 = lean_ctor_get(x_11, 3); lean_inc(x_232); -x_233 = lean_ctor_get(x_228, 1); +x_233 = lean_ctor_get(x_11, 4); lean_inc(x_233); -lean_dec(x_228); -x_234 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_234, 0, x_232); -x_183 = x_234; -x_184 = x_233; -goto block_215; +if (lean_is_exclusive(x_11)) { + lean_ctor_release(x_11, 0); + lean_ctor_release(x_11, 1); + lean_ctor_release(x_11, 2); + lean_ctor_release(x_11, 3); + lean_ctor_release(x_11, 4); + x_234 = x_11; +} else { + lean_dec_ref(x_11); + x_234 = lean_box(0); } -block_215: +x_235 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_235, 0, x_32); +lean_ctor_set(x_235, 1, x_19); +x_236 = lean_array_push(x_231, x_235); +if (lean_is_scalar(x_234)) { + x_237 = lean_alloc_ctor(0, 5, 0); +} else { + x_237 = x_234; +} +lean_ctor_set(x_237, 0, x_229); +lean_ctor_set(x_237, 1, x_230); +lean_ctor_set(x_237, 2, x_236); +lean_ctor_set(x_237, 3, x_232); +lean_ctor_set(x_237, 4, x_233); +x_238 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_34, x_237, x_228); +if (lean_obj_tag(x_238) == 0) { -if (lean_obj_tag(x_183) == 0) -{ -lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; -x_185 = lean_ctor_get(x_184, 2); -lean_inc(x_185); -x_186 = lean_ctor_get(x_183, 0); -lean_inc(x_186); -lean_dec(x_183); -x_187 = lean_ctor_get(x_184, 0); -lean_inc(x_187); -x_188 = lean_ctor_get(x_184, 1); -lean_inc(x_188); -x_189 = lean_ctor_get(x_184, 3); -lean_inc(x_189); -x_190 = lean_ctor_get(x_184, 4); -lean_inc(x_190); -x_191 = lean_ctor_get(x_184, 5); -lean_inc(x_191); -if (lean_is_exclusive(x_184)) { - lean_ctor_release(x_184, 0); - lean_ctor_release(x_184, 1); - lean_ctor_release(x_184, 2); - lean_ctor_release(x_184, 3); - lean_ctor_release(x_184, 4); - lean_ctor_release(x_184, 5); - x_192 = x_184; -} else { - lean_dec_ref(x_184); - x_192 = lean_box(0); -} -x_193 = lean_ctor_get(x_185, 0); -lean_inc(x_193); -x_194 = lean_ctor_get(x_185, 1); -lean_inc(x_194); -x_195 = lean_ctor_get(x_185, 3); -lean_inc(x_195); -if (lean_is_exclusive(x_185)) { - lean_ctor_release(x_185, 0); - lean_ctor_release(x_185, 1); - lean_ctor_release(x_185, 2); - lean_ctor_release(x_185, 3); - x_196 = x_185; -} else { - lean_dec_ref(x_185); - x_196 = lean_box(0); -} -if (lean_is_scalar(x_196)) { - x_197 = lean_alloc_ctor(0, 4, 0); -} else { - x_197 = x_196; -} -lean_ctor_set(x_197, 0, x_193); -lean_ctor_set(x_197, 1, x_194); -lean_ctor_set(x_197, 2, x_180); -lean_ctor_set(x_197, 3, x_195); -if (lean_is_scalar(x_192)) { - x_198 = lean_alloc_ctor(0, 6, 0); -} else { - x_198 = x_192; -} -lean_ctor_set(x_198, 0, x_187); -lean_ctor_set(x_198, 1, x_188); -lean_ctor_set(x_198, 2, x_197); -lean_ctor_set(x_198, 3, x_189); -lean_ctor_set(x_198, 4, x_190); -lean_ctor_set(x_198, 5, x_191); -if (lean_is_scalar(x_31)) { - x_199 = lean_alloc_ctor(1, 2, 0); -} else { - x_199 = x_31; - lean_ctor_set_tag(x_199, 1); -} -lean_ctor_set(x_199, 0, x_186); -lean_ctor_set(x_199, 1, x_198); -return x_199; +lean_object* x_239; lean_object* x_240; lean_object* x_241; +x_239 = lean_ctor_get(x_238, 0); +lean_inc(x_239); +x_240 = lean_ctor_get(x_238, 1); +lean_inc(x_240); +lean_dec(x_238); +x_241 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_241, 0, x_239); +x_191 = x_241; +x_192 = x_240; +goto block_225; } else { -lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; -x_200 = lean_ctor_get(x_184, 2); -lean_inc(x_200); -x_201 = lean_ctor_get(x_183, 0); +lean_object* x_242; lean_object* x_243; lean_object* x_244; +x_242 = lean_ctor_get(x_238, 0); +lean_inc(x_242); +x_243 = lean_ctor_get(x_238, 1); +lean_inc(x_243); +lean_dec(x_238); +x_244 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_244, 0, x_242); +x_191 = x_244; +x_192 = x_243; +goto block_225; +} +block_225: +{ +if (lean_obj_tag(x_191) == 0) +{ +lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; +x_193 = lean_ctor_get(x_192, 2); +lean_inc(x_193); +x_194 = lean_ctor_get(x_191, 0); +lean_inc(x_194); +lean_dec(x_191); +x_195 = lean_ctor_get(x_192, 0); +lean_inc(x_195); +x_196 = lean_ctor_get(x_192, 1); +lean_inc(x_196); +x_197 = lean_ctor_get(x_192, 3); +lean_inc(x_197); +x_198 = lean_ctor_get(x_192, 4); +lean_inc(x_198); +x_199 = lean_ctor_get(x_192, 5); +lean_inc(x_199); +if (lean_is_exclusive(x_192)) { + lean_ctor_release(x_192, 0); + lean_ctor_release(x_192, 1); + lean_ctor_release(x_192, 2); + lean_ctor_release(x_192, 3); + lean_ctor_release(x_192, 4); + lean_ctor_release(x_192, 5); + x_200 = x_192; +} else { + lean_dec_ref(x_192); + x_200 = lean_box(0); +} +x_201 = lean_ctor_get(x_193, 0); lean_inc(x_201); -lean_dec(x_183); -x_202 = lean_ctor_get(x_184, 0); +x_202 = lean_ctor_get(x_193, 1); lean_inc(x_202); -x_203 = lean_ctor_get(x_184, 1); +x_203 = lean_ctor_get(x_193, 3); lean_inc(x_203); -x_204 = lean_ctor_get(x_184, 3); +x_204 = lean_ctor_get(x_193, 4); lean_inc(x_204); -x_205 = lean_ctor_get(x_184, 4); -lean_inc(x_205); -x_206 = lean_ctor_get(x_184, 5); -lean_inc(x_206); -if (lean_is_exclusive(x_184)) { - lean_ctor_release(x_184, 0); - lean_ctor_release(x_184, 1); - lean_ctor_release(x_184, 2); - lean_ctor_release(x_184, 3); - lean_ctor_release(x_184, 4); - lean_ctor_release(x_184, 5); - x_207 = x_184; +if (lean_is_exclusive(x_193)) { + lean_ctor_release(x_193, 0); + lean_ctor_release(x_193, 1); + lean_ctor_release(x_193, 2); + lean_ctor_release(x_193, 3); + lean_ctor_release(x_193, 4); + x_205 = x_193; } else { - lean_dec_ref(x_184); - x_207 = lean_box(0); + lean_dec_ref(x_193); + x_205 = lean_box(0); } -x_208 = lean_ctor_get(x_200, 0); -lean_inc(x_208); -x_209 = lean_ctor_get(x_200, 1); -lean_inc(x_209); -x_210 = lean_ctor_get(x_200, 3); -lean_inc(x_210); -if (lean_is_exclusive(x_200)) { - lean_ctor_release(x_200, 0); - lean_ctor_release(x_200, 1); - lean_ctor_release(x_200, 2); - lean_ctor_release(x_200, 3); - x_211 = x_200; +if (lean_is_scalar(x_205)) { + x_206 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_200); - x_211 = lean_box(0); + x_206 = x_205; } -if (lean_is_scalar(x_211)) { - x_212 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_206, 0, x_201); +lean_ctor_set(x_206, 1, x_202); +lean_ctor_set(x_206, 2, x_187); +lean_ctor_set(x_206, 3, x_203); +lean_ctor_set(x_206, 4, x_204); +if (lean_is_scalar(x_200)) { + x_207 = lean_alloc_ctor(0, 6, 0); } else { - x_212 = x_211; + x_207 = x_200; } -lean_ctor_set(x_212, 0, x_208); -lean_ctor_set(x_212, 1, x_209); -lean_ctor_set(x_212, 2, x_180); -lean_ctor_set(x_212, 3, x_210); -if (lean_is_scalar(x_207)) { - x_213 = lean_alloc_ctor(0, 6, 0); -} else { - x_213 = x_207; -} -lean_ctor_set(x_213, 0, x_202); -lean_ctor_set(x_213, 1, x_203); -lean_ctor_set(x_213, 2, x_212); -lean_ctor_set(x_213, 3, x_204); -lean_ctor_set(x_213, 4, x_205); -lean_ctor_set(x_213, 5, x_206); +lean_ctor_set(x_207, 0, x_195); +lean_ctor_set(x_207, 1, x_196); +lean_ctor_set(x_207, 2, x_206); +lean_ctor_set(x_207, 3, x_197); +lean_ctor_set(x_207, 4, x_198); +lean_ctor_set(x_207, 5, x_199); if (lean_is_scalar(x_31)) { - x_214 = lean_alloc_ctor(0, 2, 0); + x_208 = lean_alloc_ctor(1, 2, 0); } else { - x_214 = x_31; + x_208 = x_31; + lean_ctor_set_tag(x_208, 1); } -lean_ctor_set(x_214, 0, x_201); -lean_ctor_set(x_214, 1, x_213); -return x_214; +lean_ctor_set(x_208, 0, x_194); +lean_ctor_set(x_208, 1, x_207); +return x_208; +} +else +{ +lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; lean_object* x_224; +x_209 = lean_ctor_get(x_192, 2); +lean_inc(x_209); +x_210 = lean_ctor_get(x_191, 0); +lean_inc(x_210); +lean_dec(x_191); +x_211 = lean_ctor_get(x_192, 0); +lean_inc(x_211); +x_212 = lean_ctor_get(x_192, 1); +lean_inc(x_212); +x_213 = lean_ctor_get(x_192, 3); +lean_inc(x_213); +x_214 = lean_ctor_get(x_192, 4); +lean_inc(x_214); +x_215 = lean_ctor_get(x_192, 5); +lean_inc(x_215); +if (lean_is_exclusive(x_192)) { + lean_ctor_release(x_192, 0); + lean_ctor_release(x_192, 1); + lean_ctor_release(x_192, 2); + lean_ctor_release(x_192, 3); + lean_ctor_release(x_192, 4); + lean_ctor_release(x_192, 5); + x_216 = x_192; +} else { + lean_dec_ref(x_192); + x_216 = lean_box(0); +} +x_217 = lean_ctor_get(x_209, 0); +lean_inc(x_217); +x_218 = lean_ctor_get(x_209, 1); +lean_inc(x_218); +x_219 = lean_ctor_get(x_209, 3); +lean_inc(x_219); +x_220 = lean_ctor_get(x_209, 4); +lean_inc(x_220); +if (lean_is_exclusive(x_209)) { + lean_ctor_release(x_209, 0); + lean_ctor_release(x_209, 1); + lean_ctor_release(x_209, 2); + lean_ctor_release(x_209, 3); + lean_ctor_release(x_209, 4); + x_221 = x_209; +} else { + lean_dec_ref(x_209); + x_221 = lean_box(0); +} +if (lean_is_scalar(x_221)) { + x_222 = lean_alloc_ctor(0, 5, 0); +} else { + x_222 = x_221; +} +lean_ctor_set(x_222, 0, x_217); +lean_ctor_set(x_222, 1, x_218); +lean_ctor_set(x_222, 2, x_187); +lean_ctor_set(x_222, 3, x_219); +lean_ctor_set(x_222, 4, x_220); +if (lean_is_scalar(x_216)) { + x_223 = lean_alloc_ctor(0, 6, 0); +} else { + x_223 = x_216; +} +lean_ctor_set(x_223, 0, x_211); +lean_ctor_set(x_223, 1, x_212); +lean_ctor_set(x_223, 2, x_222); +lean_ctor_set(x_223, 3, x_213); +lean_ctor_set(x_223, 4, x_214); +lean_ctor_set(x_223, 5, x_215); +if (lean_is_scalar(x_31)) { + x_224 = lean_alloc_ctor(0, 2, 0); +} else { + x_224 = x_31; +} +lean_ctor_set(x_224, 0, x_210); +lean_ctor_set(x_224, 1, x_223); +return x_224; } } } } default: { -lean_object* x_235; lean_object* x_236; -x_235 = lean_ctor_get(x_24, 1); -lean_inc(x_235); +lean_object* x_245; lean_object* x_246; +x_245 = lean_ctor_get(x_24, 1); +lean_inc(x_245); lean_dec(x_24); lean_inc(x_11); -x_236 = l_Lean_Meta_isClassExpensive___main(x_23, x_11, x_235); -if (lean_obj_tag(x_236) == 0) +x_246 = l_Lean_Meta_isClassExpensive___main(x_23, x_11, x_245); +if (lean_obj_tag(x_246) == 0) { -lean_object* x_237; -x_237 = lean_ctor_get(x_236, 0); -lean_inc(x_237); -if (lean_obj_tag(x_237) == 0) +lean_object* x_247; +x_247 = lean_ctor_get(x_246, 0); +lean_inc(x_247); +if (lean_obj_tag(x_247) == 0) { -lean_object* x_238; lean_object* x_239; lean_object* x_240; +lean_object* x_248; lean_object* x_249; lean_object* x_250; lean_dec(x_19); -x_238 = lean_ctor_get(x_236, 1); -lean_inc(x_238); -lean_dec(x_236); -x_239 = lean_unsigned_to_nat(1u); -x_240 = lean_nat_add(x_10, x_239); +x_248 = lean_ctor_get(x_246, 1); +lean_inc(x_248); +lean_dec(x_246); +x_249 = lean_unsigned_to_nat(1u); +x_250 = lean_nat_add(x_10, x_249); lean_dec(x_10); -x_10 = x_240; -x_12 = x_238; +x_10 = x_250; +x_12 = x_248; goto _start; } else { -lean_object* x_242; lean_object* x_243; lean_object* x_244; lean_object* x_245; lean_object* x_246; uint8_t x_247; -x_242 = lean_ctor_get(x_236, 1); -lean_inc(x_242); -if (lean_is_exclusive(x_236)) { - lean_ctor_release(x_236, 0); - lean_ctor_release(x_236, 1); - x_243 = x_236; +lean_object* x_252; lean_object* x_253; lean_object* x_254; lean_object* x_255; lean_object* x_256; uint8_t x_257; +x_252 = lean_ctor_get(x_246, 1); +lean_inc(x_252); +if (lean_is_exclusive(x_246)) { + lean_ctor_release(x_246, 0); + lean_ctor_release(x_246, 1); + x_253 = x_246; } else { - lean_dec_ref(x_236); - x_243 = lean_box(0); + lean_dec_ref(x_246); + x_253 = lean_box(0); } -x_244 = lean_ctor_get(x_237, 0); -lean_inc(x_244); -lean_dec(x_237); -x_245 = lean_unsigned_to_nat(1u); -x_246 = lean_nat_add(x_10, x_245); -lean_dec(x_10); -x_247 = !lean_is_exclusive(x_242); -if (x_247 == 0) -{ -lean_object* x_248; uint8_t x_249; -x_248 = lean_ctor_get(x_242, 2); -x_249 = !lean_is_exclusive(x_248); -if (x_249 == 0) -{ -lean_object* x_250; lean_object* x_251; lean_object* x_252; lean_object* x_302; uint8_t x_303; -x_250 = lean_ctor_get(x_248, 2); -x_302 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_248, 2, x_302); -x_303 = !lean_is_exclusive(x_11); -if (x_303 == 0) -{ -lean_object* x_304; lean_object* x_305; lean_object* x_306; lean_object* x_307; -x_304 = lean_ctor_get(x_11, 2); -x_305 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_305, 0, x_244); -lean_ctor_set(x_305, 1, x_19); -x_306 = lean_array_push(x_304, x_305); -lean_ctor_set(x_11, 2, x_306); -x_307 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_246, x_11, x_242); -if (lean_obj_tag(x_307) == 0) -{ -lean_object* x_308; lean_object* x_309; lean_object* x_310; -x_308 = lean_ctor_get(x_307, 0); -lean_inc(x_308); -x_309 = lean_ctor_get(x_307, 1); -lean_inc(x_309); -lean_dec(x_307); -x_310 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_310, 0, x_308); -x_251 = x_310; -x_252 = x_309; -goto block_301; -} -else -{ -lean_object* x_311; lean_object* x_312; lean_object* x_313; -x_311 = lean_ctor_get(x_307, 0); -lean_inc(x_311); -x_312 = lean_ctor_get(x_307, 1); -lean_inc(x_312); -lean_dec(x_307); -x_313 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_313, 0, x_311); -x_251 = x_313; -x_252 = x_312; -goto block_301; -} -} -else -{ -lean_object* x_314; lean_object* x_315; lean_object* x_316; lean_object* x_317; lean_object* x_318; lean_object* x_319; lean_object* x_320; lean_object* x_321; lean_object* x_322; -x_314 = lean_ctor_get(x_11, 0); -x_315 = lean_ctor_get(x_11, 1); -x_316 = lean_ctor_get(x_11, 2); -x_317 = lean_ctor_get(x_11, 3); -x_318 = lean_ctor_get(x_11, 4); -lean_inc(x_318); -lean_inc(x_317); -lean_inc(x_316); -lean_inc(x_315); -lean_inc(x_314); -lean_dec(x_11); -x_319 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_319, 0, x_244); -lean_ctor_set(x_319, 1, x_19); -x_320 = lean_array_push(x_316, x_319); -x_321 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_321, 0, x_314); -lean_ctor_set(x_321, 1, x_315); -lean_ctor_set(x_321, 2, x_320); -lean_ctor_set(x_321, 3, x_317); -lean_ctor_set(x_321, 4, x_318); -x_322 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_246, x_321, x_242); -if (lean_obj_tag(x_322) == 0) -{ -lean_object* x_323; lean_object* x_324; lean_object* x_325; -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_alloc_ctor(1, 1, 0); -lean_ctor_set(x_325, 0, x_323); -x_251 = x_325; -x_252 = x_324; -goto block_301; -} -else -{ -lean_object* x_326; lean_object* x_327; lean_object* x_328; -x_326 = lean_ctor_get(x_322, 0); -lean_inc(x_326); -x_327 = lean_ctor_get(x_322, 1); -lean_inc(x_327); -lean_dec(x_322); -x_328 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_328, 0, x_326); -x_251 = x_328; -x_252 = x_327; -goto block_301; -} -} -block_301: -{ -if (lean_obj_tag(x_251) == 0) -{ -lean_object* x_253; lean_object* x_254; uint8_t x_255; -x_253 = lean_ctor_get(x_252, 2); -lean_inc(x_253); -x_254 = lean_ctor_get(x_251, 0); +x_254 = lean_ctor_get(x_247, 0); lean_inc(x_254); -lean_dec(x_251); -x_255 = !lean_is_exclusive(x_252); -if (x_255 == 0) -{ -lean_object* x_256; uint8_t x_257; -x_256 = lean_ctor_get(x_252, 2); -lean_dec(x_256); -x_257 = !lean_is_exclusive(x_253); +lean_dec(x_247); +x_255 = lean_unsigned_to_nat(1u); +x_256 = lean_nat_add(x_10, x_255); +lean_dec(x_10); +x_257 = !lean_is_exclusive(x_252); if (x_257 == 0) { -lean_object* x_258; lean_object* x_259; -x_258 = lean_ctor_get(x_253, 2); -lean_dec(x_258); -lean_ctor_set(x_253, 2, x_250); -if (lean_is_scalar(x_243)) { - x_259 = lean_alloc_ctor(1, 2, 0); -} else { - x_259 = x_243; - lean_ctor_set_tag(x_259, 1); -} -lean_ctor_set(x_259, 0, x_254); -lean_ctor_set(x_259, 1, x_252); -return x_259; +lean_object* x_258; uint8_t x_259; +x_258 = lean_ctor_get(x_252, 2); +x_259 = !lean_is_exclusive(x_258); +if (x_259 == 0) +{ +lean_object* x_260; lean_object* x_261; lean_object* x_262; lean_object* x_316; uint8_t x_317; +x_260 = lean_ctor_get(x_258, 2); +x_316 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_258, 2, x_316); +x_317 = !lean_is_exclusive(x_11); +if (x_317 == 0) +{ +lean_object* x_318; lean_object* x_319; lean_object* x_320; lean_object* x_321; +x_318 = lean_ctor_get(x_11, 2); +x_319 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_319, 0, x_254); +lean_ctor_set(x_319, 1, x_19); +x_320 = lean_array_push(x_318, x_319); +lean_ctor_set(x_11, 2, x_320); +x_321 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_256, x_11, x_252); +if (lean_obj_tag(x_321) == 0) +{ +lean_object* x_322; lean_object* x_323; lean_object* x_324; +x_322 = lean_ctor_get(x_321, 0); +lean_inc(x_322); +x_323 = lean_ctor_get(x_321, 1); +lean_inc(x_323); +lean_dec(x_321); +x_324 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_324, 0, x_322); +x_261 = x_324; +x_262 = x_323; +goto block_315; } else { -lean_object* x_260; lean_object* x_261; lean_object* x_262; lean_object* x_263; lean_object* x_264; -x_260 = lean_ctor_get(x_253, 0); -x_261 = lean_ctor_get(x_253, 1); -x_262 = lean_ctor_get(x_253, 3); -lean_inc(x_262); -lean_inc(x_261); -lean_inc(x_260); -lean_dec(x_253); -x_263 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_263, 0, x_260); -lean_ctor_set(x_263, 1, x_261); -lean_ctor_set(x_263, 2, x_250); -lean_ctor_set(x_263, 3, x_262); -lean_ctor_set(x_252, 2, x_263); -if (lean_is_scalar(x_243)) { - x_264 = lean_alloc_ctor(1, 2, 0); -} else { - x_264 = x_243; - lean_ctor_set_tag(x_264, 1); -} -lean_ctor_set(x_264, 0, x_254); -lean_ctor_set(x_264, 1, x_252); -return x_264; +lean_object* x_325; lean_object* x_326; lean_object* x_327; +x_325 = lean_ctor_get(x_321, 0); +lean_inc(x_325); +x_326 = lean_ctor_get(x_321, 1); +lean_inc(x_326); +lean_dec(x_321); +x_327 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_327, 0, x_325); +x_261 = x_327; +x_262 = x_326; +goto block_315; } } else { -lean_object* x_265; lean_object* x_266; lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_object* x_270; lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_object* x_276; -x_265 = lean_ctor_get(x_252, 0); -x_266 = lean_ctor_get(x_252, 1); -x_267 = lean_ctor_get(x_252, 3); -x_268 = lean_ctor_get(x_252, 4); -x_269 = lean_ctor_get(x_252, 5); -lean_inc(x_269); -lean_inc(x_268); -lean_inc(x_267); -lean_inc(x_266); -lean_inc(x_265); -lean_dec(x_252); -x_270 = lean_ctor_get(x_253, 0); -lean_inc(x_270); -x_271 = lean_ctor_get(x_253, 1); -lean_inc(x_271); -x_272 = lean_ctor_get(x_253, 3); +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; +x_328 = lean_ctor_get(x_11, 0); +x_329 = lean_ctor_get(x_11, 1); +x_330 = lean_ctor_get(x_11, 2); +x_331 = lean_ctor_get(x_11, 3); +x_332 = lean_ctor_get(x_11, 4); +lean_inc(x_332); +lean_inc(x_331); +lean_inc(x_330); +lean_inc(x_329); +lean_inc(x_328); +lean_dec(x_11); +x_333 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_333, 0, x_254); +lean_ctor_set(x_333, 1, x_19); +x_334 = lean_array_push(x_330, x_333); +x_335 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_335, 0, x_328); +lean_ctor_set(x_335, 1, x_329); +lean_ctor_set(x_335, 2, x_334); +lean_ctor_set(x_335, 3, x_331); +lean_ctor_set(x_335, 4, x_332); +x_336 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_256, x_335, x_252); +if (lean_obj_tag(x_336) == 0) +{ +lean_object* x_337; lean_object* x_338; lean_object* x_339; +x_337 = lean_ctor_get(x_336, 0); +lean_inc(x_337); +x_338 = lean_ctor_get(x_336, 1); +lean_inc(x_338); +lean_dec(x_336); +x_339 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_339, 0, x_337); +x_261 = x_339; +x_262 = x_338; +goto block_315; +} +else +{ +lean_object* x_340; lean_object* x_341; lean_object* x_342; +x_340 = lean_ctor_get(x_336, 0); +lean_inc(x_340); +x_341 = lean_ctor_get(x_336, 1); +lean_inc(x_341); +lean_dec(x_336); +x_342 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_342, 0, x_340); +x_261 = x_342; +x_262 = x_341; +goto block_315; +} +} +block_315: +{ +if (lean_obj_tag(x_261) == 0) +{ +lean_object* x_263; lean_object* x_264; uint8_t x_265; +x_263 = lean_ctor_get(x_262, 2); +lean_inc(x_263); +x_264 = lean_ctor_get(x_261, 0); +lean_inc(x_264); +lean_dec(x_261); +x_265 = !lean_is_exclusive(x_262); +if (x_265 == 0) +{ +lean_object* x_266; uint8_t x_267; +x_266 = lean_ctor_get(x_262, 2); +lean_dec(x_266); +x_267 = !lean_is_exclusive(x_263); +if (x_267 == 0) +{ +lean_object* x_268; lean_object* x_269; +x_268 = lean_ctor_get(x_263, 2); +lean_dec(x_268); +lean_ctor_set(x_263, 2, x_260); +if (lean_is_scalar(x_253)) { + x_269 = lean_alloc_ctor(1, 2, 0); +} else { + x_269 = x_253; + lean_ctor_set_tag(x_269, 1); +} +lean_ctor_set(x_269, 0, x_264); +lean_ctor_set(x_269, 1, x_262); +return x_269; +} +else +{ +lean_object* x_270; lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; lean_object* x_275; +x_270 = lean_ctor_get(x_263, 0); +x_271 = lean_ctor_get(x_263, 1); +x_272 = lean_ctor_get(x_263, 3); +x_273 = lean_ctor_get(x_263, 4); +lean_inc(x_273); lean_inc(x_272); -if (lean_is_exclusive(x_253)) { - lean_ctor_release(x_253, 0); - lean_ctor_release(x_253, 1); - lean_ctor_release(x_253, 2); - lean_ctor_release(x_253, 3); - x_273 = x_253; -} else { - lean_dec_ref(x_253); - x_273 = lean_box(0); -} -if (lean_is_scalar(x_273)) { - x_274 = lean_alloc_ctor(0, 4, 0); -} else { - x_274 = x_273; -} +lean_inc(x_271); +lean_inc(x_270); +lean_dec(x_263); +x_274 = lean_alloc_ctor(0, 5, 0); lean_ctor_set(x_274, 0, x_270); lean_ctor_set(x_274, 1, x_271); -lean_ctor_set(x_274, 2, x_250); +lean_ctor_set(x_274, 2, x_260); lean_ctor_set(x_274, 3, x_272); -x_275 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_275, 0, x_265); -lean_ctor_set(x_275, 1, x_266); -lean_ctor_set(x_275, 2, x_274); -lean_ctor_set(x_275, 3, x_267); -lean_ctor_set(x_275, 4, x_268); -lean_ctor_set(x_275, 5, x_269); -if (lean_is_scalar(x_243)) { - x_276 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_274, 4, x_273); +lean_ctor_set(x_262, 2, x_274); +if (lean_is_scalar(x_253)) { + x_275 = lean_alloc_ctor(1, 2, 0); } else { - x_276 = x_243; - lean_ctor_set_tag(x_276, 1); + x_275 = x_253; + lean_ctor_set_tag(x_275, 1); } -lean_ctor_set(x_276, 0, x_254); -lean_ctor_set(x_276, 1, x_275); -return x_276; +lean_ctor_set(x_275, 0, x_264); +lean_ctor_set(x_275, 1, x_262); +return x_275; } } else { -lean_object* x_277; lean_object* x_278; uint8_t x_279; -x_277 = lean_ctor_get(x_252, 2); -lean_inc(x_277); -x_278 = lean_ctor_get(x_251, 0); +lean_object* x_276; lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; lean_object* x_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; +x_276 = lean_ctor_get(x_262, 0); +x_277 = lean_ctor_get(x_262, 1); +x_278 = lean_ctor_get(x_262, 3); +x_279 = lean_ctor_get(x_262, 4); +x_280 = lean_ctor_get(x_262, 5); +lean_inc(x_280); +lean_inc(x_279); lean_inc(x_278); -lean_dec(x_251); -x_279 = !lean_is_exclusive(x_252); -if (x_279 == 0) -{ -lean_object* x_280; uint8_t x_281; -x_280 = lean_ctor_get(x_252, 2); -lean_dec(x_280); -x_281 = !lean_is_exclusive(x_277); -if (x_281 == 0) -{ -lean_object* x_282; lean_object* x_283; -x_282 = lean_ctor_get(x_277, 2); -lean_dec(x_282); -lean_ctor_set(x_277, 2, x_250); -if (lean_is_scalar(x_243)) { - x_283 = lean_alloc_ctor(0, 2, 0); -} else { - x_283 = x_243; -} -lean_ctor_set(x_283, 0, x_278); -lean_ctor_set(x_283, 1, x_252); -return x_283; -} -else -{ -lean_object* x_284; lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; -x_284 = lean_ctor_get(x_277, 0); -x_285 = lean_ctor_get(x_277, 1); -x_286 = lean_ctor_get(x_277, 3); -lean_inc(x_286); -lean_inc(x_285); +lean_inc(x_277); +lean_inc(x_276); +lean_dec(x_262); +x_281 = lean_ctor_get(x_263, 0); +lean_inc(x_281); +x_282 = lean_ctor_get(x_263, 1); +lean_inc(x_282); +x_283 = lean_ctor_get(x_263, 3); +lean_inc(x_283); +x_284 = lean_ctor_get(x_263, 4); lean_inc(x_284); -lean_dec(x_277); -x_287 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_287, 0, x_284); -lean_ctor_set(x_287, 1, x_285); -lean_ctor_set(x_287, 2, x_250); -lean_ctor_set(x_287, 3, x_286); -lean_ctor_set(x_252, 2, x_287); -if (lean_is_scalar(x_243)) { - x_288 = lean_alloc_ctor(0, 2, 0); +if (lean_is_exclusive(x_263)) { + lean_ctor_release(x_263, 0); + lean_ctor_release(x_263, 1); + lean_ctor_release(x_263, 2); + lean_ctor_release(x_263, 3); + lean_ctor_release(x_263, 4); + x_285 = x_263; } else { - x_288 = x_243; + lean_dec_ref(x_263); + x_285 = lean_box(0); } -lean_ctor_set(x_288, 0, x_278); -lean_ctor_set(x_288, 1, x_252); +if (lean_is_scalar(x_285)) { + x_286 = lean_alloc_ctor(0, 5, 0); +} else { + x_286 = x_285; +} +lean_ctor_set(x_286, 0, x_281); +lean_ctor_set(x_286, 1, x_282); +lean_ctor_set(x_286, 2, x_260); +lean_ctor_set(x_286, 3, x_283); +lean_ctor_set(x_286, 4, x_284); +x_287 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_287, 0, x_276); +lean_ctor_set(x_287, 1, x_277); +lean_ctor_set(x_287, 2, x_286); +lean_ctor_set(x_287, 3, x_278); +lean_ctor_set(x_287, 4, x_279); +lean_ctor_set(x_287, 5, x_280); +if (lean_is_scalar(x_253)) { + x_288 = lean_alloc_ctor(1, 2, 0); +} else { + x_288 = x_253; + lean_ctor_set_tag(x_288, 1); +} +lean_ctor_set(x_288, 0, x_264); +lean_ctor_set(x_288, 1, x_287); return x_288; } } else { -lean_object* x_289; lean_object* x_290; lean_object* x_291; lean_object* x_292; lean_object* x_293; lean_object* x_294; lean_object* x_295; lean_object* x_296; lean_object* x_297; lean_object* x_298; lean_object* x_299; lean_object* x_300; -x_289 = lean_ctor_get(x_252, 0); -x_290 = lean_ctor_get(x_252, 1); -x_291 = lean_ctor_get(x_252, 3); -x_292 = lean_ctor_get(x_252, 4); -x_293 = lean_ctor_get(x_252, 5); -lean_inc(x_293); -lean_inc(x_292); -lean_inc(x_291); -lean_inc(x_290); +lean_object* x_289; lean_object* x_290; uint8_t x_291; +x_289 = lean_ctor_get(x_262, 2); lean_inc(x_289); -lean_dec(x_252); -x_294 = lean_ctor_get(x_277, 0); -lean_inc(x_294); -x_295 = lean_ctor_get(x_277, 1); -lean_inc(x_295); -x_296 = lean_ctor_get(x_277, 3); +x_290 = lean_ctor_get(x_261, 0); +lean_inc(x_290); +lean_dec(x_261); +x_291 = !lean_is_exclusive(x_262); +if (x_291 == 0) +{ +lean_object* x_292; uint8_t x_293; +x_292 = lean_ctor_get(x_262, 2); +lean_dec(x_292); +x_293 = !lean_is_exclusive(x_289); +if (x_293 == 0) +{ +lean_object* x_294; lean_object* x_295; +x_294 = lean_ctor_get(x_289, 2); +lean_dec(x_294); +lean_ctor_set(x_289, 2, x_260); +if (lean_is_scalar(x_253)) { + x_295 = lean_alloc_ctor(0, 2, 0); +} else { + x_295 = x_253; +} +lean_ctor_set(x_295, 0, x_290); +lean_ctor_set(x_295, 1, x_262); +return x_295; +} +else +{ +lean_object* x_296; lean_object* x_297; lean_object* x_298; lean_object* x_299; lean_object* x_300; lean_object* x_301; +x_296 = lean_ctor_get(x_289, 0); +x_297 = lean_ctor_get(x_289, 1); +x_298 = lean_ctor_get(x_289, 3); +x_299 = lean_ctor_get(x_289, 4); +lean_inc(x_299); +lean_inc(x_298); +lean_inc(x_297); lean_inc(x_296); -if (lean_is_exclusive(x_277)) { - lean_ctor_release(x_277, 0); - lean_ctor_release(x_277, 1); - lean_ctor_release(x_277, 2); - lean_ctor_release(x_277, 3); - x_297 = x_277; +lean_dec(x_289); +x_300 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_300, 0, x_296); +lean_ctor_set(x_300, 1, x_297); +lean_ctor_set(x_300, 2, x_260); +lean_ctor_set(x_300, 3, x_298); +lean_ctor_set(x_300, 4, x_299); +lean_ctor_set(x_262, 2, x_300); +if (lean_is_scalar(x_253)) { + x_301 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_277); - x_297 = lean_box(0); + x_301 = x_253; } -if (lean_is_scalar(x_297)) { - x_298 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_301, 0, x_290); +lean_ctor_set(x_301, 1, x_262); +return x_301; +} +} +else +{ +lean_object* x_302; lean_object* x_303; lean_object* x_304; lean_object* x_305; lean_object* x_306; lean_object* x_307; lean_object* x_308; lean_object* x_309; lean_object* x_310; lean_object* x_311; lean_object* x_312; lean_object* x_313; lean_object* x_314; +x_302 = lean_ctor_get(x_262, 0); +x_303 = lean_ctor_get(x_262, 1); +x_304 = lean_ctor_get(x_262, 3); +x_305 = lean_ctor_get(x_262, 4); +x_306 = lean_ctor_get(x_262, 5); +lean_inc(x_306); +lean_inc(x_305); +lean_inc(x_304); +lean_inc(x_303); +lean_inc(x_302); +lean_dec(x_262); +x_307 = lean_ctor_get(x_289, 0); +lean_inc(x_307); +x_308 = lean_ctor_get(x_289, 1); +lean_inc(x_308); +x_309 = lean_ctor_get(x_289, 3); +lean_inc(x_309); +x_310 = lean_ctor_get(x_289, 4); +lean_inc(x_310); +if (lean_is_exclusive(x_289)) { + lean_ctor_release(x_289, 0); + lean_ctor_release(x_289, 1); + lean_ctor_release(x_289, 2); + lean_ctor_release(x_289, 3); + lean_ctor_release(x_289, 4); + x_311 = x_289; } else { - x_298 = x_297; + lean_dec_ref(x_289); + x_311 = lean_box(0); } -lean_ctor_set(x_298, 0, x_294); -lean_ctor_set(x_298, 1, x_295); -lean_ctor_set(x_298, 2, x_250); -lean_ctor_set(x_298, 3, x_296); -x_299 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_299, 0, x_289); -lean_ctor_set(x_299, 1, x_290); -lean_ctor_set(x_299, 2, x_298); -lean_ctor_set(x_299, 3, x_291); -lean_ctor_set(x_299, 4, x_292); -lean_ctor_set(x_299, 5, x_293); -if (lean_is_scalar(x_243)) { - x_300 = lean_alloc_ctor(0, 2, 0); +if (lean_is_scalar(x_311)) { + x_312 = lean_alloc_ctor(0, 5, 0); } else { - x_300 = x_243; + x_312 = x_311; } -lean_ctor_set(x_300, 0, x_278); -lean_ctor_set(x_300, 1, x_299); -return x_300; +lean_ctor_set(x_312, 0, x_307); +lean_ctor_set(x_312, 1, x_308); +lean_ctor_set(x_312, 2, x_260); +lean_ctor_set(x_312, 3, x_309); +lean_ctor_set(x_312, 4, x_310); +x_313 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_313, 0, x_302); +lean_ctor_set(x_313, 1, x_303); +lean_ctor_set(x_313, 2, x_312); +lean_ctor_set(x_313, 3, x_304); +lean_ctor_set(x_313, 4, x_305); +lean_ctor_set(x_313, 5, x_306); +if (lean_is_scalar(x_253)) { + x_314 = lean_alloc_ctor(0, 2, 0); +} else { + x_314 = x_253; +} +lean_ctor_set(x_314, 0, x_290); +lean_ctor_set(x_314, 1, x_313); +return x_314; } } } } else { -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_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; lean_object* x_374; lean_object* x_375; lean_object* x_376; lean_object* x_377; -x_329 = lean_ctor_get(x_248, 0); -x_330 = lean_ctor_get(x_248, 1); -x_331 = lean_ctor_get(x_248, 2); -x_332 = lean_ctor_get(x_248, 3); -lean_inc(x_332); -lean_inc(x_331); -lean_inc(x_330); -lean_inc(x_329); -lean_dec(x_248); -x_366 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_367 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_367, 0, x_329); -lean_ctor_set(x_367, 1, x_330); -lean_ctor_set(x_367, 2, x_366); -lean_ctor_set(x_367, 3, x_332); -lean_ctor_set(x_242, 2, x_367); -x_368 = lean_ctor_get(x_11, 0); -lean_inc(x_368); -x_369 = lean_ctor_get(x_11, 1); -lean_inc(x_369); -x_370 = lean_ctor_get(x_11, 2); -lean_inc(x_370); -x_371 = lean_ctor_get(x_11, 3); -lean_inc(x_371); -x_372 = lean_ctor_get(x_11, 4); -lean_inc(x_372); +lean_object* x_343; lean_object* x_344; lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; 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; lean_object* x_391; lean_object* x_392; lean_object* x_393; lean_object* x_394; +x_343 = lean_ctor_get(x_258, 0); +x_344 = lean_ctor_get(x_258, 1); +x_345 = lean_ctor_get(x_258, 2); +x_346 = lean_ctor_get(x_258, 3); +x_347 = lean_ctor_get(x_258, 4); +lean_inc(x_347); +lean_inc(x_346); +lean_inc(x_345); +lean_inc(x_344); +lean_inc(x_343); +lean_dec(x_258); +x_383 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_384 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_384, 0, x_343); +lean_ctor_set(x_384, 1, x_344); +lean_ctor_set(x_384, 2, x_383); +lean_ctor_set(x_384, 3, x_346); +lean_ctor_set(x_384, 4, x_347); +lean_ctor_set(x_252, 2, x_384); +x_385 = lean_ctor_get(x_11, 0); +lean_inc(x_385); +x_386 = lean_ctor_get(x_11, 1); +lean_inc(x_386); +x_387 = lean_ctor_get(x_11, 2); +lean_inc(x_387); +x_388 = lean_ctor_get(x_11, 3); +lean_inc(x_388); +x_389 = lean_ctor_get(x_11, 4); +lean_inc(x_389); if (lean_is_exclusive(x_11)) { lean_ctor_release(x_11, 0); lean_ctor_release(x_11, 1); lean_ctor_release(x_11, 2); lean_ctor_release(x_11, 3); lean_ctor_release(x_11, 4); - x_373 = x_11; + x_390 = x_11; } else { lean_dec_ref(x_11); - x_373 = lean_box(0); + x_390 = lean_box(0); } -x_374 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_374, 0, x_244); -lean_ctor_set(x_374, 1, x_19); -x_375 = lean_array_push(x_370, x_374); -if (lean_is_scalar(x_373)) { - x_376 = lean_alloc_ctor(0, 5, 0); +x_391 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_391, 0, x_254); +lean_ctor_set(x_391, 1, x_19); +x_392 = lean_array_push(x_387, x_391); +if (lean_is_scalar(x_390)) { + x_393 = lean_alloc_ctor(0, 5, 0); } else { - x_376 = x_373; + x_393 = x_390; } -lean_ctor_set(x_376, 0, x_368); -lean_ctor_set(x_376, 1, x_369); -lean_ctor_set(x_376, 2, x_375); -lean_ctor_set(x_376, 3, x_371); -lean_ctor_set(x_376, 4, x_372); -x_377 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_246, x_376, x_242); -if (lean_obj_tag(x_377) == 0) +lean_ctor_set(x_393, 0, x_385); +lean_ctor_set(x_393, 1, x_386); +lean_ctor_set(x_393, 2, x_392); +lean_ctor_set(x_393, 3, x_388); +lean_ctor_set(x_393, 4, x_389); +x_394 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_256, x_393, x_252); +if (lean_obj_tag(x_394) == 0) { -lean_object* x_378; lean_object* x_379; lean_object* x_380; -x_378 = lean_ctor_get(x_377, 0); -lean_inc(x_378); -x_379 = lean_ctor_get(x_377, 1); -lean_inc(x_379); -lean_dec(x_377); -x_380 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_380, 0, x_378); -x_333 = x_380; -x_334 = x_379; -goto block_365; +lean_object* x_395; lean_object* x_396; lean_object* x_397; +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, 1, 0); +lean_ctor_set(x_397, 0, x_395); +x_348 = x_397; +x_349 = x_396; +goto block_382; } else { -lean_object* x_381; lean_object* x_382; lean_object* x_383; -x_381 = lean_ctor_get(x_377, 0); -lean_inc(x_381); -x_382 = lean_ctor_get(x_377, 1); -lean_inc(x_382); -lean_dec(x_377); -x_383 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_383, 0, x_381); -x_333 = x_383; -x_334 = x_382; -goto block_365; +lean_object* x_398; lean_object* x_399; lean_object* x_400; +x_398 = lean_ctor_get(x_394, 0); +lean_inc(x_398); +x_399 = lean_ctor_get(x_394, 1); +lean_inc(x_399); +lean_dec(x_394); +x_400 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_400, 0, x_398); +x_348 = x_400; +x_349 = x_399; +goto block_382; } -block_365: +block_382: { -if (lean_obj_tag(x_333) == 0) +if (lean_obj_tag(x_348) == 0) { -lean_object* x_335; lean_object* x_336; lean_object* x_337; lean_object* x_338; lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; -x_335 = lean_ctor_get(x_334, 2); -lean_inc(x_335); -x_336 = lean_ctor_get(x_333, 0); -lean_inc(x_336); -lean_dec(x_333); -x_337 = lean_ctor_get(x_334, 0); -lean_inc(x_337); -x_338 = lean_ctor_get(x_334, 1); -lean_inc(x_338); -x_339 = lean_ctor_get(x_334, 3); -lean_inc(x_339); -x_340 = lean_ctor_get(x_334, 4); -lean_inc(x_340); -x_341 = lean_ctor_get(x_334, 5); -lean_inc(x_341); -if (lean_is_exclusive(x_334)) { - lean_ctor_release(x_334, 0); - lean_ctor_release(x_334, 1); - lean_ctor_release(x_334, 2); - lean_ctor_release(x_334, 3); - lean_ctor_release(x_334, 4); - lean_ctor_release(x_334, 5); - x_342 = x_334; -} else { - lean_dec_ref(x_334); - x_342 = lean_box(0); -} -x_343 = lean_ctor_get(x_335, 0); -lean_inc(x_343); -x_344 = lean_ctor_get(x_335, 1); -lean_inc(x_344); -x_345 = lean_ctor_get(x_335, 3); -lean_inc(x_345); -if (lean_is_exclusive(x_335)) { - lean_ctor_release(x_335, 0); - lean_ctor_release(x_335, 1); - lean_ctor_release(x_335, 2); - lean_ctor_release(x_335, 3); - x_346 = x_335; -} else { - lean_dec_ref(x_335); - x_346 = lean_box(0); -} -if (lean_is_scalar(x_346)) { - x_347 = lean_alloc_ctor(0, 4, 0); -} else { - x_347 = x_346; -} -lean_ctor_set(x_347, 0, x_343); -lean_ctor_set(x_347, 1, x_344); -lean_ctor_set(x_347, 2, x_331); -lean_ctor_set(x_347, 3, x_345); -if (lean_is_scalar(x_342)) { - x_348 = lean_alloc_ctor(0, 6, 0); -} else { - x_348 = x_342; -} -lean_ctor_set(x_348, 0, x_337); -lean_ctor_set(x_348, 1, x_338); -lean_ctor_set(x_348, 2, x_347); -lean_ctor_set(x_348, 3, x_339); -lean_ctor_set(x_348, 4, x_340); -lean_ctor_set(x_348, 5, x_341); -if (lean_is_scalar(x_243)) { - x_349 = lean_alloc_ctor(1, 2, 0); -} else { - x_349 = x_243; - lean_ctor_set_tag(x_349, 1); -} -lean_ctor_set(x_349, 0, x_336); -lean_ctor_set(x_349, 1, x_348); -return x_349; -} -else -{ -lean_object* x_350; lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; 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; -x_350 = lean_ctor_get(x_334, 2); +lean_object* x_350; lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; 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; +x_350 = lean_ctor_get(x_349, 2); lean_inc(x_350); -x_351 = lean_ctor_get(x_333, 0); +x_351 = lean_ctor_get(x_348, 0); lean_inc(x_351); -lean_dec(x_333); -x_352 = lean_ctor_get(x_334, 0); +lean_dec(x_348); +x_352 = lean_ctor_get(x_349, 0); lean_inc(x_352); -x_353 = lean_ctor_get(x_334, 1); +x_353 = lean_ctor_get(x_349, 1); lean_inc(x_353); -x_354 = lean_ctor_get(x_334, 3); +x_354 = lean_ctor_get(x_349, 3); lean_inc(x_354); -x_355 = lean_ctor_get(x_334, 4); +x_355 = lean_ctor_get(x_349, 4); lean_inc(x_355); -x_356 = lean_ctor_get(x_334, 5); +x_356 = lean_ctor_get(x_349, 5); lean_inc(x_356); -if (lean_is_exclusive(x_334)) { - lean_ctor_release(x_334, 0); - lean_ctor_release(x_334, 1); - lean_ctor_release(x_334, 2); - lean_ctor_release(x_334, 3); - lean_ctor_release(x_334, 4); - lean_ctor_release(x_334, 5); - x_357 = x_334; +if (lean_is_exclusive(x_349)) { + lean_ctor_release(x_349, 0); + lean_ctor_release(x_349, 1); + lean_ctor_release(x_349, 2); + lean_ctor_release(x_349, 3); + lean_ctor_release(x_349, 4); + lean_ctor_release(x_349, 5); + x_357 = x_349; } else { - lean_dec_ref(x_334); + lean_dec_ref(x_349); x_357 = lean_box(0); } x_358 = lean_ctor_get(x_350, 0); @@ -14389,315 +14695,411 @@ x_359 = lean_ctor_get(x_350, 1); lean_inc(x_359); x_360 = lean_ctor_get(x_350, 3); lean_inc(x_360); +x_361 = lean_ctor_get(x_350, 4); +lean_inc(x_361); if (lean_is_exclusive(x_350)) { lean_ctor_release(x_350, 0); lean_ctor_release(x_350, 1); lean_ctor_release(x_350, 2); lean_ctor_release(x_350, 3); - x_361 = x_350; + lean_ctor_release(x_350, 4); + x_362 = x_350; } else { lean_dec_ref(x_350); - x_361 = lean_box(0); + x_362 = lean_box(0); } -if (lean_is_scalar(x_361)) { - x_362 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_362)) { + x_363 = lean_alloc_ctor(0, 5, 0); } else { - x_362 = x_361; + x_363 = x_362; } -lean_ctor_set(x_362, 0, x_358); -lean_ctor_set(x_362, 1, x_359); -lean_ctor_set(x_362, 2, x_331); -lean_ctor_set(x_362, 3, x_360); +lean_ctor_set(x_363, 0, x_358); +lean_ctor_set(x_363, 1, x_359); +lean_ctor_set(x_363, 2, x_345); +lean_ctor_set(x_363, 3, x_360); +lean_ctor_set(x_363, 4, x_361); if (lean_is_scalar(x_357)) { - x_363 = lean_alloc_ctor(0, 6, 0); + x_364 = lean_alloc_ctor(0, 6, 0); } else { - x_363 = x_357; + x_364 = x_357; } -lean_ctor_set(x_363, 0, x_352); -lean_ctor_set(x_363, 1, x_353); -lean_ctor_set(x_363, 2, x_362); -lean_ctor_set(x_363, 3, x_354); -lean_ctor_set(x_363, 4, x_355); -lean_ctor_set(x_363, 5, x_356); -if (lean_is_scalar(x_243)) { - x_364 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_364, 0, x_352); +lean_ctor_set(x_364, 1, x_353); +lean_ctor_set(x_364, 2, x_363); +lean_ctor_set(x_364, 3, x_354); +lean_ctor_set(x_364, 4, x_355); +lean_ctor_set(x_364, 5, x_356); +if (lean_is_scalar(x_253)) { + x_365 = lean_alloc_ctor(1, 2, 0); } else { - x_364 = x_243; + x_365 = x_253; + lean_ctor_set_tag(x_365, 1); } -lean_ctor_set(x_364, 0, x_351); -lean_ctor_set(x_364, 1, x_363); -return x_364; +lean_ctor_set(x_365, 0, x_351); +lean_ctor_set(x_365, 1, x_364); +return x_365; +} +else +{ +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; lean_object* x_374; lean_object* x_375; lean_object* x_376; lean_object* x_377; lean_object* x_378; lean_object* x_379; lean_object* x_380; lean_object* x_381; +x_366 = lean_ctor_get(x_349, 2); +lean_inc(x_366); +x_367 = lean_ctor_get(x_348, 0); +lean_inc(x_367); +lean_dec(x_348); +x_368 = lean_ctor_get(x_349, 0); +lean_inc(x_368); +x_369 = lean_ctor_get(x_349, 1); +lean_inc(x_369); +x_370 = lean_ctor_get(x_349, 3); +lean_inc(x_370); +x_371 = lean_ctor_get(x_349, 4); +lean_inc(x_371); +x_372 = lean_ctor_get(x_349, 5); +lean_inc(x_372); +if (lean_is_exclusive(x_349)) { + lean_ctor_release(x_349, 0); + lean_ctor_release(x_349, 1); + lean_ctor_release(x_349, 2); + lean_ctor_release(x_349, 3); + lean_ctor_release(x_349, 4); + lean_ctor_release(x_349, 5); + x_373 = x_349; +} else { + lean_dec_ref(x_349); + x_373 = lean_box(0); +} +x_374 = lean_ctor_get(x_366, 0); +lean_inc(x_374); +x_375 = lean_ctor_get(x_366, 1); +lean_inc(x_375); +x_376 = lean_ctor_get(x_366, 3); +lean_inc(x_376); +x_377 = lean_ctor_get(x_366, 4); +lean_inc(x_377); +if (lean_is_exclusive(x_366)) { + lean_ctor_release(x_366, 0); + lean_ctor_release(x_366, 1); + lean_ctor_release(x_366, 2); + lean_ctor_release(x_366, 3); + lean_ctor_release(x_366, 4); + x_378 = x_366; +} else { + lean_dec_ref(x_366); + x_378 = lean_box(0); +} +if (lean_is_scalar(x_378)) { + x_379 = lean_alloc_ctor(0, 5, 0); +} else { + x_379 = x_378; +} +lean_ctor_set(x_379, 0, x_374); +lean_ctor_set(x_379, 1, x_375); +lean_ctor_set(x_379, 2, x_345); +lean_ctor_set(x_379, 3, x_376); +lean_ctor_set(x_379, 4, x_377); +if (lean_is_scalar(x_373)) { + x_380 = lean_alloc_ctor(0, 6, 0); +} else { + x_380 = x_373; +} +lean_ctor_set(x_380, 0, x_368); +lean_ctor_set(x_380, 1, x_369); +lean_ctor_set(x_380, 2, x_379); +lean_ctor_set(x_380, 3, x_370); +lean_ctor_set(x_380, 4, x_371); +lean_ctor_set(x_380, 5, x_372); +if (lean_is_scalar(x_253)) { + x_381 = lean_alloc_ctor(0, 2, 0); +} else { + x_381 = x_253; +} +lean_ctor_set(x_381, 0, x_367); +lean_ctor_set(x_381, 1, x_380); +return x_381; } } } } else { -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; lean_object* x_391; lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_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; -x_384 = lean_ctor_get(x_242, 2); -x_385 = lean_ctor_get(x_242, 0); -x_386 = lean_ctor_get(x_242, 1); -x_387 = lean_ctor_get(x_242, 3); -x_388 = lean_ctor_get(x_242, 4); -x_389 = lean_ctor_get(x_242, 5); -lean_inc(x_389); -lean_inc(x_388); -lean_inc(x_387); -lean_inc(x_384); -lean_inc(x_386); -lean_inc(x_385); -lean_dec(x_242); -x_390 = lean_ctor_get(x_384, 0); -lean_inc(x_390); -x_391 = lean_ctor_get(x_384, 1); -lean_inc(x_391); -x_392 = lean_ctor_get(x_384, 2); -lean_inc(x_392); -x_393 = lean_ctor_get(x_384, 3); -lean_inc(x_393); -if (lean_is_exclusive(x_384)) { - lean_ctor_release(x_384, 0); - lean_ctor_release(x_384, 1); - lean_ctor_release(x_384, 2); - lean_ctor_release(x_384, 3); - x_394 = x_384; +lean_object* x_401; lean_object* x_402; lean_object* x_403; lean_object* x_404; lean_object* x_405; lean_object* x_406; lean_object* x_407; lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_object* x_412; lean_object* x_413; lean_object* x_414; lean_object* x_448; lean_object* x_449; lean_object* x_450; lean_object* x_451; lean_object* x_452; lean_object* x_453; lean_object* x_454; lean_object* x_455; lean_object* x_456; lean_object* x_457; lean_object* x_458; lean_object* x_459; lean_object* x_460; +x_401 = lean_ctor_get(x_252, 2); +x_402 = lean_ctor_get(x_252, 0); +x_403 = lean_ctor_get(x_252, 1); +x_404 = lean_ctor_get(x_252, 3); +x_405 = lean_ctor_get(x_252, 4); +x_406 = lean_ctor_get(x_252, 5); +lean_inc(x_406); +lean_inc(x_405); +lean_inc(x_404); +lean_inc(x_401); +lean_inc(x_403); +lean_inc(x_402); +lean_dec(x_252); +x_407 = lean_ctor_get(x_401, 0); +lean_inc(x_407); +x_408 = lean_ctor_get(x_401, 1); +lean_inc(x_408); +x_409 = lean_ctor_get(x_401, 2); +lean_inc(x_409); +x_410 = lean_ctor_get(x_401, 3); +lean_inc(x_410); +x_411 = lean_ctor_get(x_401, 4); +lean_inc(x_411); +if (lean_is_exclusive(x_401)) { + lean_ctor_release(x_401, 0); + lean_ctor_release(x_401, 1); + lean_ctor_release(x_401, 2); + lean_ctor_release(x_401, 3); + lean_ctor_release(x_401, 4); + x_412 = x_401; } else { - lean_dec_ref(x_384); - x_394 = lean_box(0); + lean_dec_ref(x_401); + x_412 = lean_box(0); } -x_428 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_394)) { - x_429 = lean_alloc_ctor(0, 4, 0); +x_448 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_412)) { + x_449 = lean_alloc_ctor(0, 5, 0); } else { - x_429 = x_394; + x_449 = x_412; } -lean_ctor_set(x_429, 0, x_390); -lean_ctor_set(x_429, 1, x_391); -lean_ctor_set(x_429, 2, x_428); -lean_ctor_set(x_429, 3, x_393); -x_430 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_430, 0, x_385); -lean_ctor_set(x_430, 1, x_386); -lean_ctor_set(x_430, 2, x_429); -lean_ctor_set(x_430, 3, x_387); -lean_ctor_set(x_430, 4, x_388); -lean_ctor_set(x_430, 5, x_389); -x_431 = lean_ctor_get(x_11, 0); -lean_inc(x_431); -x_432 = lean_ctor_get(x_11, 1); -lean_inc(x_432); -x_433 = lean_ctor_get(x_11, 2); -lean_inc(x_433); -x_434 = lean_ctor_get(x_11, 3); -lean_inc(x_434); -x_435 = lean_ctor_get(x_11, 4); -lean_inc(x_435); +lean_ctor_set(x_449, 0, x_407); +lean_ctor_set(x_449, 1, x_408); +lean_ctor_set(x_449, 2, x_448); +lean_ctor_set(x_449, 3, x_410); +lean_ctor_set(x_449, 4, x_411); +x_450 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_450, 0, x_402); +lean_ctor_set(x_450, 1, x_403); +lean_ctor_set(x_450, 2, x_449); +lean_ctor_set(x_450, 3, x_404); +lean_ctor_set(x_450, 4, x_405); +lean_ctor_set(x_450, 5, x_406); +x_451 = lean_ctor_get(x_11, 0); +lean_inc(x_451); +x_452 = lean_ctor_get(x_11, 1); +lean_inc(x_452); +x_453 = lean_ctor_get(x_11, 2); +lean_inc(x_453); +x_454 = lean_ctor_get(x_11, 3); +lean_inc(x_454); +x_455 = lean_ctor_get(x_11, 4); +lean_inc(x_455); if (lean_is_exclusive(x_11)) { lean_ctor_release(x_11, 0); lean_ctor_release(x_11, 1); lean_ctor_release(x_11, 2); lean_ctor_release(x_11, 3); lean_ctor_release(x_11, 4); - x_436 = x_11; + x_456 = x_11; } else { lean_dec_ref(x_11); - x_436 = lean_box(0); + x_456 = lean_box(0); } -x_437 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_437, 0, x_244); -lean_ctor_set(x_437, 1, x_19); -x_438 = lean_array_push(x_433, x_437); -if (lean_is_scalar(x_436)) { - x_439 = lean_alloc_ctor(0, 5, 0); +x_457 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_457, 0, x_254); +lean_ctor_set(x_457, 1, x_19); +x_458 = lean_array_push(x_453, x_457); +if (lean_is_scalar(x_456)) { + x_459 = lean_alloc_ctor(0, 5, 0); } else { - x_439 = x_436; + x_459 = x_456; } -lean_ctor_set(x_439, 0, x_431); -lean_ctor_set(x_439, 1, x_432); -lean_ctor_set(x_439, 2, x_438); -lean_ctor_set(x_439, 3, x_434); -lean_ctor_set(x_439, 4, x_435); -x_440 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_246, x_439, x_430); -if (lean_obj_tag(x_440) == 0) +lean_ctor_set(x_459, 0, x_451); +lean_ctor_set(x_459, 1, x_452); +lean_ctor_set(x_459, 2, x_458); +lean_ctor_set(x_459, 3, x_454); +lean_ctor_set(x_459, 4, x_455); +x_460 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_256, x_459, x_450); +if (lean_obj_tag(x_460) == 0) { -lean_object* x_441; lean_object* x_442; lean_object* x_443; -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_443 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_443, 0, x_441); -x_395 = x_443; -x_396 = x_442; -goto block_427; +lean_object* x_461; lean_object* x_462; lean_object* x_463; +x_461 = lean_ctor_get(x_460, 0); +lean_inc(x_461); +x_462 = lean_ctor_get(x_460, 1); +lean_inc(x_462); +lean_dec(x_460); +x_463 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_463, 0, x_461); +x_413 = x_463; +x_414 = x_462; +goto block_447; } else { -lean_object* x_444; lean_object* x_445; lean_object* x_446; -x_444 = lean_ctor_get(x_440, 0); -lean_inc(x_444); -x_445 = lean_ctor_get(x_440, 1); -lean_inc(x_445); -lean_dec(x_440); -x_446 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_446, 0, x_444); -x_395 = x_446; -x_396 = x_445; -goto block_427; +lean_object* x_464; lean_object* x_465; lean_object* x_466; +x_464 = lean_ctor_get(x_460, 0); +lean_inc(x_464); +x_465 = lean_ctor_get(x_460, 1); +lean_inc(x_465); +lean_dec(x_460); +x_466 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_466, 0, x_464); +x_413 = x_466; +x_414 = x_465; +goto block_447; } -block_427: +block_447: { -if (lean_obj_tag(x_395) == 0) +if (lean_obj_tag(x_413) == 0) { -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; lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_411; -x_397 = lean_ctor_get(x_396, 2); -lean_inc(x_397); -x_398 = lean_ctor_get(x_395, 0); -lean_inc(x_398); -lean_dec(x_395); -x_399 = lean_ctor_get(x_396, 0); -lean_inc(x_399); -x_400 = lean_ctor_get(x_396, 1); -lean_inc(x_400); -x_401 = lean_ctor_get(x_396, 3); -lean_inc(x_401); -x_402 = lean_ctor_get(x_396, 4); -lean_inc(x_402); -x_403 = lean_ctor_get(x_396, 5); -lean_inc(x_403); -if (lean_is_exclusive(x_396)) { - lean_ctor_release(x_396, 0); - lean_ctor_release(x_396, 1); - lean_ctor_release(x_396, 2); - lean_ctor_release(x_396, 3); - lean_ctor_release(x_396, 4); - lean_ctor_release(x_396, 5); - x_404 = x_396; -} else { - lean_dec_ref(x_396); - x_404 = lean_box(0); -} -x_405 = lean_ctor_get(x_397, 0); -lean_inc(x_405); -x_406 = lean_ctor_get(x_397, 1); -lean_inc(x_406); -x_407 = lean_ctor_get(x_397, 3); -lean_inc(x_407); -if (lean_is_exclusive(x_397)) { - lean_ctor_release(x_397, 0); - lean_ctor_release(x_397, 1); - lean_ctor_release(x_397, 2); - lean_ctor_release(x_397, 3); - x_408 = x_397; -} else { - lean_dec_ref(x_397); - x_408 = lean_box(0); -} -if (lean_is_scalar(x_408)) { - x_409 = lean_alloc_ctor(0, 4, 0); -} else { - x_409 = x_408; -} -lean_ctor_set(x_409, 0, x_405); -lean_ctor_set(x_409, 1, x_406); -lean_ctor_set(x_409, 2, x_392); -lean_ctor_set(x_409, 3, x_407); -if (lean_is_scalar(x_404)) { - x_410 = lean_alloc_ctor(0, 6, 0); -} else { - x_410 = x_404; -} -lean_ctor_set(x_410, 0, x_399); -lean_ctor_set(x_410, 1, x_400); -lean_ctor_set(x_410, 2, x_409); -lean_ctor_set(x_410, 3, x_401); -lean_ctor_set(x_410, 4, x_402); -lean_ctor_set(x_410, 5, x_403); -if (lean_is_scalar(x_243)) { - x_411 = lean_alloc_ctor(1, 2, 0); -} else { - x_411 = x_243; - lean_ctor_set_tag(x_411, 1); -} -lean_ctor_set(x_411, 0, x_398); -lean_ctor_set(x_411, 1, x_410); -return x_411; -} -else -{ -lean_object* x_412; lean_object* x_413; lean_object* x_414; lean_object* x_415; lean_object* x_416; lean_object* x_417; lean_object* x_418; lean_object* x_419; lean_object* x_420; lean_object* x_421; lean_object* x_422; lean_object* x_423; lean_object* x_424; lean_object* x_425; lean_object* x_426; -x_412 = lean_ctor_get(x_396, 2); -lean_inc(x_412); -x_413 = lean_ctor_get(x_395, 0); -lean_inc(x_413); -lean_dec(x_395); -x_414 = lean_ctor_get(x_396, 0); -lean_inc(x_414); -x_415 = lean_ctor_get(x_396, 1); +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; lean_object* x_426; lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; +x_415 = lean_ctor_get(x_414, 2); lean_inc(x_415); -x_416 = lean_ctor_get(x_396, 3); +x_416 = lean_ctor_get(x_413, 0); lean_inc(x_416); -x_417 = lean_ctor_get(x_396, 4); +lean_dec(x_413); +x_417 = lean_ctor_get(x_414, 0); lean_inc(x_417); -x_418 = lean_ctor_get(x_396, 5); +x_418 = lean_ctor_get(x_414, 1); lean_inc(x_418); -if (lean_is_exclusive(x_396)) { - lean_ctor_release(x_396, 0); - lean_ctor_release(x_396, 1); - lean_ctor_release(x_396, 2); - lean_ctor_release(x_396, 3); - lean_ctor_release(x_396, 4); - lean_ctor_release(x_396, 5); - x_419 = x_396; -} else { - lean_dec_ref(x_396); - x_419 = lean_box(0); -} -x_420 = lean_ctor_get(x_412, 0); +x_419 = lean_ctor_get(x_414, 3); +lean_inc(x_419); +x_420 = lean_ctor_get(x_414, 4); lean_inc(x_420); -x_421 = lean_ctor_get(x_412, 1); +x_421 = lean_ctor_get(x_414, 5); lean_inc(x_421); -x_422 = lean_ctor_get(x_412, 3); -lean_inc(x_422); -if (lean_is_exclusive(x_412)) { - lean_ctor_release(x_412, 0); - lean_ctor_release(x_412, 1); - lean_ctor_release(x_412, 2); - lean_ctor_release(x_412, 3); - x_423 = x_412; +if (lean_is_exclusive(x_414)) { + lean_ctor_release(x_414, 0); + lean_ctor_release(x_414, 1); + lean_ctor_release(x_414, 2); + lean_ctor_release(x_414, 3); + lean_ctor_release(x_414, 4); + lean_ctor_release(x_414, 5); + x_422 = x_414; } else { - lean_dec_ref(x_412); - x_423 = lean_box(0); + lean_dec_ref(x_414); + x_422 = lean_box(0); } -if (lean_is_scalar(x_423)) { - x_424 = lean_alloc_ctor(0, 4, 0); +x_423 = lean_ctor_get(x_415, 0); +lean_inc(x_423); +x_424 = lean_ctor_get(x_415, 1); +lean_inc(x_424); +x_425 = lean_ctor_get(x_415, 3); +lean_inc(x_425); +x_426 = lean_ctor_get(x_415, 4); +lean_inc(x_426); +if (lean_is_exclusive(x_415)) { + lean_ctor_release(x_415, 0); + lean_ctor_release(x_415, 1); + lean_ctor_release(x_415, 2); + lean_ctor_release(x_415, 3); + lean_ctor_release(x_415, 4); + x_427 = x_415; } else { - x_424 = x_423; + lean_dec_ref(x_415); + x_427 = lean_box(0); } -lean_ctor_set(x_424, 0, x_420); -lean_ctor_set(x_424, 1, x_421); -lean_ctor_set(x_424, 2, x_392); -lean_ctor_set(x_424, 3, x_422); -if (lean_is_scalar(x_419)) { - x_425 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_427)) { + x_428 = lean_alloc_ctor(0, 5, 0); } else { - x_425 = x_419; + x_428 = x_427; } -lean_ctor_set(x_425, 0, x_414); -lean_ctor_set(x_425, 1, x_415); -lean_ctor_set(x_425, 2, x_424); -lean_ctor_set(x_425, 3, x_416); -lean_ctor_set(x_425, 4, x_417); -lean_ctor_set(x_425, 5, x_418); -if (lean_is_scalar(x_243)) { - x_426 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_428, 0, x_423); +lean_ctor_set(x_428, 1, x_424); +lean_ctor_set(x_428, 2, x_409); +lean_ctor_set(x_428, 3, x_425); +lean_ctor_set(x_428, 4, x_426); +if (lean_is_scalar(x_422)) { + x_429 = lean_alloc_ctor(0, 6, 0); } else { - x_426 = x_243; + x_429 = x_422; } -lean_ctor_set(x_426, 0, x_413); -lean_ctor_set(x_426, 1, x_425); -return x_426; +lean_ctor_set(x_429, 0, x_417); +lean_ctor_set(x_429, 1, x_418); +lean_ctor_set(x_429, 2, x_428); +lean_ctor_set(x_429, 3, x_419); +lean_ctor_set(x_429, 4, x_420); +lean_ctor_set(x_429, 5, x_421); +if (lean_is_scalar(x_253)) { + x_430 = lean_alloc_ctor(1, 2, 0); +} else { + x_430 = x_253; + lean_ctor_set_tag(x_430, 1); +} +lean_ctor_set(x_430, 0, x_416); +lean_ctor_set(x_430, 1, x_429); +return x_430; +} +else +{ +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; lean_object* x_445; lean_object* x_446; +x_431 = lean_ctor_get(x_414, 2); +lean_inc(x_431); +x_432 = lean_ctor_get(x_413, 0); +lean_inc(x_432); +lean_dec(x_413); +x_433 = lean_ctor_get(x_414, 0); +lean_inc(x_433); +x_434 = lean_ctor_get(x_414, 1); +lean_inc(x_434); +x_435 = lean_ctor_get(x_414, 3); +lean_inc(x_435); +x_436 = lean_ctor_get(x_414, 4); +lean_inc(x_436); +x_437 = lean_ctor_get(x_414, 5); +lean_inc(x_437); +if (lean_is_exclusive(x_414)) { + lean_ctor_release(x_414, 0); + lean_ctor_release(x_414, 1); + lean_ctor_release(x_414, 2); + lean_ctor_release(x_414, 3); + lean_ctor_release(x_414, 4); + lean_ctor_release(x_414, 5); + x_438 = x_414; +} else { + lean_dec_ref(x_414); + x_438 = lean_box(0); +} +x_439 = lean_ctor_get(x_431, 0); +lean_inc(x_439); +x_440 = lean_ctor_get(x_431, 1); +lean_inc(x_440); +x_441 = lean_ctor_get(x_431, 3); +lean_inc(x_441); +x_442 = lean_ctor_get(x_431, 4); +lean_inc(x_442); +if (lean_is_exclusive(x_431)) { + lean_ctor_release(x_431, 0); + lean_ctor_release(x_431, 1); + lean_ctor_release(x_431, 2); + lean_ctor_release(x_431, 3); + lean_ctor_release(x_431, 4); + x_443 = x_431; +} else { + lean_dec_ref(x_431); + x_443 = lean_box(0); +} +if (lean_is_scalar(x_443)) { + x_444 = lean_alloc_ctor(0, 5, 0); +} else { + x_444 = x_443; +} +lean_ctor_set(x_444, 0, x_439); +lean_ctor_set(x_444, 1, x_440); +lean_ctor_set(x_444, 2, x_409); +lean_ctor_set(x_444, 3, x_441); +lean_ctor_set(x_444, 4, x_442); +if (lean_is_scalar(x_438)) { + x_445 = lean_alloc_ctor(0, 6, 0); +} else { + x_445 = x_438; +} +lean_ctor_set(x_445, 0, x_433); +lean_ctor_set(x_445, 1, x_434); +lean_ctor_set(x_445, 2, x_444); +lean_ctor_set(x_445, 3, x_435); +lean_ctor_set(x_445, 4, x_436); +lean_ctor_set(x_445, 5, x_437); +if (lean_is_scalar(x_253)) { + x_446 = lean_alloc_ctor(0, 2, 0); +} else { + x_446 = x_253; +} +lean_ctor_set(x_446, 0, x_432); +lean_ctor_set(x_446, 1, x_445); +return x_446; } } } @@ -14705,7 +15107,7 @@ return x_426; } else { -uint8_t x_447; +uint8_t x_467; lean_dec(x_19); lean_dec(x_11); lean_dec(x_10); @@ -14714,23 +15116,23 @@ lean_dec(x_7); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_447 = !lean_is_exclusive(x_236); -if (x_447 == 0) +x_467 = !lean_is_exclusive(x_246); +if (x_467 == 0) { -return x_236; +return x_246; } else { -lean_object* x_448; lean_object* x_449; lean_object* x_450; -x_448 = lean_ctor_get(x_236, 0); -x_449 = lean_ctor_get(x_236, 1); -lean_inc(x_449); -lean_inc(x_448); -lean_dec(x_236); -x_450 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_450, 0, x_448); -lean_ctor_set(x_450, 1, x_449); -return x_450; +lean_object* x_468; lean_object* x_469; lean_object* x_470; +x_468 = lean_ctor_get(x_246, 0); +x_469 = lean_ctor_get(x_246, 1); +lean_inc(x_469); +lean_inc(x_468); +lean_dec(x_246); +x_470 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_470, 0, x_468); +lean_ctor_set(x_470, 1, x_469); +return x_470; } } } @@ -14738,7 +15140,7 @@ return x_450; } else { -uint8_t x_451; +uint8_t x_471; lean_dec(x_23); lean_dec(x_19); lean_dec(x_11); @@ -14748,29 +15150,29 @@ lean_dec(x_7); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_451 = !lean_is_exclusive(x_24); -if (x_451 == 0) +x_471 = !lean_is_exclusive(x_24); +if (x_471 == 0) { return x_24; } else { -lean_object* x_452; lean_object* x_453; lean_object* x_454; -x_452 = lean_ctor_get(x_24, 0); -x_453 = lean_ctor_get(x_24, 1); -lean_inc(x_453); -lean_inc(x_452); +lean_object* x_472; lean_object* x_473; lean_object* x_474; +x_472 = lean_ctor_get(x_24, 0); +x_473 = lean_ctor_get(x_24, 1); +lean_inc(x_473); +lean_inc(x_472); lean_dec(x_24); -x_454 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_454, 0, x_452); -lean_ctor_set(x_454, 1, x_453); -return x_454; +x_474 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_474, 0, x_472); +lean_ctor_set(x_474, 1, x_473); +return x_474; } } } else { -uint8_t x_455; +uint8_t x_475; lean_dec(x_19); lean_dec(x_11); lean_dec(x_10); @@ -14779,23 +15181,23 @@ lean_dec(x_7); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_455 = !lean_is_exclusive(x_20); -if (x_455 == 0) +x_475 = !lean_is_exclusive(x_20); +if (x_475 == 0) { return x_20; } else { -lean_object* x_456; lean_object* x_457; lean_object* x_458; -x_456 = lean_ctor_get(x_20, 0); -x_457 = lean_ctor_get(x_20, 1); -lean_inc(x_457); -lean_inc(x_456); +lean_object* x_476; lean_object* x_477; lean_object* x_478; +x_476 = lean_ctor_get(x_20, 0); +x_477 = lean_ctor_get(x_20, 1); +lean_inc(x_477); +lean_inc(x_476); lean_dec(x_20); -x_458 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_458, 0, x_456); -lean_ctor_set(x_458, 1, x_457); -return x_458; +x_478 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_478, 0, x_476); +lean_ctor_set(x_478, 1, x_477); +return x_478; } } } @@ -14924,105 +15326,105 @@ x_35 = lean_ctor_get(x_29, 2); x_36 = !lean_is_exclusive(x_35); if (x_36 == 0) { -lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_89; uint8_t x_90; +lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_93; uint8_t x_94; x_37 = lean_ctor_get(x_35, 2); -x_89 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_35, 2, x_89); -x_90 = !lean_is_exclusive(x_4); -if (x_90 == 0) +x_93 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_35, 2, x_93); +x_94 = !lean_is_exclusive(x_4); +if (x_94 == 0) { -lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; -x_91 = lean_ctor_get(x_4, 2); -x_92 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_92, 0, x_31); -lean_ctor_set(x_92, 1, x_18); -x_93 = lean_array_push(x_91, x_92); -lean_ctor_set(x_4, 2, x_93); -x_94 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__6(x_1, x_2, x_33, x_4, x_29); -if (lean_obj_tag(x_94) == 0) +lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; +x_95 = lean_ctor_get(x_4, 2); +x_96 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_96, 0, x_31); +lean_ctor_set(x_96, 1, x_18); +x_97 = lean_array_push(x_95, x_96); +lean_ctor_set(x_4, 2, x_97); +x_98 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__6(x_1, x_2, x_33, x_4, x_29); +if (lean_obj_tag(x_98) == 0) { -lean_object* x_95; lean_object* x_96; lean_object* x_97; -x_95 = lean_ctor_get(x_94, 0); -lean_inc(x_95); -x_96 = lean_ctor_get(x_94, 1); -lean_inc(x_96); -lean_dec(x_94); -x_97 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_97, 0, x_95); -x_38 = x_97; -x_39 = x_96; -goto block_88; -} -else -{ -lean_object* x_98; lean_object* x_99; lean_object* x_100; -x_98 = lean_ctor_get(x_94, 0); -lean_inc(x_98); -x_99 = lean_ctor_get(x_94, 1); +lean_object* x_99; lean_object* x_100; lean_object* x_101; +x_99 = lean_ctor_get(x_98, 0); lean_inc(x_99); -lean_dec(x_94); -x_100 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_100, 0, x_98); -x_38 = x_100; -x_39 = x_99; -goto block_88; -} +x_100 = lean_ctor_get(x_98, 1); +lean_inc(x_100); +lean_dec(x_98); +x_101 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_101, 0, x_99); +x_38 = x_101; +x_39 = x_100; +goto block_92; } 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; -x_101 = lean_ctor_get(x_4, 0); -x_102 = lean_ctor_get(x_4, 1); -x_103 = lean_ctor_get(x_4, 2); -x_104 = lean_ctor_get(x_4, 3); -x_105 = lean_ctor_get(x_4, 4); -lean_inc(x_105); -lean_inc(x_104); -lean_inc(x_103); +lean_object* x_102; lean_object* x_103; lean_object* x_104; +x_102 = lean_ctor_get(x_98, 0); lean_inc(x_102); -lean_inc(x_101); -lean_dec(x_4); -x_106 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_106, 0, x_31); -lean_ctor_set(x_106, 1, x_18); -x_107 = lean_array_push(x_103, x_106); -x_108 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_108, 0, x_101); -lean_ctor_set(x_108, 1, x_102); -lean_ctor_set(x_108, 2, x_107); -lean_ctor_set(x_108, 3, x_104); -lean_ctor_set(x_108, 4, x_105); -x_109 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__6(x_1, x_2, x_33, x_108, x_29); -if (lean_obj_tag(x_109) == 0) -{ -lean_object* x_110; lean_object* x_111; lean_object* x_112; -x_110 = lean_ctor_get(x_109, 0); -lean_inc(x_110); -x_111 = lean_ctor_get(x_109, 1); -lean_inc(x_111); -lean_dec(x_109); -x_112 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_112, 0, x_110); -x_38 = x_112; -x_39 = x_111; -goto block_88; +x_103 = lean_ctor_get(x_98, 1); +lean_inc(x_103); +lean_dec(x_98); +x_104 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_104, 0, x_102); +x_38 = x_104; +x_39 = x_103; +goto block_92; +} } else { -lean_object* x_113; lean_object* x_114; lean_object* x_115; -x_113 = lean_ctor_get(x_109, 0); -lean_inc(x_113); -x_114 = lean_ctor_get(x_109, 1); +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_105 = lean_ctor_get(x_4, 0); +x_106 = lean_ctor_get(x_4, 1); +x_107 = lean_ctor_get(x_4, 2); +x_108 = lean_ctor_get(x_4, 3); +x_109 = lean_ctor_get(x_4, 4); +lean_inc(x_109); +lean_inc(x_108); +lean_inc(x_107); +lean_inc(x_106); +lean_inc(x_105); +lean_dec(x_4); +x_110 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_110, 0, x_31); +lean_ctor_set(x_110, 1, x_18); +x_111 = lean_array_push(x_107, x_110); +x_112 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_112, 0, x_105); +lean_ctor_set(x_112, 1, x_106); +lean_ctor_set(x_112, 2, x_111); +lean_ctor_set(x_112, 3, x_108); +lean_ctor_set(x_112, 4, x_109); +x_113 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__6(x_1, x_2, x_33, x_112, x_29); +if (lean_obj_tag(x_113) == 0) +{ +lean_object* x_114; lean_object* x_115; lean_object* x_116; +x_114 = lean_ctor_get(x_113, 0); lean_inc(x_114); -lean_dec(x_109); -x_115 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_115, 0, x_113); -x_38 = x_115; -x_39 = x_114; -goto block_88; +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_114); +x_38 = x_116; +x_39 = x_115; +goto block_92; +} +else +{ +lean_object* x_117; lean_object* x_118; lean_object* x_119; +x_117 = lean_ctor_get(x_113, 0); +lean_inc(x_117); +x_118 = lean_ctor_get(x_113, 1); +lean_inc(x_118); +lean_dec(x_113); +x_119 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_119, 0, x_117); +x_38 = x_119; +x_39 = x_118; +goto block_92; } } -block_88: +block_92: { if (lean_obj_tag(x_38) == 0) { @@ -15057,1284 +15459,1262 @@ return x_46; } else { -lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; +lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; x_47 = lean_ctor_get(x_40, 0); x_48 = lean_ctor_get(x_40, 1); x_49 = lean_ctor_get(x_40, 3); +x_50 = lean_ctor_get(x_40, 4); +lean_inc(x_50); lean_inc(x_49); lean_inc(x_48); lean_inc(x_47); lean_dec(x_40); -x_50 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_50, 0, x_47); -lean_ctor_set(x_50, 1, x_48); -lean_ctor_set(x_50, 2, x_37); -lean_ctor_set(x_50, 3, x_49); -lean_ctor_set(x_39, 2, x_50); +x_51 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_51, 0, x_47); +lean_ctor_set(x_51, 1, x_48); +lean_ctor_set(x_51, 2, x_37); +lean_ctor_set(x_51, 3, x_49); +lean_ctor_set(x_51, 4, x_50); +lean_ctor_set(x_39, 2, x_51); if (lean_is_scalar(x_30)) { - x_51 = lean_alloc_ctor(1, 2, 0); + x_52 = lean_alloc_ctor(1, 2, 0); } else { - x_51 = x_30; - lean_ctor_set_tag(x_51, 1); + x_52 = x_30; + lean_ctor_set_tag(x_52, 1); } -lean_ctor_set(x_51, 0, x_41); -lean_ctor_set(x_51, 1, x_39); -return x_51; +lean_ctor_set(x_52, 0, x_41); +lean_ctor_set(x_52, 1, x_39); +return x_52; } } else { -lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; -x_52 = lean_ctor_get(x_39, 0); -x_53 = lean_ctor_get(x_39, 1); -x_54 = lean_ctor_get(x_39, 3); -x_55 = lean_ctor_get(x_39, 4); -x_56 = lean_ctor_get(x_39, 5); +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_object* x_63; lean_object* x_64; lean_object* x_65; +x_53 = lean_ctor_get(x_39, 0); +x_54 = lean_ctor_get(x_39, 1); +x_55 = lean_ctor_get(x_39, 3); +x_56 = lean_ctor_get(x_39, 4); +x_57 = lean_ctor_get(x_39, 5); +lean_inc(x_57); lean_inc(x_56); lean_inc(x_55); lean_inc(x_54); lean_inc(x_53); -lean_inc(x_52); lean_dec(x_39); -x_57 = lean_ctor_get(x_40, 0); -lean_inc(x_57); -x_58 = lean_ctor_get(x_40, 1); +x_58 = lean_ctor_get(x_40, 0); lean_inc(x_58); -x_59 = lean_ctor_get(x_40, 3); +x_59 = lean_ctor_get(x_40, 1); lean_inc(x_59); +x_60 = lean_ctor_get(x_40, 3); +lean_inc(x_60); +x_61 = lean_ctor_get(x_40, 4); +lean_inc(x_61); if (lean_is_exclusive(x_40)) { lean_ctor_release(x_40, 0); lean_ctor_release(x_40, 1); lean_ctor_release(x_40, 2); lean_ctor_release(x_40, 3); - x_60 = x_40; + lean_ctor_release(x_40, 4); + x_62 = x_40; } else { lean_dec_ref(x_40); - x_60 = lean_box(0); + x_62 = lean_box(0); } -if (lean_is_scalar(x_60)) { - x_61 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_62)) { + x_63 = lean_alloc_ctor(0, 5, 0); } else { - x_61 = x_60; + x_63 = x_62; } -lean_ctor_set(x_61, 0, x_57); -lean_ctor_set(x_61, 1, x_58); -lean_ctor_set(x_61, 2, x_37); -lean_ctor_set(x_61, 3, x_59); -x_62 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_62, 0, x_52); -lean_ctor_set(x_62, 1, x_53); -lean_ctor_set(x_62, 2, x_61); -lean_ctor_set(x_62, 3, x_54); -lean_ctor_set(x_62, 4, x_55); -lean_ctor_set(x_62, 5, x_56); +lean_ctor_set(x_63, 0, x_58); +lean_ctor_set(x_63, 1, x_59); +lean_ctor_set(x_63, 2, x_37); +lean_ctor_set(x_63, 3, x_60); +lean_ctor_set(x_63, 4, x_61); +x_64 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_64, 0, x_53); +lean_ctor_set(x_64, 1, x_54); +lean_ctor_set(x_64, 2, x_63); +lean_ctor_set(x_64, 3, x_55); +lean_ctor_set(x_64, 4, x_56); +lean_ctor_set(x_64, 5, x_57); if (lean_is_scalar(x_30)) { - x_63 = lean_alloc_ctor(1, 2, 0); + x_65 = lean_alloc_ctor(1, 2, 0); } else { - x_63 = x_30; - lean_ctor_set_tag(x_63, 1); + x_65 = x_30; + lean_ctor_set_tag(x_65, 1); } -lean_ctor_set(x_63, 0, x_41); -lean_ctor_set(x_63, 1, x_62); -return x_63; +lean_ctor_set(x_65, 0, x_41); +lean_ctor_set(x_65, 1, x_64); +return x_65; } } else { -lean_object* x_64; lean_object* x_65; uint8_t x_66; -x_64 = lean_ctor_get(x_39, 2); -lean_inc(x_64); -x_65 = lean_ctor_get(x_38, 0); -lean_inc(x_65); +lean_object* x_66; lean_object* x_67; uint8_t x_68; +x_66 = lean_ctor_get(x_39, 2); +lean_inc(x_66); +x_67 = lean_ctor_get(x_38, 0); +lean_inc(x_67); lean_dec(x_38); -x_66 = !lean_is_exclusive(x_39); -if (x_66 == 0) -{ -lean_object* x_67; uint8_t x_68; -x_67 = lean_ctor_get(x_39, 2); -lean_dec(x_67); -x_68 = !lean_is_exclusive(x_64); +x_68 = !lean_is_exclusive(x_39); if (x_68 == 0) { -lean_object* x_69; lean_object* x_70; -x_69 = lean_ctor_get(x_64, 2); +lean_object* x_69; uint8_t x_70; +x_69 = lean_ctor_get(x_39, 2); lean_dec(x_69); -lean_ctor_set(x_64, 2, x_37); +x_70 = !lean_is_exclusive(x_66); +if (x_70 == 0) +{ +lean_object* x_71; lean_object* x_72; +x_71 = lean_ctor_get(x_66, 2); +lean_dec(x_71); +lean_ctor_set(x_66, 2, x_37); if (lean_is_scalar(x_30)) { - x_70 = lean_alloc_ctor(0, 2, 0); + x_72 = lean_alloc_ctor(0, 2, 0); } else { - x_70 = x_30; + x_72 = x_30; } -lean_ctor_set(x_70, 0, x_65); -lean_ctor_set(x_70, 1, x_39); -return x_70; +lean_ctor_set(x_72, 0, x_67); +lean_ctor_set(x_72, 1, x_39); +return x_72; } else { -lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; -x_71 = lean_ctor_get(x_64, 0); -x_72 = lean_ctor_get(x_64, 1); -x_73 = lean_ctor_get(x_64, 3); +lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; +x_73 = lean_ctor_get(x_66, 0); +x_74 = lean_ctor_get(x_66, 1); +x_75 = lean_ctor_get(x_66, 3); +x_76 = lean_ctor_get(x_66, 4); +lean_inc(x_76); +lean_inc(x_75); +lean_inc(x_74); lean_inc(x_73); -lean_inc(x_72); -lean_inc(x_71); -lean_dec(x_64); -x_74 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_74, 0, x_71); -lean_ctor_set(x_74, 1, x_72); -lean_ctor_set(x_74, 2, x_37); -lean_ctor_set(x_74, 3, x_73); -lean_ctor_set(x_39, 2, x_74); +lean_dec(x_66); +x_77 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_77, 0, x_73); +lean_ctor_set(x_77, 1, x_74); +lean_ctor_set(x_77, 2, x_37); +lean_ctor_set(x_77, 3, x_75); +lean_ctor_set(x_77, 4, x_76); +lean_ctor_set(x_39, 2, x_77); if (lean_is_scalar(x_30)) { - x_75 = lean_alloc_ctor(0, 2, 0); + x_78 = lean_alloc_ctor(0, 2, 0); } else { - x_75 = x_30; + x_78 = x_30; } -lean_ctor_set(x_75, 0, x_65); -lean_ctor_set(x_75, 1, x_39); -return x_75; +lean_ctor_set(x_78, 0, x_67); +lean_ctor_set(x_78, 1, x_39); +return x_78; } } else { -lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; -x_76 = lean_ctor_get(x_39, 0); -x_77 = lean_ctor_get(x_39, 1); -x_78 = lean_ctor_get(x_39, 3); -x_79 = lean_ctor_get(x_39, 4); -x_80 = lean_ctor_get(x_39, 5); +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; +x_79 = lean_ctor_get(x_39, 0); +x_80 = lean_ctor_get(x_39, 1); +x_81 = lean_ctor_get(x_39, 3); +x_82 = lean_ctor_get(x_39, 4); +x_83 = lean_ctor_get(x_39, 5); +lean_inc(x_83); +lean_inc(x_82); +lean_inc(x_81); lean_inc(x_80); lean_inc(x_79); -lean_inc(x_78); -lean_inc(x_77); -lean_inc(x_76); lean_dec(x_39); -x_81 = lean_ctor_get(x_64, 0); -lean_inc(x_81); -x_82 = lean_ctor_get(x_64, 1); -lean_inc(x_82); -x_83 = lean_ctor_get(x_64, 3); -lean_inc(x_83); -if (lean_is_exclusive(x_64)) { - lean_ctor_release(x_64, 0); - lean_ctor_release(x_64, 1); - lean_ctor_release(x_64, 2); - lean_ctor_release(x_64, 3); - x_84 = x_64; +x_84 = lean_ctor_get(x_66, 0); +lean_inc(x_84); +x_85 = lean_ctor_get(x_66, 1); +lean_inc(x_85); +x_86 = lean_ctor_get(x_66, 3); +lean_inc(x_86); +x_87 = lean_ctor_get(x_66, 4); +lean_inc(x_87); +if (lean_is_exclusive(x_66)) { + lean_ctor_release(x_66, 0); + lean_ctor_release(x_66, 1); + lean_ctor_release(x_66, 2); + lean_ctor_release(x_66, 3); + lean_ctor_release(x_66, 4); + x_88 = x_66; } else { - lean_dec_ref(x_64); - x_84 = lean_box(0); + lean_dec_ref(x_66); + x_88 = lean_box(0); } -if (lean_is_scalar(x_84)) { - x_85 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_88)) { + x_89 = lean_alloc_ctor(0, 5, 0); } else { - x_85 = x_84; + x_89 = x_88; } -lean_ctor_set(x_85, 0, x_81); -lean_ctor_set(x_85, 1, x_82); -lean_ctor_set(x_85, 2, x_37); -lean_ctor_set(x_85, 3, x_83); -x_86 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_86, 0, x_76); -lean_ctor_set(x_86, 1, x_77); -lean_ctor_set(x_86, 2, x_85); -lean_ctor_set(x_86, 3, x_78); -lean_ctor_set(x_86, 4, x_79); -lean_ctor_set(x_86, 5, x_80); +lean_ctor_set(x_89, 0, x_84); +lean_ctor_set(x_89, 1, x_85); +lean_ctor_set(x_89, 2, x_37); +lean_ctor_set(x_89, 3, x_86); +lean_ctor_set(x_89, 4, x_87); +x_90 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_90, 0, x_79); +lean_ctor_set(x_90, 1, x_80); +lean_ctor_set(x_90, 2, x_89); +lean_ctor_set(x_90, 3, x_81); +lean_ctor_set(x_90, 4, x_82); +lean_ctor_set(x_90, 5, x_83); if (lean_is_scalar(x_30)) { - x_87 = lean_alloc_ctor(0, 2, 0); + x_91 = lean_alloc_ctor(0, 2, 0); } else { - x_87 = x_30; + x_91 = x_30; } -lean_ctor_set(x_87, 0, x_65); -lean_ctor_set(x_87, 1, x_86); -return x_87; +lean_ctor_set(x_91, 0, x_67); +lean_ctor_set(x_91, 1, x_90); +return x_91; } } } } else { -lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_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; -x_116 = lean_ctor_get(x_35, 0); -x_117 = lean_ctor_get(x_35, 1); -x_118 = lean_ctor_get(x_35, 2); -x_119 = lean_ctor_get(x_35, 3); -lean_inc(x_119); -lean_inc(x_118); -lean_inc(x_117); -lean_inc(x_116); -lean_dec(x_35); -x_153 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_154 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_154, 0, x_116); -lean_ctor_set(x_154, 1, x_117); -lean_ctor_set(x_154, 2, x_153); -lean_ctor_set(x_154, 3, x_119); -lean_ctor_set(x_29, 2, x_154); -x_155 = lean_ctor_get(x_4, 0); -lean_inc(x_155); -x_156 = lean_ctor_get(x_4, 1); -lean_inc(x_156); -x_157 = lean_ctor_get(x_4, 2); -lean_inc(x_157); -x_158 = lean_ctor_get(x_4, 3); -lean_inc(x_158); -x_159 = lean_ctor_get(x_4, 4); -lean_inc(x_159); -if (lean_is_exclusive(x_4)) { - lean_ctor_release(x_4, 0); - lean_ctor_release(x_4, 1); - lean_ctor_release(x_4, 2); - lean_ctor_release(x_4, 3); - lean_ctor_release(x_4, 4); - x_160 = x_4; -} else { - lean_dec_ref(x_4); - x_160 = lean_box(0); -} -x_161 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_161, 0, x_31); -lean_ctor_set(x_161, 1, x_18); -x_162 = lean_array_push(x_157, x_161); -if (lean_is_scalar(x_160)) { - x_163 = lean_alloc_ctor(0, 5, 0); -} else { - x_163 = x_160; -} -lean_ctor_set(x_163, 0, x_155); -lean_ctor_set(x_163, 1, x_156); -lean_ctor_set(x_163, 2, x_162); -lean_ctor_set(x_163, 3, x_158); -lean_ctor_set(x_163, 4, x_159); -x_164 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__6(x_1, x_2, x_33, x_163, x_29); -if (lean_obj_tag(x_164) == 0) -{ -lean_object* x_165; lean_object* x_166; lean_object* x_167; -x_165 = lean_ctor_get(x_164, 0); -lean_inc(x_165); -x_166 = lean_ctor_get(x_164, 1); -lean_inc(x_166); -lean_dec(x_164); -x_167 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_167, 0, x_165); -x_120 = x_167; -x_121 = x_166; -goto block_152; -} -else -{ -lean_object* x_168; lean_object* x_169; lean_object* x_170; -x_168 = lean_ctor_get(x_164, 0); -lean_inc(x_168); -x_169 = lean_ctor_get(x_164, 1); -lean_inc(x_169); -lean_dec(x_164); -x_170 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_170, 0, x_168); -x_120 = x_170; -x_121 = x_169; -goto block_152; -} -block_152: -{ -if (lean_obj_tag(x_120) == 0) -{ -lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; -x_122 = lean_ctor_get(x_121, 2); -lean_inc(x_122); -x_123 = lean_ctor_get(x_120, 0); -lean_inc(x_123); -lean_dec(x_120); -x_124 = lean_ctor_get(x_121, 0); +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_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; +x_120 = lean_ctor_get(x_35, 0); +x_121 = lean_ctor_get(x_35, 1); +x_122 = lean_ctor_get(x_35, 2); +x_123 = lean_ctor_get(x_35, 3); +x_124 = lean_ctor_get(x_35, 4); lean_inc(x_124); -x_125 = lean_ctor_get(x_121, 1); -lean_inc(x_125); -x_126 = lean_ctor_get(x_121, 3); -lean_inc(x_126); -x_127 = lean_ctor_get(x_121, 4); -lean_inc(x_127); -x_128 = lean_ctor_get(x_121, 5); -lean_inc(x_128); -if (lean_is_exclusive(x_121)) { - lean_ctor_release(x_121, 0); - lean_ctor_release(x_121, 1); - lean_ctor_release(x_121, 2); - lean_ctor_release(x_121, 3); - lean_ctor_release(x_121, 4); - lean_ctor_release(x_121, 5); - x_129 = x_121; -} else { - lean_dec_ref(x_121); - x_129 = lean_box(0); -} -x_130 = lean_ctor_get(x_122, 0); -lean_inc(x_130); -x_131 = lean_ctor_get(x_122, 1); -lean_inc(x_131); -x_132 = lean_ctor_get(x_122, 3); -lean_inc(x_132); -if (lean_is_exclusive(x_122)) { - lean_ctor_release(x_122, 0); - lean_ctor_release(x_122, 1); - lean_ctor_release(x_122, 2); - lean_ctor_release(x_122, 3); - x_133 = x_122; -} else { - lean_dec_ref(x_122); - x_133 = lean_box(0); -} -if (lean_is_scalar(x_133)) { - x_134 = lean_alloc_ctor(0, 4, 0); -} else { - x_134 = x_133; -} -lean_ctor_set(x_134, 0, x_130); -lean_ctor_set(x_134, 1, x_131); -lean_ctor_set(x_134, 2, x_118); -lean_ctor_set(x_134, 3, x_132); -if (lean_is_scalar(x_129)) { - x_135 = lean_alloc_ctor(0, 6, 0); -} else { - x_135 = x_129; -} -lean_ctor_set(x_135, 0, x_124); -lean_ctor_set(x_135, 1, x_125); -lean_ctor_set(x_135, 2, x_134); -lean_ctor_set(x_135, 3, x_126); -lean_ctor_set(x_135, 4, x_127); -lean_ctor_set(x_135, 5, x_128); -if (lean_is_scalar(x_30)) { - x_136 = lean_alloc_ctor(1, 2, 0); -} else { - x_136 = x_30; - lean_ctor_set_tag(x_136, 1); -} -lean_ctor_set(x_136, 0, x_123); -lean_ctor_set(x_136, 1, x_135); -return x_136; -} -else -{ -lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; -x_137 = lean_ctor_get(x_121, 2); -lean_inc(x_137); -x_138 = lean_ctor_get(x_120, 0); -lean_inc(x_138); -lean_dec(x_120); -x_139 = lean_ctor_get(x_121, 0); -lean_inc(x_139); -x_140 = lean_ctor_get(x_121, 1); -lean_inc(x_140); -x_141 = lean_ctor_get(x_121, 3); -lean_inc(x_141); -x_142 = lean_ctor_get(x_121, 4); -lean_inc(x_142); -x_143 = lean_ctor_get(x_121, 5); -lean_inc(x_143); -if (lean_is_exclusive(x_121)) { - lean_ctor_release(x_121, 0); - lean_ctor_release(x_121, 1); - lean_ctor_release(x_121, 2); - lean_ctor_release(x_121, 3); - lean_ctor_release(x_121, 4); - lean_ctor_release(x_121, 5); - x_144 = x_121; -} else { - lean_dec_ref(x_121); - x_144 = lean_box(0); -} -x_145 = lean_ctor_get(x_137, 0); -lean_inc(x_145); -x_146 = lean_ctor_get(x_137, 1); -lean_inc(x_146); -x_147 = lean_ctor_get(x_137, 3); -lean_inc(x_147); -if (lean_is_exclusive(x_137)) { - lean_ctor_release(x_137, 0); - lean_ctor_release(x_137, 1); - lean_ctor_release(x_137, 2); - lean_ctor_release(x_137, 3); - x_148 = x_137; -} else { - lean_dec_ref(x_137); - x_148 = lean_box(0); -} -if (lean_is_scalar(x_148)) { - x_149 = lean_alloc_ctor(0, 4, 0); -} else { - x_149 = x_148; -} -lean_ctor_set(x_149, 0, x_145); -lean_ctor_set(x_149, 1, x_146); -lean_ctor_set(x_149, 2, x_118); -lean_ctor_set(x_149, 3, x_147); -if (lean_is_scalar(x_144)) { - x_150 = lean_alloc_ctor(0, 6, 0); -} else { - x_150 = x_144; -} -lean_ctor_set(x_150, 0, x_139); -lean_ctor_set(x_150, 1, x_140); -lean_ctor_set(x_150, 2, x_149); -lean_ctor_set(x_150, 3, x_141); -lean_ctor_set(x_150, 4, x_142); -lean_ctor_set(x_150, 5, x_143); -if (lean_is_scalar(x_30)) { - x_151 = lean_alloc_ctor(0, 2, 0); -} else { - x_151 = x_30; -} -lean_ctor_set(x_151, 0, x_138); -lean_ctor_set(x_151, 1, x_150); -return x_151; -} -} -} -} -else -{ -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; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; lean_object* x_224; lean_object* x_225; lean_object* x_226; lean_object* x_227; -x_171 = lean_ctor_get(x_29, 2); -x_172 = lean_ctor_get(x_29, 0); -x_173 = lean_ctor_get(x_29, 1); -x_174 = lean_ctor_get(x_29, 3); -x_175 = lean_ctor_get(x_29, 4); -x_176 = lean_ctor_get(x_29, 5); -lean_inc(x_176); -lean_inc(x_175); -lean_inc(x_174); -lean_inc(x_171); -lean_inc(x_173); -lean_inc(x_172); -lean_dec(x_29); -x_177 = lean_ctor_get(x_171, 0); -lean_inc(x_177); -x_178 = lean_ctor_get(x_171, 1); -lean_inc(x_178); -x_179 = lean_ctor_get(x_171, 2); -lean_inc(x_179); -x_180 = lean_ctor_get(x_171, 3); -lean_inc(x_180); -if (lean_is_exclusive(x_171)) { - lean_ctor_release(x_171, 0); - lean_ctor_release(x_171, 1); - lean_ctor_release(x_171, 2); - lean_ctor_release(x_171, 3); - x_181 = x_171; -} else { - lean_dec_ref(x_171); - x_181 = lean_box(0); -} -x_215 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_181)) { - x_216 = lean_alloc_ctor(0, 4, 0); -} else { - x_216 = x_181; -} -lean_ctor_set(x_216, 0, x_177); -lean_ctor_set(x_216, 1, x_178); -lean_ctor_set(x_216, 2, x_215); -lean_ctor_set(x_216, 3, x_180); -x_217 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_217, 0, x_172); -lean_ctor_set(x_217, 1, x_173); -lean_ctor_set(x_217, 2, x_216); -lean_ctor_set(x_217, 3, x_174); -lean_ctor_set(x_217, 4, x_175); -lean_ctor_set(x_217, 5, x_176); -x_218 = lean_ctor_get(x_4, 0); -lean_inc(x_218); -x_219 = lean_ctor_get(x_4, 1); -lean_inc(x_219); -x_220 = lean_ctor_get(x_4, 2); -lean_inc(x_220); -x_221 = lean_ctor_get(x_4, 3); -lean_inc(x_221); -x_222 = lean_ctor_get(x_4, 4); -lean_inc(x_222); +lean_inc(x_123); +lean_inc(x_122); +lean_inc(x_121); +lean_inc(x_120); +lean_dec(x_35); +x_160 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_161 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_161, 0, x_120); +lean_ctor_set(x_161, 1, x_121); +lean_ctor_set(x_161, 2, x_160); +lean_ctor_set(x_161, 3, x_123); +lean_ctor_set(x_161, 4, x_124); +lean_ctor_set(x_29, 2, x_161); +x_162 = lean_ctor_get(x_4, 0); +lean_inc(x_162); +x_163 = lean_ctor_get(x_4, 1); +lean_inc(x_163); +x_164 = lean_ctor_get(x_4, 2); +lean_inc(x_164); +x_165 = lean_ctor_get(x_4, 3); +lean_inc(x_165); +x_166 = lean_ctor_get(x_4, 4); +lean_inc(x_166); if (lean_is_exclusive(x_4)) { lean_ctor_release(x_4, 0); lean_ctor_release(x_4, 1); lean_ctor_release(x_4, 2); lean_ctor_release(x_4, 3); lean_ctor_release(x_4, 4); - x_223 = x_4; + x_167 = x_4; } else { lean_dec_ref(x_4); - x_223 = lean_box(0); + x_167 = lean_box(0); } -x_224 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_224, 0, x_31); -lean_ctor_set(x_224, 1, x_18); -x_225 = lean_array_push(x_220, x_224); -if (lean_is_scalar(x_223)) { +x_168 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_168, 0, x_31); +lean_ctor_set(x_168, 1, x_18); +x_169 = lean_array_push(x_164, x_168); +if (lean_is_scalar(x_167)) { + x_170 = lean_alloc_ctor(0, 5, 0); +} else { + x_170 = x_167; +} +lean_ctor_set(x_170, 0, x_162); +lean_ctor_set(x_170, 1, x_163); +lean_ctor_set(x_170, 2, x_169); +lean_ctor_set(x_170, 3, x_165); +lean_ctor_set(x_170, 4, x_166); +x_171 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__6(x_1, x_2, x_33, x_170, x_29); +if (lean_obj_tag(x_171) == 0) +{ +lean_object* x_172; lean_object* x_173; lean_object* x_174; +x_172 = lean_ctor_get(x_171, 0); +lean_inc(x_172); +x_173 = lean_ctor_get(x_171, 1); +lean_inc(x_173); +lean_dec(x_171); +x_174 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_174, 0, x_172); +x_125 = x_174; +x_126 = x_173; +goto block_159; +} +else +{ +lean_object* x_175; lean_object* x_176; lean_object* x_177; +x_175 = lean_ctor_get(x_171, 0); +lean_inc(x_175); +x_176 = lean_ctor_get(x_171, 1); +lean_inc(x_176); +lean_dec(x_171); +x_177 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_177, 0, x_175); +x_125 = x_177; +x_126 = x_176; +goto block_159; +} +block_159: +{ +if (lean_obj_tag(x_125) == 0) +{ +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; +x_127 = lean_ctor_get(x_126, 2); +lean_inc(x_127); +x_128 = lean_ctor_get(x_125, 0); +lean_inc(x_128); +lean_dec(x_125); +x_129 = lean_ctor_get(x_126, 0); +lean_inc(x_129); +x_130 = lean_ctor_get(x_126, 1); +lean_inc(x_130); +x_131 = lean_ctor_get(x_126, 3); +lean_inc(x_131); +x_132 = lean_ctor_get(x_126, 4); +lean_inc(x_132); +x_133 = lean_ctor_get(x_126, 5); +lean_inc(x_133); +if (lean_is_exclusive(x_126)) { + lean_ctor_release(x_126, 0); + lean_ctor_release(x_126, 1); + lean_ctor_release(x_126, 2); + lean_ctor_release(x_126, 3); + lean_ctor_release(x_126, 4); + lean_ctor_release(x_126, 5); + x_134 = x_126; +} else { + lean_dec_ref(x_126); + x_134 = lean_box(0); +} +x_135 = lean_ctor_get(x_127, 0); +lean_inc(x_135); +x_136 = lean_ctor_get(x_127, 1); +lean_inc(x_136); +x_137 = lean_ctor_get(x_127, 3); +lean_inc(x_137); +x_138 = lean_ctor_get(x_127, 4); +lean_inc(x_138); +if (lean_is_exclusive(x_127)) { + lean_ctor_release(x_127, 0); + lean_ctor_release(x_127, 1); + lean_ctor_release(x_127, 2); + lean_ctor_release(x_127, 3); + lean_ctor_release(x_127, 4); + x_139 = x_127; +} else { + lean_dec_ref(x_127); + x_139 = lean_box(0); +} +if (lean_is_scalar(x_139)) { + x_140 = lean_alloc_ctor(0, 5, 0); +} else { + x_140 = x_139; +} +lean_ctor_set(x_140, 0, x_135); +lean_ctor_set(x_140, 1, x_136); +lean_ctor_set(x_140, 2, x_122); +lean_ctor_set(x_140, 3, x_137); +lean_ctor_set(x_140, 4, x_138); +if (lean_is_scalar(x_134)) { + x_141 = lean_alloc_ctor(0, 6, 0); +} else { + x_141 = x_134; +} +lean_ctor_set(x_141, 0, x_129); +lean_ctor_set(x_141, 1, x_130); +lean_ctor_set(x_141, 2, x_140); +lean_ctor_set(x_141, 3, x_131); +lean_ctor_set(x_141, 4, x_132); +lean_ctor_set(x_141, 5, x_133); +if (lean_is_scalar(x_30)) { + x_142 = lean_alloc_ctor(1, 2, 0); +} else { + x_142 = x_30; + lean_ctor_set_tag(x_142, 1); +} +lean_ctor_set(x_142, 0, x_128); +lean_ctor_set(x_142, 1, x_141); +return x_142; +} +else +{ +lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; 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; +x_143 = lean_ctor_get(x_126, 2); +lean_inc(x_143); +x_144 = lean_ctor_get(x_125, 0); +lean_inc(x_144); +lean_dec(x_125); +x_145 = lean_ctor_get(x_126, 0); +lean_inc(x_145); +x_146 = lean_ctor_get(x_126, 1); +lean_inc(x_146); +x_147 = lean_ctor_get(x_126, 3); +lean_inc(x_147); +x_148 = lean_ctor_get(x_126, 4); +lean_inc(x_148); +x_149 = lean_ctor_get(x_126, 5); +lean_inc(x_149); +if (lean_is_exclusive(x_126)) { + lean_ctor_release(x_126, 0); + lean_ctor_release(x_126, 1); + lean_ctor_release(x_126, 2); + lean_ctor_release(x_126, 3); + lean_ctor_release(x_126, 4); + lean_ctor_release(x_126, 5); + x_150 = x_126; +} else { + lean_dec_ref(x_126); + x_150 = lean_box(0); +} +x_151 = lean_ctor_get(x_143, 0); +lean_inc(x_151); +x_152 = lean_ctor_get(x_143, 1); +lean_inc(x_152); +x_153 = lean_ctor_get(x_143, 3); +lean_inc(x_153); +x_154 = lean_ctor_get(x_143, 4); +lean_inc(x_154); +if (lean_is_exclusive(x_143)) { + lean_ctor_release(x_143, 0); + lean_ctor_release(x_143, 1); + lean_ctor_release(x_143, 2); + lean_ctor_release(x_143, 3); + lean_ctor_release(x_143, 4); + x_155 = x_143; +} else { + lean_dec_ref(x_143); + x_155 = lean_box(0); +} +if (lean_is_scalar(x_155)) { + x_156 = lean_alloc_ctor(0, 5, 0); +} else { + x_156 = x_155; +} +lean_ctor_set(x_156, 0, x_151); +lean_ctor_set(x_156, 1, x_152); +lean_ctor_set(x_156, 2, x_122); +lean_ctor_set(x_156, 3, x_153); +lean_ctor_set(x_156, 4, x_154); +if (lean_is_scalar(x_150)) { + x_157 = lean_alloc_ctor(0, 6, 0); +} else { + x_157 = x_150; +} +lean_ctor_set(x_157, 0, x_145); +lean_ctor_set(x_157, 1, x_146); +lean_ctor_set(x_157, 2, x_156); +lean_ctor_set(x_157, 3, x_147); +lean_ctor_set(x_157, 4, x_148); +lean_ctor_set(x_157, 5, x_149); +if (lean_is_scalar(x_30)) { + x_158 = lean_alloc_ctor(0, 2, 0); +} else { + x_158 = x_30; +} +lean_ctor_set(x_158, 0, x_144); +lean_ctor_set(x_158, 1, x_157); +return x_158; +} +} +} +} +else +{ +lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_225; lean_object* x_226; lean_object* x_227; lean_object* x_228; lean_object* x_229; lean_object* x_230; lean_object* x_231; lean_object* x_232; lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_object* x_236; lean_object* x_237; +x_178 = lean_ctor_get(x_29, 2); +x_179 = lean_ctor_get(x_29, 0); +x_180 = lean_ctor_get(x_29, 1); +x_181 = lean_ctor_get(x_29, 3); +x_182 = lean_ctor_get(x_29, 4); +x_183 = lean_ctor_get(x_29, 5); +lean_inc(x_183); +lean_inc(x_182); +lean_inc(x_181); +lean_inc(x_178); +lean_inc(x_180); +lean_inc(x_179); +lean_dec(x_29); +x_184 = lean_ctor_get(x_178, 0); +lean_inc(x_184); +x_185 = lean_ctor_get(x_178, 1); +lean_inc(x_185); +x_186 = lean_ctor_get(x_178, 2); +lean_inc(x_186); +x_187 = lean_ctor_get(x_178, 3); +lean_inc(x_187); +x_188 = lean_ctor_get(x_178, 4); +lean_inc(x_188); +if (lean_is_exclusive(x_178)) { + lean_ctor_release(x_178, 0); + lean_ctor_release(x_178, 1); + lean_ctor_release(x_178, 2); + lean_ctor_release(x_178, 3); + lean_ctor_release(x_178, 4); + x_189 = x_178; +} else { + lean_dec_ref(x_178); + x_189 = lean_box(0); +} +x_225 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_189)) { x_226 = lean_alloc_ctor(0, 5, 0); } else { - x_226 = x_223; + x_226 = x_189; } -lean_ctor_set(x_226, 0, x_218); -lean_ctor_set(x_226, 1, x_219); +lean_ctor_set(x_226, 0, x_184); +lean_ctor_set(x_226, 1, x_185); lean_ctor_set(x_226, 2, x_225); -lean_ctor_set(x_226, 3, x_221); -lean_ctor_set(x_226, 4, x_222); -x_227 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__6(x_1, x_2, x_33, x_226, x_217); -if (lean_obj_tag(x_227) == 0) -{ -lean_object* x_228; lean_object* x_229; lean_object* x_230; -x_228 = lean_ctor_get(x_227, 0); +lean_ctor_set(x_226, 3, x_187); +lean_ctor_set(x_226, 4, x_188); +x_227 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_227, 0, x_179); +lean_ctor_set(x_227, 1, x_180); +lean_ctor_set(x_227, 2, x_226); +lean_ctor_set(x_227, 3, x_181); +lean_ctor_set(x_227, 4, x_182); +lean_ctor_set(x_227, 5, x_183); +x_228 = lean_ctor_get(x_4, 0); lean_inc(x_228); -x_229 = lean_ctor_get(x_227, 1); +x_229 = lean_ctor_get(x_4, 1); lean_inc(x_229); -lean_dec(x_227); -x_230 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_230, 0, x_228); -x_182 = x_230; -x_183 = x_229; -goto block_214; -} -else -{ -lean_object* x_231; lean_object* x_232; lean_object* x_233; -x_231 = lean_ctor_get(x_227, 0); +x_230 = lean_ctor_get(x_4, 2); +lean_inc(x_230); +x_231 = lean_ctor_get(x_4, 3); lean_inc(x_231); -x_232 = lean_ctor_get(x_227, 1); +x_232 = lean_ctor_get(x_4, 4); lean_inc(x_232); -lean_dec(x_227); -x_233 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_233, 0, x_231); -x_182 = x_233; -x_183 = x_232; -goto block_214; +if (lean_is_exclusive(x_4)) { + lean_ctor_release(x_4, 0); + lean_ctor_release(x_4, 1); + lean_ctor_release(x_4, 2); + lean_ctor_release(x_4, 3); + lean_ctor_release(x_4, 4); + x_233 = x_4; +} else { + lean_dec_ref(x_4); + x_233 = lean_box(0); } -block_214: +x_234 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_234, 0, x_31); +lean_ctor_set(x_234, 1, x_18); +x_235 = lean_array_push(x_230, x_234); +if (lean_is_scalar(x_233)) { + x_236 = lean_alloc_ctor(0, 5, 0); +} else { + x_236 = x_233; +} +lean_ctor_set(x_236, 0, x_228); +lean_ctor_set(x_236, 1, x_229); +lean_ctor_set(x_236, 2, x_235); +lean_ctor_set(x_236, 3, x_231); +lean_ctor_set(x_236, 4, x_232); +x_237 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__6(x_1, x_2, x_33, x_236, x_227); +if (lean_obj_tag(x_237) == 0) { -if (lean_obj_tag(x_182) == 0) -{ -lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; -x_184 = lean_ctor_get(x_183, 2); -lean_inc(x_184); -x_185 = lean_ctor_get(x_182, 0); -lean_inc(x_185); -lean_dec(x_182); -x_186 = lean_ctor_get(x_183, 0); -lean_inc(x_186); -x_187 = lean_ctor_get(x_183, 1); -lean_inc(x_187); -x_188 = lean_ctor_get(x_183, 3); -lean_inc(x_188); -x_189 = lean_ctor_get(x_183, 4); -lean_inc(x_189); -x_190 = lean_ctor_get(x_183, 5); -lean_inc(x_190); -if (lean_is_exclusive(x_183)) { - lean_ctor_release(x_183, 0); - lean_ctor_release(x_183, 1); - lean_ctor_release(x_183, 2); - lean_ctor_release(x_183, 3); - lean_ctor_release(x_183, 4); - lean_ctor_release(x_183, 5); - x_191 = x_183; -} else { - lean_dec_ref(x_183); - x_191 = lean_box(0); -} -x_192 = lean_ctor_get(x_184, 0); -lean_inc(x_192); -x_193 = lean_ctor_get(x_184, 1); -lean_inc(x_193); -x_194 = lean_ctor_get(x_184, 3); -lean_inc(x_194); -if (lean_is_exclusive(x_184)) { - lean_ctor_release(x_184, 0); - lean_ctor_release(x_184, 1); - lean_ctor_release(x_184, 2); - lean_ctor_release(x_184, 3); - x_195 = x_184; -} else { - lean_dec_ref(x_184); - x_195 = lean_box(0); -} -if (lean_is_scalar(x_195)) { - x_196 = lean_alloc_ctor(0, 4, 0); -} else { - x_196 = x_195; -} -lean_ctor_set(x_196, 0, x_192); -lean_ctor_set(x_196, 1, x_193); -lean_ctor_set(x_196, 2, x_179); -lean_ctor_set(x_196, 3, x_194); -if (lean_is_scalar(x_191)) { - x_197 = lean_alloc_ctor(0, 6, 0); -} else { - x_197 = x_191; -} -lean_ctor_set(x_197, 0, x_186); -lean_ctor_set(x_197, 1, x_187); -lean_ctor_set(x_197, 2, x_196); -lean_ctor_set(x_197, 3, x_188); -lean_ctor_set(x_197, 4, x_189); -lean_ctor_set(x_197, 5, x_190); -if (lean_is_scalar(x_30)) { - x_198 = lean_alloc_ctor(1, 2, 0); -} else { - x_198 = x_30; - lean_ctor_set_tag(x_198, 1); -} -lean_ctor_set(x_198, 0, x_185); -lean_ctor_set(x_198, 1, x_197); -return x_198; +lean_object* x_238; lean_object* x_239; lean_object* x_240; +x_238 = lean_ctor_get(x_237, 0); +lean_inc(x_238); +x_239 = lean_ctor_get(x_237, 1); +lean_inc(x_239); +lean_dec(x_237); +x_240 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_240, 0, x_238); +x_190 = x_240; +x_191 = x_239; +goto block_224; } else { -lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; -x_199 = lean_ctor_get(x_183, 2); -lean_inc(x_199); -x_200 = lean_ctor_get(x_182, 0); +lean_object* x_241; lean_object* x_242; lean_object* x_243; +x_241 = lean_ctor_get(x_237, 0); +lean_inc(x_241); +x_242 = lean_ctor_get(x_237, 1); +lean_inc(x_242); +lean_dec(x_237); +x_243 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_243, 0, x_241); +x_190 = x_243; +x_191 = x_242; +goto block_224; +} +block_224: +{ +if (lean_obj_tag(x_190) == 0) +{ +lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; +x_192 = lean_ctor_get(x_191, 2); +lean_inc(x_192); +x_193 = lean_ctor_get(x_190, 0); +lean_inc(x_193); +lean_dec(x_190); +x_194 = lean_ctor_get(x_191, 0); +lean_inc(x_194); +x_195 = lean_ctor_get(x_191, 1); +lean_inc(x_195); +x_196 = lean_ctor_get(x_191, 3); +lean_inc(x_196); +x_197 = lean_ctor_get(x_191, 4); +lean_inc(x_197); +x_198 = lean_ctor_get(x_191, 5); +lean_inc(x_198); +if (lean_is_exclusive(x_191)) { + lean_ctor_release(x_191, 0); + lean_ctor_release(x_191, 1); + lean_ctor_release(x_191, 2); + lean_ctor_release(x_191, 3); + lean_ctor_release(x_191, 4); + lean_ctor_release(x_191, 5); + x_199 = x_191; +} else { + lean_dec_ref(x_191); + x_199 = lean_box(0); +} +x_200 = lean_ctor_get(x_192, 0); lean_inc(x_200); -lean_dec(x_182); -x_201 = lean_ctor_get(x_183, 0); +x_201 = lean_ctor_get(x_192, 1); lean_inc(x_201); -x_202 = lean_ctor_get(x_183, 1); +x_202 = lean_ctor_get(x_192, 3); lean_inc(x_202); -x_203 = lean_ctor_get(x_183, 3); +x_203 = lean_ctor_get(x_192, 4); lean_inc(x_203); -x_204 = lean_ctor_get(x_183, 4); -lean_inc(x_204); -x_205 = lean_ctor_get(x_183, 5); -lean_inc(x_205); -if (lean_is_exclusive(x_183)) { - lean_ctor_release(x_183, 0); - lean_ctor_release(x_183, 1); - lean_ctor_release(x_183, 2); - lean_ctor_release(x_183, 3); - lean_ctor_release(x_183, 4); - lean_ctor_release(x_183, 5); - x_206 = x_183; +if (lean_is_exclusive(x_192)) { + lean_ctor_release(x_192, 0); + lean_ctor_release(x_192, 1); + lean_ctor_release(x_192, 2); + lean_ctor_release(x_192, 3); + lean_ctor_release(x_192, 4); + x_204 = x_192; } else { - lean_dec_ref(x_183); - x_206 = lean_box(0); + lean_dec_ref(x_192); + x_204 = lean_box(0); } -x_207 = lean_ctor_get(x_199, 0); -lean_inc(x_207); -x_208 = lean_ctor_get(x_199, 1); -lean_inc(x_208); -x_209 = lean_ctor_get(x_199, 3); -lean_inc(x_209); -if (lean_is_exclusive(x_199)) { - lean_ctor_release(x_199, 0); - lean_ctor_release(x_199, 1); - lean_ctor_release(x_199, 2); - lean_ctor_release(x_199, 3); - x_210 = x_199; +if (lean_is_scalar(x_204)) { + x_205 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_199); - x_210 = lean_box(0); + x_205 = x_204; } -if (lean_is_scalar(x_210)) { - x_211 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_205, 0, x_200); +lean_ctor_set(x_205, 1, x_201); +lean_ctor_set(x_205, 2, x_186); +lean_ctor_set(x_205, 3, x_202); +lean_ctor_set(x_205, 4, x_203); +if (lean_is_scalar(x_199)) { + x_206 = lean_alloc_ctor(0, 6, 0); } else { - x_211 = x_210; + x_206 = x_199; } -lean_ctor_set(x_211, 0, x_207); -lean_ctor_set(x_211, 1, x_208); -lean_ctor_set(x_211, 2, x_179); -lean_ctor_set(x_211, 3, x_209); -if (lean_is_scalar(x_206)) { - x_212 = lean_alloc_ctor(0, 6, 0); -} else { - x_212 = x_206; -} -lean_ctor_set(x_212, 0, x_201); -lean_ctor_set(x_212, 1, x_202); -lean_ctor_set(x_212, 2, x_211); -lean_ctor_set(x_212, 3, x_203); -lean_ctor_set(x_212, 4, x_204); -lean_ctor_set(x_212, 5, x_205); +lean_ctor_set(x_206, 0, x_194); +lean_ctor_set(x_206, 1, x_195); +lean_ctor_set(x_206, 2, x_205); +lean_ctor_set(x_206, 3, x_196); +lean_ctor_set(x_206, 4, x_197); +lean_ctor_set(x_206, 5, x_198); if (lean_is_scalar(x_30)) { - x_213 = lean_alloc_ctor(0, 2, 0); + x_207 = lean_alloc_ctor(1, 2, 0); } else { - x_213 = x_30; + x_207 = x_30; + lean_ctor_set_tag(x_207, 1); } -lean_ctor_set(x_213, 0, x_200); -lean_ctor_set(x_213, 1, x_212); -return x_213; +lean_ctor_set(x_207, 0, x_193); +lean_ctor_set(x_207, 1, x_206); +return x_207; +} +else +{ +lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; +x_208 = lean_ctor_get(x_191, 2); +lean_inc(x_208); +x_209 = lean_ctor_get(x_190, 0); +lean_inc(x_209); +lean_dec(x_190); +x_210 = lean_ctor_get(x_191, 0); +lean_inc(x_210); +x_211 = lean_ctor_get(x_191, 1); +lean_inc(x_211); +x_212 = lean_ctor_get(x_191, 3); +lean_inc(x_212); +x_213 = lean_ctor_get(x_191, 4); +lean_inc(x_213); +x_214 = lean_ctor_get(x_191, 5); +lean_inc(x_214); +if (lean_is_exclusive(x_191)) { + lean_ctor_release(x_191, 0); + lean_ctor_release(x_191, 1); + lean_ctor_release(x_191, 2); + lean_ctor_release(x_191, 3); + lean_ctor_release(x_191, 4); + lean_ctor_release(x_191, 5); + x_215 = x_191; +} else { + lean_dec_ref(x_191); + x_215 = lean_box(0); +} +x_216 = lean_ctor_get(x_208, 0); +lean_inc(x_216); +x_217 = lean_ctor_get(x_208, 1); +lean_inc(x_217); +x_218 = lean_ctor_get(x_208, 3); +lean_inc(x_218); +x_219 = lean_ctor_get(x_208, 4); +lean_inc(x_219); +if (lean_is_exclusive(x_208)) { + lean_ctor_release(x_208, 0); + lean_ctor_release(x_208, 1); + lean_ctor_release(x_208, 2); + lean_ctor_release(x_208, 3); + lean_ctor_release(x_208, 4); + x_220 = x_208; +} else { + lean_dec_ref(x_208); + x_220 = lean_box(0); +} +if (lean_is_scalar(x_220)) { + x_221 = lean_alloc_ctor(0, 5, 0); +} else { + x_221 = x_220; +} +lean_ctor_set(x_221, 0, x_216); +lean_ctor_set(x_221, 1, x_217); +lean_ctor_set(x_221, 2, x_186); +lean_ctor_set(x_221, 3, x_218); +lean_ctor_set(x_221, 4, x_219); +if (lean_is_scalar(x_215)) { + x_222 = lean_alloc_ctor(0, 6, 0); +} else { + x_222 = x_215; +} +lean_ctor_set(x_222, 0, x_210); +lean_ctor_set(x_222, 1, x_211); +lean_ctor_set(x_222, 2, x_221); +lean_ctor_set(x_222, 3, x_212); +lean_ctor_set(x_222, 4, x_213); +lean_ctor_set(x_222, 5, x_214); +if (lean_is_scalar(x_30)) { + x_223 = lean_alloc_ctor(0, 2, 0); +} else { + x_223 = x_30; +} +lean_ctor_set(x_223, 0, x_209); +lean_ctor_set(x_223, 1, x_222); +return x_223; } } } } default: { -lean_object* x_234; lean_object* x_235; -x_234 = lean_ctor_get(x_23, 1); -lean_inc(x_234); +lean_object* x_244; lean_object* x_245; +x_244 = lean_ctor_get(x_23, 1); +lean_inc(x_244); lean_dec(x_23); lean_inc(x_4); -x_235 = l_Lean_Meta_isClassExpensive___main(x_22, x_4, x_234); -if (lean_obj_tag(x_235) == 0) +x_245 = l_Lean_Meta_isClassExpensive___main(x_22, x_4, x_244); +if (lean_obj_tag(x_245) == 0) { -lean_object* x_236; -x_236 = lean_ctor_get(x_235, 0); -lean_inc(x_236); -if (lean_obj_tag(x_236) == 0) +lean_object* x_246; +x_246 = lean_ctor_get(x_245, 0); +lean_inc(x_246); +if (lean_obj_tag(x_246) == 0) { -lean_object* x_237; lean_object* x_238; lean_object* x_239; +lean_object* x_247; lean_object* x_248; lean_object* x_249; lean_dec(x_18); -x_237 = lean_ctor_get(x_235, 1); -lean_inc(x_237); -lean_dec(x_235); -x_238 = lean_unsigned_to_nat(1u); -x_239 = lean_nat_add(x_3, x_238); +x_247 = lean_ctor_get(x_245, 1); +lean_inc(x_247); +lean_dec(x_245); +x_248 = lean_unsigned_to_nat(1u); +x_249 = lean_nat_add(x_3, x_248); lean_dec(x_3); -x_3 = x_239; -x_5 = x_237; +x_3 = x_249; +x_5 = x_247; goto _start; } else { -lean_object* x_241; lean_object* x_242; lean_object* x_243; lean_object* x_244; lean_object* x_245; uint8_t x_246; -x_241 = lean_ctor_get(x_235, 1); -lean_inc(x_241); -if (lean_is_exclusive(x_235)) { - lean_ctor_release(x_235, 0); - lean_ctor_release(x_235, 1); - x_242 = x_235; +lean_object* x_251; lean_object* x_252; lean_object* x_253; lean_object* x_254; lean_object* x_255; uint8_t x_256; +x_251 = lean_ctor_get(x_245, 1); +lean_inc(x_251); +if (lean_is_exclusive(x_245)) { + lean_ctor_release(x_245, 0); + lean_ctor_release(x_245, 1); + x_252 = x_245; } else { - lean_dec_ref(x_235); - x_242 = lean_box(0); + lean_dec_ref(x_245); + x_252 = lean_box(0); } -x_243 = lean_ctor_get(x_236, 0); -lean_inc(x_243); -lean_dec(x_236); -x_244 = lean_unsigned_to_nat(1u); -x_245 = lean_nat_add(x_3, x_244); -lean_dec(x_3); -x_246 = !lean_is_exclusive(x_241); -if (x_246 == 0) -{ -lean_object* x_247; uint8_t x_248; -x_247 = lean_ctor_get(x_241, 2); -x_248 = !lean_is_exclusive(x_247); -if (x_248 == 0) -{ -lean_object* x_249; lean_object* x_250; lean_object* x_251; lean_object* x_301; uint8_t x_302; -x_249 = lean_ctor_get(x_247, 2); -x_301 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_247, 2, x_301); -x_302 = !lean_is_exclusive(x_4); -if (x_302 == 0) -{ -lean_object* x_303; lean_object* x_304; lean_object* x_305; lean_object* x_306; -x_303 = lean_ctor_get(x_4, 2); -x_304 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_304, 0, x_243); -lean_ctor_set(x_304, 1, x_18); -x_305 = lean_array_push(x_303, x_304); -lean_ctor_set(x_4, 2, x_305); -x_306 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__6(x_1, x_2, x_245, x_4, x_241); -if (lean_obj_tag(x_306) == 0) -{ -lean_object* x_307; lean_object* x_308; lean_object* x_309; -x_307 = lean_ctor_get(x_306, 0); -lean_inc(x_307); -x_308 = lean_ctor_get(x_306, 1); -lean_inc(x_308); -lean_dec(x_306); -x_309 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_309, 0, x_307); -x_250 = x_309; -x_251 = x_308; -goto block_300; -} -else -{ -lean_object* x_310; lean_object* x_311; lean_object* x_312; -x_310 = lean_ctor_get(x_306, 0); -lean_inc(x_310); -x_311 = lean_ctor_get(x_306, 1); -lean_inc(x_311); -lean_dec(x_306); -x_312 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_312, 0, x_310); -x_250 = x_312; -x_251 = x_311; -goto block_300; -} -} -else -{ -lean_object* x_313; lean_object* x_314; lean_object* x_315; lean_object* x_316; lean_object* x_317; lean_object* x_318; lean_object* x_319; lean_object* x_320; lean_object* x_321; -x_313 = lean_ctor_get(x_4, 0); -x_314 = lean_ctor_get(x_4, 1); -x_315 = lean_ctor_get(x_4, 2); -x_316 = lean_ctor_get(x_4, 3); -x_317 = lean_ctor_get(x_4, 4); -lean_inc(x_317); -lean_inc(x_316); -lean_inc(x_315); -lean_inc(x_314); -lean_inc(x_313); -lean_dec(x_4); -x_318 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_318, 0, x_243); -lean_ctor_set(x_318, 1, x_18); -x_319 = lean_array_push(x_315, x_318); -x_320 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_320, 0, x_313); -lean_ctor_set(x_320, 1, x_314); -lean_ctor_set(x_320, 2, x_319); -lean_ctor_set(x_320, 3, x_316); -lean_ctor_set(x_320, 4, x_317); -x_321 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__6(x_1, x_2, x_245, x_320, x_241); -if (lean_obj_tag(x_321) == 0) -{ -lean_object* x_322; lean_object* x_323; lean_object* x_324; -x_322 = lean_ctor_get(x_321, 0); -lean_inc(x_322); -x_323 = lean_ctor_get(x_321, 1); -lean_inc(x_323); -lean_dec(x_321); -x_324 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_324, 0, x_322); -x_250 = x_324; -x_251 = x_323; -goto block_300; -} -else -{ -lean_object* x_325; lean_object* x_326; lean_object* x_327; -x_325 = lean_ctor_get(x_321, 0); -lean_inc(x_325); -x_326 = lean_ctor_get(x_321, 1); -lean_inc(x_326); -lean_dec(x_321); -x_327 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_327, 0, x_325); -x_250 = x_327; -x_251 = x_326; -goto block_300; -} -} -block_300: -{ -if (lean_obj_tag(x_250) == 0) -{ -lean_object* x_252; lean_object* x_253; uint8_t x_254; -x_252 = lean_ctor_get(x_251, 2); -lean_inc(x_252); -x_253 = lean_ctor_get(x_250, 0); +x_253 = lean_ctor_get(x_246, 0); lean_inc(x_253); -lean_dec(x_250); -x_254 = !lean_is_exclusive(x_251); -if (x_254 == 0) -{ -lean_object* x_255; uint8_t x_256; -x_255 = lean_ctor_get(x_251, 2); -lean_dec(x_255); -x_256 = !lean_is_exclusive(x_252); +lean_dec(x_246); +x_254 = lean_unsigned_to_nat(1u); +x_255 = lean_nat_add(x_3, x_254); +lean_dec(x_3); +x_256 = !lean_is_exclusive(x_251); if (x_256 == 0) { -lean_object* x_257; lean_object* x_258; -x_257 = lean_ctor_get(x_252, 2); -lean_dec(x_257); -lean_ctor_set(x_252, 2, x_249); -if (lean_is_scalar(x_242)) { - x_258 = lean_alloc_ctor(1, 2, 0); -} else { - x_258 = x_242; - lean_ctor_set_tag(x_258, 1); -} -lean_ctor_set(x_258, 0, x_253); -lean_ctor_set(x_258, 1, x_251); -return x_258; +lean_object* x_257; uint8_t x_258; +x_257 = lean_ctor_get(x_251, 2); +x_258 = !lean_is_exclusive(x_257); +if (x_258 == 0) +{ +lean_object* x_259; lean_object* x_260; lean_object* x_261; lean_object* x_315; uint8_t x_316; +x_259 = lean_ctor_get(x_257, 2); +x_315 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_257, 2, x_315); +x_316 = !lean_is_exclusive(x_4); +if (x_316 == 0) +{ +lean_object* x_317; lean_object* x_318; lean_object* x_319; lean_object* x_320; +x_317 = lean_ctor_get(x_4, 2); +x_318 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_318, 0, x_253); +lean_ctor_set(x_318, 1, x_18); +x_319 = lean_array_push(x_317, x_318); +lean_ctor_set(x_4, 2, x_319); +x_320 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__6(x_1, x_2, x_255, x_4, x_251); +if (lean_obj_tag(x_320) == 0) +{ +lean_object* x_321; lean_object* x_322; lean_object* x_323; +x_321 = lean_ctor_get(x_320, 0); +lean_inc(x_321); +x_322 = lean_ctor_get(x_320, 1); +lean_inc(x_322); +lean_dec(x_320); +x_323 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_323, 0, x_321); +x_260 = x_323; +x_261 = x_322; +goto block_314; } else { -lean_object* x_259; lean_object* x_260; lean_object* x_261; lean_object* x_262; lean_object* x_263; -x_259 = lean_ctor_get(x_252, 0); -x_260 = lean_ctor_get(x_252, 1); -x_261 = lean_ctor_get(x_252, 3); -lean_inc(x_261); -lean_inc(x_260); -lean_inc(x_259); -lean_dec(x_252); -x_262 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_262, 0, x_259); -lean_ctor_set(x_262, 1, x_260); -lean_ctor_set(x_262, 2, x_249); -lean_ctor_set(x_262, 3, x_261); -lean_ctor_set(x_251, 2, x_262); -if (lean_is_scalar(x_242)) { - x_263 = lean_alloc_ctor(1, 2, 0); -} else { - x_263 = x_242; - lean_ctor_set_tag(x_263, 1); -} -lean_ctor_set(x_263, 0, x_253); -lean_ctor_set(x_263, 1, x_251); -return x_263; +lean_object* x_324; lean_object* x_325; lean_object* x_326; +x_324 = lean_ctor_get(x_320, 0); +lean_inc(x_324); +x_325 = lean_ctor_get(x_320, 1); +lean_inc(x_325); +lean_dec(x_320); +x_326 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_326, 0, x_324); +x_260 = x_326; +x_261 = x_325; +goto block_314; } } else { -lean_object* x_264; lean_object* x_265; lean_object* x_266; lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_object* x_270; lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; lean_object* x_275; -x_264 = lean_ctor_get(x_251, 0); -x_265 = lean_ctor_get(x_251, 1); -x_266 = lean_ctor_get(x_251, 3); -x_267 = lean_ctor_get(x_251, 4); -x_268 = lean_ctor_get(x_251, 5); -lean_inc(x_268); -lean_inc(x_267); -lean_inc(x_266); -lean_inc(x_265); -lean_inc(x_264); -lean_dec(x_251); -x_269 = lean_ctor_get(x_252, 0); -lean_inc(x_269); -x_270 = lean_ctor_get(x_252, 1); -lean_inc(x_270); -x_271 = lean_ctor_get(x_252, 3); +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; +x_327 = lean_ctor_get(x_4, 0); +x_328 = lean_ctor_get(x_4, 1); +x_329 = lean_ctor_get(x_4, 2); +x_330 = lean_ctor_get(x_4, 3); +x_331 = lean_ctor_get(x_4, 4); +lean_inc(x_331); +lean_inc(x_330); +lean_inc(x_329); +lean_inc(x_328); +lean_inc(x_327); +lean_dec(x_4); +x_332 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_332, 0, x_253); +lean_ctor_set(x_332, 1, x_18); +x_333 = lean_array_push(x_329, x_332); +x_334 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_334, 0, x_327); +lean_ctor_set(x_334, 1, x_328); +lean_ctor_set(x_334, 2, x_333); +lean_ctor_set(x_334, 3, x_330); +lean_ctor_set(x_334, 4, x_331); +x_335 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__6(x_1, x_2, x_255, x_334, x_251); +if (lean_obj_tag(x_335) == 0) +{ +lean_object* x_336; lean_object* x_337; lean_object* x_338; +x_336 = lean_ctor_get(x_335, 0); +lean_inc(x_336); +x_337 = lean_ctor_get(x_335, 1); +lean_inc(x_337); +lean_dec(x_335); +x_338 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_338, 0, x_336); +x_260 = x_338; +x_261 = x_337; +goto block_314; +} +else +{ +lean_object* x_339; lean_object* x_340; lean_object* x_341; +x_339 = lean_ctor_get(x_335, 0); +lean_inc(x_339); +x_340 = lean_ctor_get(x_335, 1); +lean_inc(x_340); +lean_dec(x_335); +x_341 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_341, 0, x_339); +x_260 = x_341; +x_261 = x_340; +goto block_314; +} +} +block_314: +{ +if (lean_obj_tag(x_260) == 0) +{ +lean_object* x_262; lean_object* x_263; uint8_t x_264; +x_262 = lean_ctor_get(x_261, 2); +lean_inc(x_262); +x_263 = lean_ctor_get(x_260, 0); +lean_inc(x_263); +lean_dec(x_260); +x_264 = !lean_is_exclusive(x_261); +if (x_264 == 0) +{ +lean_object* x_265; uint8_t x_266; +x_265 = lean_ctor_get(x_261, 2); +lean_dec(x_265); +x_266 = !lean_is_exclusive(x_262); +if (x_266 == 0) +{ +lean_object* x_267; lean_object* x_268; +x_267 = lean_ctor_get(x_262, 2); +lean_dec(x_267); +lean_ctor_set(x_262, 2, x_259); +if (lean_is_scalar(x_252)) { + x_268 = lean_alloc_ctor(1, 2, 0); +} else { + x_268 = x_252; + lean_ctor_set_tag(x_268, 1); +} +lean_ctor_set(x_268, 0, x_263); +lean_ctor_set(x_268, 1, x_261); +return x_268; +} +else +{ +lean_object* x_269; lean_object* x_270; lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; +x_269 = lean_ctor_get(x_262, 0); +x_270 = lean_ctor_get(x_262, 1); +x_271 = lean_ctor_get(x_262, 3); +x_272 = lean_ctor_get(x_262, 4); +lean_inc(x_272); lean_inc(x_271); -if (lean_is_exclusive(x_252)) { - lean_ctor_release(x_252, 0); - lean_ctor_release(x_252, 1); - lean_ctor_release(x_252, 2); - lean_ctor_release(x_252, 3); - x_272 = x_252; -} else { - lean_dec_ref(x_252); - x_272 = lean_box(0); -} -if (lean_is_scalar(x_272)) { - x_273 = lean_alloc_ctor(0, 4, 0); -} else { - x_273 = x_272; -} +lean_inc(x_270); +lean_inc(x_269); +lean_dec(x_262); +x_273 = lean_alloc_ctor(0, 5, 0); lean_ctor_set(x_273, 0, x_269); lean_ctor_set(x_273, 1, x_270); -lean_ctor_set(x_273, 2, x_249); +lean_ctor_set(x_273, 2, x_259); lean_ctor_set(x_273, 3, x_271); -x_274 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_274, 0, x_264); -lean_ctor_set(x_274, 1, x_265); -lean_ctor_set(x_274, 2, x_273); -lean_ctor_set(x_274, 3, x_266); -lean_ctor_set(x_274, 4, x_267); -lean_ctor_set(x_274, 5, x_268); -if (lean_is_scalar(x_242)) { - x_275 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_273, 4, x_272); +lean_ctor_set(x_261, 2, x_273); +if (lean_is_scalar(x_252)) { + x_274 = lean_alloc_ctor(1, 2, 0); } else { - x_275 = x_242; - lean_ctor_set_tag(x_275, 1); + x_274 = x_252; + lean_ctor_set_tag(x_274, 1); } -lean_ctor_set(x_275, 0, x_253); -lean_ctor_set(x_275, 1, x_274); -return x_275; +lean_ctor_set(x_274, 0, x_263); +lean_ctor_set(x_274, 1, x_261); +return x_274; } } else { -lean_object* x_276; lean_object* x_277; uint8_t x_278; -x_276 = lean_ctor_get(x_251, 2); -lean_inc(x_276); -x_277 = lean_ctor_get(x_250, 0); +lean_object* x_275; lean_object* x_276; lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; lean_object* x_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; lean_object* x_285; lean_object* x_286; lean_object* x_287; +x_275 = lean_ctor_get(x_261, 0); +x_276 = lean_ctor_get(x_261, 1); +x_277 = lean_ctor_get(x_261, 3); +x_278 = lean_ctor_get(x_261, 4); +x_279 = lean_ctor_get(x_261, 5); +lean_inc(x_279); +lean_inc(x_278); lean_inc(x_277); -lean_dec(x_250); -x_278 = !lean_is_exclusive(x_251); -if (x_278 == 0) -{ -lean_object* x_279; uint8_t x_280; -x_279 = lean_ctor_get(x_251, 2); -lean_dec(x_279); -x_280 = !lean_is_exclusive(x_276); -if (x_280 == 0) -{ -lean_object* x_281; lean_object* x_282; -x_281 = lean_ctor_get(x_276, 2); -lean_dec(x_281); -lean_ctor_set(x_276, 2, x_249); -if (lean_is_scalar(x_242)) { - x_282 = lean_alloc_ctor(0, 2, 0); -} else { - x_282 = x_242; -} -lean_ctor_set(x_282, 0, x_277); -lean_ctor_set(x_282, 1, x_251); -return x_282; -} -else -{ -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_276, 0); -x_284 = lean_ctor_get(x_276, 1); -x_285 = lean_ctor_get(x_276, 3); -lean_inc(x_285); -lean_inc(x_284); +lean_inc(x_276); +lean_inc(x_275); +lean_dec(x_261); +x_280 = lean_ctor_get(x_262, 0); +lean_inc(x_280); +x_281 = lean_ctor_get(x_262, 1); +lean_inc(x_281); +x_282 = lean_ctor_get(x_262, 3); +lean_inc(x_282); +x_283 = lean_ctor_get(x_262, 4); lean_inc(x_283); -lean_dec(x_276); -x_286 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_286, 0, x_283); -lean_ctor_set(x_286, 1, x_284); -lean_ctor_set(x_286, 2, x_249); -lean_ctor_set(x_286, 3, x_285); -lean_ctor_set(x_251, 2, x_286); -if (lean_is_scalar(x_242)) { - x_287 = lean_alloc_ctor(0, 2, 0); +if (lean_is_exclusive(x_262)) { + lean_ctor_release(x_262, 0); + lean_ctor_release(x_262, 1); + lean_ctor_release(x_262, 2); + lean_ctor_release(x_262, 3); + lean_ctor_release(x_262, 4); + x_284 = x_262; } else { - x_287 = x_242; + lean_dec_ref(x_262); + x_284 = lean_box(0); } -lean_ctor_set(x_287, 0, x_277); -lean_ctor_set(x_287, 1, x_251); +if (lean_is_scalar(x_284)) { + x_285 = lean_alloc_ctor(0, 5, 0); +} else { + x_285 = x_284; +} +lean_ctor_set(x_285, 0, x_280); +lean_ctor_set(x_285, 1, x_281); +lean_ctor_set(x_285, 2, x_259); +lean_ctor_set(x_285, 3, x_282); +lean_ctor_set(x_285, 4, x_283); +x_286 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_286, 0, x_275); +lean_ctor_set(x_286, 1, x_276); +lean_ctor_set(x_286, 2, x_285); +lean_ctor_set(x_286, 3, x_277); +lean_ctor_set(x_286, 4, x_278); +lean_ctor_set(x_286, 5, x_279); +if (lean_is_scalar(x_252)) { + x_287 = lean_alloc_ctor(1, 2, 0); +} else { + x_287 = x_252; + lean_ctor_set_tag(x_287, 1); +} +lean_ctor_set(x_287, 0, x_263); +lean_ctor_set(x_287, 1, x_286); return x_287; } } else { -lean_object* x_288; lean_object* x_289; lean_object* x_290; lean_object* x_291; lean_object* x_292; lean_object* x_293; lean_object* x_294; lean_object* x_295; lean_object* x_296; lean_object* x_297; lean_object* x_298; lean_object* x_299; -x_288 = lean_ctor_get(x_251, 0); -x_289 = lean_ctor_get(x_251, 1); -x_290 = lean_ctor_get(x_251, 3); -x_291 = lean_ctor_get(x_251, 4); -x_292 = lean_ctor_get(x_251, 5); -lean_inc(x_292); -lean_inc(x_291); -lean_inc(x_290); -lean_inc(x_289); +lean_object* x_288; lean_object* x_289; uint8_t x_290; +x_288 = lean_ctor_get(x_261, 2); lean_inc(x_288); -lean_dec(x_251); -x_293 = lean_ctor_get(x_276, 0); -lean_inc(x_293); -x_294 = lean_ctor_get(x_276, 1); -lean_inc(x_294); -x_295 = lean_ctor_get(x_276, 3); +x_289 = lean_ctor_get(x_260, 0); +lean_inc(x_289); +lean_dec(x_260); +x_290 = !lean_is_exclusive(x_261); +if (x_290 == 0) +{ +lean_object* x_291; uint8_t x_292; +x_291 = lean_ctor_get(x_261, 2); +lean_dec(x_291); +x_292 = !lean_is_exclusive(x_288); +if (x_292 == 0) +{ +lean_object* x_293; lean_object* x_294; +x_293 = lean_ctor_get(x_288, 2); +lean_dec(x_293); +lean_ctor_set(x_288, 2, x_259); +if (lean_is_scalar(x_252)) { + x_294 = lean_alloc_ctor(0, 2, 0); +} else { + x_294 = x_252; +} +lean_ctor_set(x_294, 0, x_289); +lean_ctor_set(x_294, 1, x_261); +return x_294; +} +else +{ +lean_object* x_295; lean_object* x_296; lean_object* x_297; lean_object* x_298; lean_object* x_299; lean_object* x_300; +x_295 = lean_ctor_get(x_288, 0); +x_296 = lean_ctor_get(x_288, 1); +x_297 = lean_ctor_get(x_288, 3); +x_298 = lean_ctor_get(x_288, 4); +lean_inc(x_298); +lean_inc(x_297); +lean_inc(x_296); lean_inc(x_295); -if (lean_is_exclusive(x_276)) { - lean_ctor_release(x_276, 0); - lean_ctor_release(x_276, 1); - lean_ctor_release(x_276, 2); - lean_ctor_release(x_276, 3); - x_296 = x_276; +lean_dec(x_288); +x_299 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_299, 0, x_295); +lean_ctor_set(x_299, 1, x_296); +lean_ctor_set(x_299, 2, x_259); +lean_ctor_set(x_299, 3, x_297); +lean_ctor_set(x_299, 4, x_298); +lean_ctor_set(x_261, 2, x_299); +if (lean_is_scalar(x_252)) { + x_300 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_276); - x_296 = lean_box(0); + x_300 = x_252; } -if (lean_is_scalar(x_296)) { - x_297 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_300, 0, x_289); +lean_ctor_set(x_300, 1, x_261); +return x_300; +} +} +else +{ +lean_object* x_301; lean_object* x_302; lean_object* x_303; lean_object* x_304; lean_object* x_305; lean_object* x_306; lean_object* x_307; lean_object* x_308; lean_object* x_309; lean_object* x_310; lean_object* x_311; lean_object* x_312; lean_object* x_313; +x_301 = lean_ctor_get(x_261, 0); +x_302 = lean_ctor_get(x_261, 1); +x_303 = lean_ctor_get(x_261, 3); +x_304 = lean_ctor_get(x_261, 4); +x_305 = lean_ctor_get(x_261, 5); +lean_inc(x_305); +lean_inc(x_304); +lean_inc(x_303); +lean_inc(x_302); +lean_inc(x_301); +lean_dec(x_261); +x_306 = lean_ctor_get(x_288, 0); +lean_inc(x_306); +x_307 = lean_ctor_get(x_288, 1); +lean_inc(x_307); +x_308 = lean_ctor_get(x_288, 3); +lean_inc(x_308); +x_309 = lean_ctor_get(x_288, 4); +lean_inc(x_309); +if (lean_is_exclusive(x_288)) { + lean_ctor_release(x_288, 0); + lean_ctor_release(x_288, 1); + lean_ctor_release(x_288, 2); + lean_ctor_release(x_288, 3); + lean_ctor_release(x_288, 4); + x_310 = x_288; } else { - x_297 = x_296; + lean_dec_ref(x_288); + x_310 = lean_box(0); } -lean_ctor_set(x_297, 0, x_293); -lean_ctor_set(x_297, 1, x_294); -lean_ctor_set(x_297, 2, x_249); -lean_ctor_set(x_297, 3, x_295); -x_298 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_298, 0, x_288); -lean_ctor_set(x_298, 1, x_289); -lean_ctor_set(x_298, 2, x_297); -lean_ctor_set(x_298, 3, x_290); -lean_ctor_set(x_298, 4, x_291); -lean_ctor_set(x_298, 5, x_292); -if (lean_is_scalar(x_242)) { - x_299 = lean_alloc_ctor(0, 2, 0); +if (lean_is_scalar(x_310)) { + x_311 = lean_alloc_ctor(0, 5, 0); } else { - x_299 = x_242; + x_311 = x_310; } -lean_ctor_set(x_299, 0, x_277); -lean_ctor_set(x_299, 1, x_298); -return x_299; +lean_ctor_set(x_311, 0, x_306); +lean_ctor_set(x_311, 1, x_307); +lean_ctor_set(x_311, 2, x_259); +lean_ctor_set(x_311, 3, x_308); +lean_ctor_set(x_311, 4, x_309); +x_312 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_312, 0, x_301); +lean_ctor_set(x_312, 1, x_302); +lean_ctor_set(x_312, 2, x_311); +lean_ctor_set(x_312, 3, x_303); +lean_ctor_set(x_312, 4, x_304); +lean_ctor_set(x_312, 5, x_305); +if (lean_is_scalar(x_252)) { + x_313 = lean_alloc_ctor(0, 2, 0); +} else { + x_313 = x_252; +} +lean_ctor_set(x_313, 0, x_289); +lean_ctor_set(x_313, 1, x_312); +return x_313; } } } } else { -lean_object* x_328; lean_object* x_329; lean_object* x_330; lean_object* x_331; lean_object* x_332; lean_object* x_333; lean_object* x_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; lean_object* x_374; lean_object* x_375; lean_object* x_376; -x_328 = lean_ctor_get(x_247, 0); -x_329 = lean_ctor_get(x_247, 1); -x_330 = lean_ctor_get(x_247, 2); -x_331 = lean_ctor_get(x_247, 3); -lean_inc(x_331); -lean_inc(x_330); -lean_inc(x_329); -lean_inc(x_328); -lean_dec(x_247); -x_365 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_366 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_366, 0, x_328); -lean_ctor_set(x_366, 1, x_329); -lean_ctor_set(x_366, 2, x_365); -lean_ctor_set(x_366, 3, x_331); -lean_ctor_set(x_241, 2, x_366); -x_367 = lean_ctor_get(x_4, 0); -lean_inc(x_367); -x_368 = lean_ctor_get(x_4, 1); -lean_inc(x_368); -x_369 = lean_ctor_get(x_4, 2); -lean_inc(x_369); -x_370 = lean_ctor_get(x_4, 3); -lean_inc(x_370); -x_371 = lean_ctor_get(x_4, 4); -lean_inc(x_371); +lean_object* x_342; lean_object* x_343; lean_object* x_344; lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; 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; lean_object* x_391; lean_object* x_392; lean_object* x_393; +x_342 = lean_ctor_get(x_257, 0); +x_343 = lean_ctor_get(x_257, 1); +x_344 = lean_ctor_get(x_257, 2); +x_345 = lean_ctor_get(x_257, 3); +x_346 = lean_ctor_get(x_257, 4); +lean_inc(x_346); +lean_inc(x_345); +lean_inc(x_344); +lean_inc(x_343); +lean_inc(x_342); +lean_dec(x_257); +x_382 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_383 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_383, 0, x_342); +lean_ctor_set(x_383, 1, x_343); +lean_ctor_set(x_383, 2, x_382); +lean_ctor_set(x_383, 3, x_345); +lean_ctor_set(x_383, 4, x_346); +lean_ctor_set(x_251, 2, x_383); +x_384 = lean_ctor_get(x_4, 0); +lean_inc(x_384); +x_385 = lean_ctor_get(x_4, 1); +lean_inc(x_385); +x_386 = lean_ctor_get(x_4, 2); +lean_inc(x_386); +x_387 = lean_ctor_get(x_4, 3); +lean_inc(x_387); +x_388 = lean_ctor_get(x_4, 4); +lean_inc(x_388); if (lean_is_exclusive(x_4)) { lean_ctor_release(x_4, 0); lean_ctor_release(x_4, 1); lean_ctor_release(x_4, 2); lean_ctor_release(x_4, 3); lean_ctor_release(x_4, 4); - x_372 = x_4; + x_389 = x_4; } else { lean_dec_ref(x_4); - x_372 = lean_box(0); + x_389 = lean_box(0); } -x_373 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_373, 0, x_243); -lean_ctor_set(x_373, 1, x_18); -x_374 = lean_array_push(x_369, x_373); -if (lean_is_scalar(x_372)) { - x_375 = lean_alloc_ctor(0, 5, 0); +x_390 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_390, 0, x_253); +lean_ctor_set(x_390, 1, x_18); +x_391 = lean_array_push(x_386, x_390); +if (lean_is_scalar(x_389)) { + x_392 = lean_alloc_ctor(0, 5, 0); } else { - x_375 = x_372; + x_392 = x_389; } -lean_ctor_set(x_375, 0, x_367); -lean_ctor_set(x_375, 1, x_368); -lean_ctor_set(x_375, 2, x_374); -lean_ctor_set(x_375, 3, x_370); -lean_ctor_set(x_375, 4, x_371); -x_376 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__6(x_1, x_2, x_245, x_375, x_241); -if (lean_obj_tag(x_376) == 0) +lean_ctor_set(x_392, 0, x_384); +lean_ctor_set(x_392, 1, x_385); +lean_ctor_set(x_392, 2, x_391); +lean_ctor_set(x_392, 3, x_387); +lean_ctor_set(x_392, 4, x_388); +x_393 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__6(x_1, x_2, x_255, x_392, x_251); +if (lean_obj_tag(x_393) == 0) { -lean_object* x_377; lean_object* x_378; lean_object* x_379; -x_377 = lean_ctor_get(x_376, 0); -lean_inc(x_377); -x_378 = lean_ctor_get(x_376, 1); -lean_inc(x_378); -lean_dec(x_376); -x_379 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_379, 0, x_377); -x_332 = x_379; -x_333 = x_378; -goto block_364; +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_396 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_396, 0, x_394); +x_347 = x_396; +x_348 = x_395; +goto block_381; } else { -lean_object* x_380; lean_object* x_381; lean_object* x_382; -x_380 = lean_ctor_get(x_376, 0); -lean_inc(x_380); -x_381 = lean_ctor_get(x_376, 1); -lean_inc(x_381); -lean_dec(x_376); -x_382 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_382, 0, x_380); -x_332 = x_382; -x_333 = x_381; -goto block_364; +lean_object* x_397; lean_object* x_398; lean_object* x_399; +x_397 = lean_ctor_get(x_393, 0); +lean_inc(x_397); +x_398 = lean_ctor_get(x_393, 1); +lean_inc(x_398); +lean_dec(x_393); +x_399 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_399, 0, x_397); +x_347 = x_399; +x_348 = x_398; +goto block_381; } -block_364: +block_381: { -if (lean_obj_tag(x_332) == 0) +if (lean_obj_tag(x_347) == 0) { -lean_object* x_334; lean_object* x_335; lean_object* x_336; lean_object* x_337; lean_object* x_338; lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; -x_334 = lean_ctor_get(x_333, 2); -lean_inc(x_334); -x_335 = lean_ctor_get(x_332, 0); -lean_inc(x_335); -lean_dec(x_332); -x_336 = lean_ctor_get(x_333, 0); -lean_inc(x_336); -x_337 = lean_ctor_get(x_333, 1); -lean_inc(x_337); -x_338 = lean_ctor_get(x_333, 3); -lean_inc(x_338); -x_339 = lean_ctor_get(x_333, 4); -lean_inc(x_339); -x_340 = lean_ctor_get(x_333, 5); -lean_inc(x_340); -if (lean_is_exclusive(x_333)) { - lean_ctor_release(x_333, 0); - lean_ctor_release(x_333, 1); - lean_ctor_release(x_333, 2); - lean_ctor_release(x_333, 3); - lean_ctor_release(x_333, 4); - lean_ctor_release(x_333, 5); - x_341 = x_333; -} else { - lean_dec_ref(x_333); - x_341 = lean_box(0); -} -x_342 = lean_ctor_get(x_334, 0); -lean_inc(x_342); -x_343 = lean_ctor_get(x_334, 1); -lean_inc(x_343); -x_344 = lean_ctor_get(x_334, 3); -lean_inc(x_344); -if (lean_is_exclusive(x_334)) { - lean_ctor_release(x_334, 0); - lean_ctor_release(x_334, 1); - lean_ctor_release(x_334, 2); - lean_ctor_release(x_334, 3); - x_345 = x_334; -} else { - lean_dec_ref(x_334); - x_345 = lean_box(0); -} -if (lean_is_scalar(x_345)) { - x_346 = lean_alloc_ctor(0, 4, 0); -} else { - x_346 = x_345; -} -lean_ctor_set(x_346, 0, x_342); -lean_ctor_set(x_346, 1, x_343); -lean_ctor_set(x_346, 2, x_330); -lean_ctor_set(x_346, 3, x_344); -if (lean_is_scalar(x_341)) { - x_347 = lean_alloc_ctor(0, 6, 0); -} else { - x_347 = x_341; -} -lean_ctor_set(x_347, 0, x_336); -lean_ctor_set(x_347, 1, x_337); -lean_ctor_set(x_347, 2, x_346); -lean_ctor_set(x_347, 3, x_338); -lean_ctor_set(x_347, 4, x_339); -lean_ctor_set(x_347, 5, x_340); -if (lean_is_scalar(x_242)) { - x_348 = lean_alloc_ctor(1, 2, 0); -} else { - x_348 = x_242; - lean_ctor_set_tag(x_348, 1); -} -lean_ctor_set(x_348, 0, x_335); -lean_ctor_set(x_348, 1, x_347); -return x_348; -} -else -{ -lean_object* x_349; lean_object* x_350; lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; lean_object* x_358; lean_object* x_359; lean_object* x_360; lean_object* x_361; lean_object* x_362; lean_object* x_363; -x_349 = lean_ctor_get(x_333, 2); +lean_object* x_349; lean_object* x_350; lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; 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; +x_349 = lean_ctor_get(x_348, 2); lean_inc(x_349); -x_350 = lean_ctor_get(x_332, 0); +x_350 = lean_ctor_get(x_347, 0); lean_inc(x_350); -lean_dec(x_332); -x_351 = lean_ctor_get(x_333, 0); +lean_dec(x_347); +x_351 = lean_ctor_get(x_348, 0); lean_inc(x_351); -x_352 = lean_ctor_get(x_333, 1); +x_352 = lean_ctor_get(x_348, 1); lean_inc(x_352); -x_353 = lean_ctor_get(x_333, 3); +x_353 = lean_ctor_get(x_348, 3); lean_inc(x_353); -x_354 = lean_ctor_get(x_333, 4); +x_354 = lean_ctor_get(x_348, 4); lean_inc(x_354); -x_355 = lean_ctor_get(x_333, 5); +x_355 = lean_ctor_get(x_348, 5); lean_inc(x_355); -if (lean_is_exclusive(x_333)) { - lean_ctor_release(x_333, 0); - lean_ctor_release(x_333, 1); - lean_ctor_release(x_333, 2); - lean_ctor_release(x_333, 3); - lean_ctor_release(x_333, 4); - lean_ctor_release(x_333, 5); - x_356 = x_333; +if (lean_is_exclusive(x_348)) { + lean_ctor_release(x_348, 0); + lean_ctor_release(x_348, 1); + lean_ctor_release(x_348, 2); + lean_ctor_release(x_348, 3); + lean_ctor_release(x_348, 4); + lean_ctor_release(x_348, 5); + x_356 = x_348; } else { - lean_dec_ref(x_333); + lean_dec_ref(x_348); x_356 = lean_box(0); } x_357 = lean_ctor_get(x_349, 0); @@ -16343,315 +16723,411 @@ x_358 = lean_ctor_get(x_349, 1); lean_inc(x_358); x_359 = lean_ctor_get(x_349, 3); lean_inc(x_359); +x_360 = lean_ctor_get(x_349, 4); +lean_inc(x_360); if (lean_is_exclusive(x_349)) { lean_ctor_release(x_349, 0); lean_ctor_release(x_349, 1); lean_ctor_release(x_349, 2); lean_ctor_release(x_349, 3); - x_360 = x_349; + lean_ctor_release(x_349, 4); + x_361 = x_349; } else { lean_dec_ref(x_349); - x_360 = lean_box(0); + x_361 = lean_box(0); } -if (lean_is_scalar(x_360)) { - x_361 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_361)) { + x_362 = lean_alloc_ctor(0, 5, 0); } else { - x_361 = x_360; + x_362 = x_361; } -lean_ctor_set(x_361, 0, x_357); -lean_ctor_set(x_361, 1, x_358); -lean_ctor_set(x_361, 2, x_330); -lean_ctor_set(x_361, 3, x_359); +lean_ctor_set(x_362, 0, x_357); +lean_ctor_set(x_362, 1, x_358); +lean_ctor_set(x_362, 2, x_344); +lean_ctor_set(x_362, 3, x_359); +lean_ctor_set(x_362, 4, x_360); if (lean_is_scalar(x_356)) { - x_362 = lean_alloc_ctor(0, 6, 0); + x_363 = lean_alloc_ctor(0, 6, 0); } else { - x_362 = x_356; + x_363 = x_356; } -lean_ctor_set(x_362, 0, x_351); -lean_ctor_set(x_362, 1, x_352); -lean_ctor_set(x_362, 2, x_361); -lean_ctor_set(x_362, 3, x_353); -lean_ctor_set(x_362, 4, x_354); -lean_ctor_set(x_362, 5, x_355); -if (lean_is_scalar(x_242)) { - x_363 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_363, 0, x_351); +lean_ctor_set(x_363, 1, x_352); +lean_ctor_set(x_363, 2, x_362); +lean_ctor_set(x_363, 3, x_353); +lean_ctor_set(x_363, 4, x_354); +lean_ctor_set(x_363, 5, x_355); +if (lean_is_scalar(x_252)) { + x_364 = lean_alloc_ctor(1, 2, 0); } else { - x_363 = x_242; + x_364 = x_252; + lean_ctor_set_tag(x_364, 1); } -lean_ctor_set(x_363, 0, x_350); -lean_ctor_set(x_363, 1, x_362); -return x_363; +lean_ctor_set(x_364, 0, x_350); +lean_ctor_set(x_364, 1, x_363); +return x_364; +} +else +{ +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; lean_object* x_374; lean_object* x_375; lean_object* x_376; lean_object* x_377; lean_object* x_378; lean_object* x_379; lean_object* x_380; +x_365 = lean_ctor_get(x_348, 2); +lean_inc(x_365); +x_366 = lean_ctor_get(x_347, 0); +lean_inc(x_366); +lean_dec(x_347); +x_367 = lean_ctor_get(x_348, 0); +lean_inc(x_367); +x_368 = lean_ctor_get(x_348, 1); +lean_inc(x_368); +x_369 = lean_ctor_get(x_348, 3); +lean_inc(x_369); +x_370 = lean_ctor_get(x_348, 4); +lean_inc(x_370); +x_371 = lean_ctor_get(x_348, 5); +lean_inc(x_371); +if (lean_is_exclusive(x_348)) { + lean_ctor_release(x_348, 0); + lean_ctor_release(x_348, 1); + lean_ctor_release(x_348, 2); + lean_ctor_release(x_348, 3); + lean_ctor_release(x_348, 4); + lean_ctor_release(x_348, 5); + x_372 = x_348; +} else { + lean_dec_ref(x_348); + x_372 = lean_box(0); +} +x_373 = lean_ctor_get(x_365, 0); +lean_inc(x_373); +x_374 = lean_ctor_get(x_365, 1); +lean_inc(x_374); +x_375 = lean_ctor_get(x_365, 3); +lean_inc(x_375); +x_376 = lean_ctor_get(x_365, 4); +lean_inc(x_376); +if (lean_is_exclusive(x_365)) { + lean_ctor_release(x_365, 0); + lean_ctor_release(x_365, 1); + lean_ctor_release(x_365, 2); + lean_ctor_release(x_365, 3); + lean_ctor_release(x_365, 4); + x_377 = x_365; +} else { + lean_dec_ref(x_365); + x_377 = lean_box(0); +} +if (lean_is_scalar(x_377)) { + x_378 = lean_alloc_ctor(0, 5, 0); +} else { + x_378 = x_377; +} +lean_ctor_set(x_378, 0, x_373); +lean_ctor_set(x_378, 1, x_374); +lean_ctor_set(x_378, 2, x_344); +lean_ctor_set(x_378, 3, x_375); +lean_ctor_set(x_378, 4, x_376); +if (lean_is_scalar(x_372)) { + x_379 = lean_alloc_ctor(0, 6, 0); +} else { + x_379 = x_372; +} +lean_ctor_set(x_379, 0, x_367); +lean_ctor_set(x_379, 1, x_368); +lean_ctor_set(x_379, 2, x_378); +lean_ctor_set(x_379, 3, x_369); +lean_ctor_set(x_379, 4, x_370); +lean_ctor_set(x_379, 5, x_371); +if (lean_is_scalar(x_252)) { + x_380 = lean_alloc_ctor(0, 2, 0); +} else { + x_380 = x_252; +} +lean_ctor_set(x_380, 0, x_366); +lean_ctor_set(x_380, 1, x_379); +return x_380; } } } } else { -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; lean_object* x_391; lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_427; 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; -x_383 = lean_ctor_get(x_241, 2); -x_384 = lean_ctor_get(x_241, 0); -x_385 = lean_ctor_get(x_241, 1); -x_386 = lean_ctor_get(x_241, 3); -x_387 = lean_ctor_get(x_241, 4); -x_388 = lean_ctor_get(x_241, 5); -lean_inc(x_388); -lean_inc(x_387); -lean_inc(x_386); -lean_inc(x_383); -lean_inc(x_385); -lean_inc(x_384); -lean_dec(x_241); -x_389 = lean_ctor_get(x_383, 0); -lean_inc(x_389); -x_390 = lean_ctor_get(x_383, 1); -lean_inc(x_390); -x_391 = lean_ctor_get(x_383, 2); -lean_inc(x_391); -x_392 = lean_ctor_get(x_383, 3); -lean_inc(x_392); -if (lean_is_exclusive(x_383)) { - lean_ctor_release(x_383, 0); - lean_ctor_release(x_383, 1); - lean_ctor_release(x_383, 2); - lean_ctor_release(x_383, 3); - x_393 = x_383; +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; lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_object* x_412; lean_object* x_413; lean_object* x_447; lean_object* x_448; lean_object* x_449; lean_object* x_450; lean_object* x_451; lean_object* x_452; lean_object* x_453; lean_object* x_454; lean_object* x_455; lean_object* x_456; lean_object* x_457; lean_object* x_458; lean_object* x_459; +x_400 = lean_ctor_get(x_251, 2); +x_401 = lean_ctor_get(x_251, 0); +x_402 = lean_ctor_get(x_251, 1); +x_403 = lean_ctor_get(x_251, 3); +x_404 = lean_ctor_get(x_251, 4); +x_405 = lean_ctor_get(x_251, 5); +lean_inc(x_405); +lean_inc(x_404); +lean_inc(x_403); +lean_inc(x_400); +lean_inc(x_402); +lean_inc(x_401); +lean_dec(x_251); +x_406 = lean_ctor_get(x_400, 0); +lean_inc(x_406); +x_407 = lean_ctor_get(x_400, 1); +lean_inc(x_407); +x_408 = lean_ctor_get(x_400, 2); +lean_inc(x_408); +x_409 = lean_ctor_get(x_400, 3); +lean_inc(x_409); +x_410 = lean_ctor_get(x_400, 4); +lean_inc(x_410); +if (lean_is_exclusive(x_400)) { + lean_ctor_release(x_400, 0); + lean_ctor_release(x_400, 1); + lean_ctor_release(x_400, 2); + lean_ctor_release(x_400, 3); + lean_ctor_release(x_400, 4); + x_411 = x_400; } else { - lean_dec_ref(x_383); - x_393 = lean_box(0); + lean_dec_ref(x_400); + x_411 = lean_box(0); } -x_427 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_393)) { - x_428 = lean_alloc_ctor(0, 4, 0); +x_447 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_411)) { + x_448 = lean_alloc_ctor(0, 5, 0); } else { - x_428 = x_393; + x_448 = x_411; } -lean_ctor_set(x_428, 0, x_389); -lean_ctor_set(x_428, 1, x_390); -lean_ctor_set(x_428, 2, x_427); -lean_ctor_set(x_428, 3, x_392); -x_429 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_429, 0, x_384); -lean_ctor_set(x_429, 1, x_385); -lean_ctor_set(x_429, 2, x_428); -lean_ctor_set(x_429, 3, x_386); -lean_ctor_set(x_429, 4, x_387); -lean_ctor_set(x_429, 5, x_388); -x_430 = lean_ctor_get(x_4, 0); -lean_inc(x_430); -x_431 = lean_ctor_get(x_4, 1); -lean_inc(x_431); -x_432 = lean_ctor_get(x_4, 2); -lean_inc(x_432); -x_433 = lean_ctor_get(x_4, 3); -lean_inc(x_433); -x_434 = lean_ctor_get(x_4, 4); -lean_inc(x_434); +lean_ctor_set(x_448, 0, x_406); +lean_ctor_set(x_448, 1, x_407); +lean_ctor_set(x_448, 2, x_447); +lean_ctor_set(x_448, 3, x_409); +lean_ctor_set(x_448, 4, x_410); +x_449 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_449, 0, x_401); +lean_ctor_set(x_449, 1, x_402); +lean_ctor_set(x_449, 2, x_448); +lean_ctor_set(x_449, 3, x_403); +lean_ctor_set(x_449, 4, x_404); +lean_ctor_set(x_449, 5, x_405); +x_450 = lean_ctor_get(x_4, 0); +lean_inc(x_450); +x_451 = lean_ctor_get(x_4, 1); +lean_inc(x_451); +x_452 = lean_ctor_get(x_4, 2); +lean_inc(x_452); +x_453 = lean_ctor_get(x_4, 3); +lean_inc(x_453); +x_454 = lean_ctor_get(x_4, 4); +lean_inc(x_454); if (lean_is_exclusive(x_4)) { lean_ctor_release(x_4, 0); lean_ctor_release(x_4, 1); lean_ctor_release(x_4, 2); lean_ctor_release(x_4, 3); lean_ctor_release(x_4, 4); - x_435 = x_4; + x_455 = x_4; } else { lean_dec_ref(x_4); - x_435 = lean_box(0); + x_455 = lean_box(0); } -x_436 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_436, 0, x_243); -lean_ctor_set(x_436, 1, x_18); -x_437 = lean_array_push(x_432, x_436); -if (lean_is_scalar(x_435)) { - x_438 = lean_alloc_ctor(0, 5, 0); +x_456 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_456, 0, x_253); +lean_ctor_set(x_456, 1, x_18); +x_457 = lean_array_push(x_452, x_456); +if (lean_is_scalar(x_455)) { + x_458 = lean_alloc_ctor(0, 5, 0); } else { - x_438 = x_435; + x_458 = x_455; } -lean_ctor_set(x_438, 0, x_430); -lean_ctor_set(x_438, 1, x_431); -lean_ctor_set(x_438, 2, x_437); -lean_ctor_set(x_438, 3, x_433); -lean_ctor_set(x_438, 4, x_434); -x_439 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__6(x_1, x_2, x_245, x_438, x_429); -if (lean_obj_tag(x_439) == 0) +lean_ctor_set(x_458, 0, x_450); +lean_ctor_set(x_458, 1, x_451); +lean_ctor_set(x_458, 2, x_457); +lean_ctor_set(x_458, 3, x_453); +lean_ctor_set(x_458, 4, x_454); +x_459 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__6(x_1, x_2, x_255, x_458, x_449); +if (lean_obj_tag(x_459) == 0) { -lean_object* x_440; lean_object* x_441; lean_object* x_442; -x_440 = lean_ctor_get(x_439, 0); -lean_inc(x_440); -x_441 = lean_ctor_get(x_439, 1); -lean_inc(x_441); -lean_dec(x_439); -x_442 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_442, 0, x_440); -x_394 = x_442; -x_395 = x_441; -goto block_426; +lean_object* x_460; lean_object* x_461; lean_object* x_462; +x_460 = lean_ctor_get(x_459, 0); +lean_inc(x_460); +x_461 = lean_ctor_get(x_459, 1); +lean_inc(x_461); +lean_dec(x_459); +x_462 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_462, 0, x_460); +x_412 = x_462; +x_413 = x_461; +goto block_446; } else { -lean_object* x_443; lean_object* x_444; lean_object* x_445; -x_443 = lean_ctor_get(x_439, 0); -lean_inc(x_443); -x_444 = lean_ctor_get(x_439, 1); -lean_inc(x_444); -lean_dec(x_439); -x_445 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_445, 0, x_443); -x_394 = x_445; -x_395 = x_444; -goto block_426; +lean_object* x_463; lean_object* x_464; lean_object* x_465; +x_463 = lean_ctor_get(x_459, 0); +lean_inc(x_463); +x_464 = lean_ctor_get(x_459, 1); +lean_inc(x_464); +lean_dec(x_459); +x_465 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_465, 0, x_463); +x_412 = x_465; +x_413 = x_464; +goto block_446; } -block_426: +block_446: { -if (lean_obj_tag(x_394) == 0) +if (lean_obj_tag(x_412) == 0) { -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; lean_object* x_408; lean_object* x_409; lean_object* x_410; -x_396 = lean_ctor_get(x_395, 2); -lean_inc(x_396); -x_397 = lean_ctor_get(x_394, 0); -lean_inc(x_397); -lean_dec(x_394); -x_398 = lean_ctor_get(x_395, 0); -lean_inc(x_398); -x_399 = lean_ctor_get(x_395, 1); -lean_inc(x_399); -x_400 = lean_ctor_get(x_395, 3); -lean_inc(x_400); -x_401 = lean_ctor_get(x_395, 4); -lean_inc(x_401); -x_402 = lean_ctor_get(x_395, 5); -lean_inc(x_402); -if (lean_is_exclusive(x_395)) { - lean_ctor_release(x_395, 0); - lean_ctor_release(x_395, 1); - lean_ctor_release(x_395, 2); - lean_ctor_release(x_395, 3); - lean_ctor_release(x_395, 4); - lean_ctor_release(x_395, 5); - x_403 = x_395; -} else { - lean_dec_ref(x_395); - x_403 = lean_box(0); -} -x_404 = lean_ctor_get(x_396, 0); -lean_inc(x_404); -x_405 = lean_ctor_get(x_396, 1); -lean_inc(x_405); -x_406 = lean_ctor_get(x_396, 3); -lean_inc(x_406); -if (lean_is_exclusive(x_396)) { - lean_ctor_release(x_396, 0); - lean_ctor_release(x_396, 1); - lean_ctor_release(x_396, 2); - lean_ctor_release(x_396, 3); - x_407 = x_396; -} else { - lean_dec_ref(x_396); - x_407 = lean_box(0); -} -if (lean_is_scalar(x_407)) { - x_408 = lean_alloc_ctor(0, 4, 0); -} else { - x_408 = x_407; -} -lean_ctor_set(x_408, 0, x_404); -lean_ctor_set(x_408, 1, x_405); -lean_ctor_set(x_408, 2, x_391); -lean_ctor_set(x_408, 3, x_406); -if (lean_is_scalar(x_403)) { - x_409 = lean_alloc_ctor(0, 6, 0); -} else { - x_409 = x_403; -} -lean_ctor_set(x_409, 0, x_398); -lean_ctor_set(x_409, 1, x_399); -lean_ctor_set(x_409, 2, x_408); -lean_ctor_set(x_409, 3, x_400); -lean_ctor_set(x_409, 4, x_401); -lean_ctor_set(x_409, 5, x_402); -if (lean_is_scalar(x_242)) { - x_410 = lean_alloc_ctor(1, 2, 0); -} else { - x_410 = x_242; - lean_ctor_set_tag(x_410, 1); -} -lean_ctor_set(x_410, 0, x_397); -lean_ctor_set(x_410, 1, x_409); -return x_410; -} -else -{ -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_395, 2); -lean_inc(x_411); -x_412 = lean_ctor_get(x_394, 0); -lean_inc(x_412); -lean_dec(x_394); -x_413 = lean_ctor_get(x_395, 0); -lean_inc(x_413); -x_414 = lean_ctor_get(x_395, 1); +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; lean_object* x_426; lean_object* x_427; lean_object* x_428; lean_object* x_429; +x_414 = lean_ctor_get(x_413, 2); lean_inc(x_414); -x_415 = lean_ctor_get(x_395, 3); +x_415 = lean_ctor_get(x_412, 0); lean_inc(x_415); -x_416 = lean_ctor_get(x_395, 4); +lean_dec(x_412); +x_416 = lean_ctor_get(x_413, 0); lean_inc(x_416); -x_417 = lean_ctor_get(x_395, 5); +x_417 = lean_ctor_get(x_413, 1); lean_inc(x_417); -if (lean_is_exclusive(x_395)) { - lean_ctor_release(x_395, 0); - lean_ctor_release(x_395, 1); - lean_ctor_release(x_395, 2); - lean_ctor_release(x_395, 3); - lean_ctor_release(x_395, 4); - lean_ctor_release(x_395, 5); - x_418 = x_395; -} else { - lean_dec_ref(x_395); - x_418 = lean_box(0); -} -x_419 = lean_ctor_get(x_411, 0); +x_418 = lean_ctor_get(x_413, 3); +lean_inc(x_418); +x_419 = lean_ctor_get(x_413, 4); lean_inc(x_419); -x_420 = lean_ctor_get(x_411, 1); +x_420 = lean_ctor_get(x_413, 5); lean_inc(x_420); -x_421 = lean_ctor_get(x_411, 3); -lean_inc(x_421); -if (lean_is_exclusive(x_411)) { - lean_ctor_release(x_411, 0); - lean_ctor_release(x_411, 1); - lean_ctor_release(x_411, 2); - lean_ctor_release(x_411, 3); - x_422 = x_411; +if (lean_is_exclusive(x_413)) { + lean_ctor_release(x_413, 0); + lean_ctor_release(x_413, 1); + lean_ctor_release(x_413, 2); + lean_ctor_release(x_413, 3); + lean_ctor_release(x_413, 4); + lean_ctor_release(x_413, 5); + x_421 = x_413; } else { - lean_dec_ref(x_411); - x_422 = lean_box(0); + lean_dec_ref(x_413); + x_421 = lean_box(0); } -if (lean_is_scalar(x_422)) { - x_423 = lean_alloc_ctor(0, 4, 0); +x_422 = lean_ctor_get(x_414, 0); +lean_inc(x_422); +x_423 = lean_ctor_get(x_414, 1); +lean_inc(x_423); +x_424 = lean_ctor_get(x_414, 3); +lean_inc(x_424); +x_425 = lean_ctor_get(x_414, 4); +lean_inc(x_425); +if (lean_is_exclusive(x_414)) { + lean_ctor_release(x_414, 0); + lean_ctor_release(x_414, 1); + lean_ctor_release(x_414, 2); + lean_ctor_release(x_414, 3); + lean_ctor_release(x_414, 4); + x_426 = x_414; } else { - x_423 = x_422; + lean_dec_ref(x_414); + x_426 = lean_box(0); } -lean_ctor_set(x_423, 0, x_419); -lean_ctor_set(x_423, 1, x_420); -lean_ctor_set(x_423, 2, x_391); -lean_ctor_set(x_423, 3, x_421); -if (lean_is_scalar(x_418)) { - x_424 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_426)) { + x_427 = lean_alloc_ctor(0, 5, 0); } else { - x_424 = x_418; + x_427 = x_426; } -lean_ctor_set(x_424, 0, x_413); -lean_ctor_set(x_424, 1, x_414); -lean_ctor_set(x_424, 2, x_423); -lean_ctor_set(x_424, 3, x_415); -lean_ctor_set(x_424, 4, x_416); -lean_ctor_set(x_424, 5, x_417); -if (lean_is_scalar(x_242)) { - x_425 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_427, 0, x_422); +lean_ctor_set(x_427, 1, x_423); +lean_ctor_set(x_427, 2, x_408); +lean_ctor_set(x_427, 3, x_424); +lean_ctor_set(x_427, 4, x_425); +if (lean_is_scalar(x_421)) { + x_428 = lean_alloc_ctor(0, 6, 0); } else { - x_425 = x_242; + x_428 = x_421; } -lean_ctor_set(x_425, 0, x_412); -lean_ctor_set(x_425, 1, x_424); -return x_425; +lean_ctor_set(x_428, 0, x_416); +lean_ctor_set(x_428, 1, x_417); +lean_ctor_set(x_428, 2, x_427); +lean_ctor_set(x_428, 3, x_418); +lean_ctor_set(x_428, 4, x_419); +lean_ctor_set(x_428, 5, x_420); +if (lean_is_scalar(x_252)) { + x_429 = lean_alloc_ctor(1, 2, 0); +} else { + x_429 = x_252; + lean_ctor_set_tag(x_429, 1); +} +lean_ctor_set(x_429, 0, x_415); +lean_ctor_set(x_429, 1, x_428); +return x_429; +} +else +{ +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; lean_object* x_445; +x_430 = lean_ctor_get(x_413, 2); +lean_inc(x_430); +x_431 = lean_ctor_get(x_412, 0); +lean_inc(x_431); +lean_dec(x_412); +x_432 = lean_ctor_get(x_413, 0); +lean_inc(x_432); +x_433 = lean_ctor_get(x_413, 1); +lean_inc(x_433); +x_434 = lean_ctor_get(x_413, 3); +lean_inc(x_434); +x_435 = lean_ctor_get(x_413, 4); +lean_inc(x_435); +x_436 = lean_ctor_get(x_413, 5); +lean_inc(x_436); +if (lean_is_exclusive(x_413)) { + lean_ctor_release(x_413, 0); + lean_ctor_release(x_413, 1); + lean_ctor_release(x_413, 2); + lean_ctor_release(x_413, 3); + lean_ctor_release(x_413, 4); + lean_ctor_release(x_413, 5); + x_437 = x_413; +} else { + lean_dec_ref(x_413); + x_437 = lean_box(0); +} +x_438 = lean_ctor_get(x_430, 0); +lean_inc(x_438); +x_439 = lean_ctor_get(x_430, 1); +lean_inc(x_439); +x_440 = lean_ctor_get(x_430, 3); +lean_inc(x_440); +x_441 = lean_ctor_get(x_430, 4); +lean_inc(x_441); +if (lean_is_exclusive(x_430)) { + lean_ctor_release(x_430, 0); + lean_ctor_release(x_430, 1); + lean_ctor_release(x_430, 2); + lean_ctor_release(x_430, 3); + lean_ctor_release(x_430, 4); + x_442 = x_430; +} else { + lean_dec_ref(x_430); + x_442 = lean_box(0); +} +if (lean_is_scalar(x_442)) { + x_443 = lean_alloc_ctor(0, 5, 0); +} else { + x_443 = x_442; +} +lean_ctor_set(x_443, 0, x_438); +lean_ctor_set(x_443, 1, x_439); +lean_ctor_set(x_443, 2, x_408); +lean_ctor_set(x_443, 3, x_440); +lean_ctor_set(x_443, 4, x_441); +if (lean_is_scalar(x_437)) { + x_444 = lean_alloc_ctor(0, 6, 0); +} else { + x_444 = x_437; +} +lean_ctor_set(x_444, 0, x_432); +lean_ctor_set(x_444, 1, x_433); +lean_ctor_set(x_444, 2, x_443); +lean_ctor_set(x_444, 3, x_434); +lean_ctor_set(x_444, 4, x_435); +lean_ctor_set(x_444, 5, x_436); +if (lean_is_scalar(x_252)) { + x_445 = lean_alloc_ctor(0, 2, 0); +} else { + x_445 = x_252; +} +lean_ctor_set(x_445, 0, x_431); +lean_ctor_set(x_445, 1, x_444); +return x_445; } } } @@ -16659,27 +17135,27 @@ return x_425; } else { -uint8_t x_446; +uint8_t x_466; lean_dec(x_18); lean_dec(x_4); lean_dec(x_3); -x_446 = !lean_is_exclusive(x_235); -if (x_446 == 0) +x_466 = !lean_is_exclusive(x_245); +if (x_466 == 0) { -return x_235; +return x_245; } else { -lean_object* x_447; lean_object* x_448; lean_object* x_449; -x_447 = lean_ctor_get(x_235, 0); -x_448 = lean_ctor_get(x_235, 1); -lean_inc(x_448); -lean_inc(x_447); -lean_dec(x_235); -x_449 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_449, 0, x_447); -lean_ctor_set(x_449, 1, x_448); -return x_449; +lean_object* x_467; lean_object* x_468; lean_object* x_469; +x_467 = lean_ctor_get(x_245, 0); +x_468 = lean_ctor_get(x_245, 1); +lean_inc(x_468); +lean_inc(x_467); +lean_dec(x_245); +x_469 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_469, 0, x_467); +lean_ctor_set(x_469, 1, x_468); +return x_469; } } } @@ -16687,54 +17163,54 @@ return x_449; } else { -uint8_t x_450; +uint8_t x_470; lean_dec(x_22); lean_dec(x_18); lean_dec(x_4); lean_dec(x_3); -x_450 = !lean_is_exclusive(x_23); -if (x_450 == 0) +x_470 = !lean_is_exclusive(x_23); +if (x_470 == 0) { return x_23; } else { -lean_object* x_451; lean_object* x_452; lean_object* x_453; -x_451 = lean_ctor_get(x_23, 0); -x_452 = lean_ctor_get(x_23, 1); -lean_inc(x_452); -lean_inc(x_451); +lean_object* x_471; lean_object* x_472; lean_object* x_473; +x_471 = lean_ctor_get(x_23, 0); +x_472 = lean_ctor_get(x_23, 1); +lean_inc(x_472); +lean_inc(x_471); lean_dec(x_23); -x_453 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_453, 0, x_451); -lean_ctor_set(x_453, 1, x_452); -return x_453; +x_473 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_473, 0, x_471); +lean_ctor_set(x_473, 1, x_472); +return x_473; } } } else { -uint8_t x_454; +uint8_t x_474; lean_dec(x_18); lean_dec(x_4); lean_dec(x_3); -x_454 = !lean_is_exclusive(x_19); -if (x_454 == 0) +x_474 = !lean_is_exclusive(x_19); +if (x_474 == 0) { return x_19; } else { -lean_object* x_455; lean_object* x_456; lean_object* x_457; -x_455 = lean_ctor_get(x_19, 0); -x_456 = lean_ctor_get(x_19, 1); -lean_inc(x_456); -lean_inc(x_455); +lean_object* x_475; lean_object* x_476; lean_object* x_477; +x_475 = lean_ctor_get(x_19, 0); +x_476 = lean_ctor_get(x_19, 1); +lean_inc(x_476); +lean_inc(x_475); lean_dec(x_19); -x_457 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_457, 0, x_455); -lean_ctor_set(x_457, 1, x_456); -return x_457; +x_477 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_477, 0, x_475); +lean_ctor_set(x_477, 1, x_476); +return x_477; } } } @@ -17379,105 +17855,105 @@ x_31 = lean_ctor_get(x_25, 2); x_32 = !lean_is_exclusive(x_31); if (x_32 == 0) { -lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_85; uint8_t x_86; +lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_89; uint8_t x_90; x_33 = lean_ctor_get(x_31, 2); -x_85 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_31, 2, x_85); -x_86 = !lean_is_exclusive(x_7); -if (x_86 == 0) +x_89 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_31, 2, x_89); +x_90 = !lean_is_exclusive(x_7); +if (x_90 == 0) { -lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; -x_87 = lean_ctor_get(x_7, 2); -x_88 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_88, 0, x_27); -lean_ctor_set(x_88, 1, x_14); -x_89 = lean_array_push(x_87, x_88); -lean_ctor_set(x_7, 2, x_89); -x_90 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__2___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_7, x_25); -if (lean_obj_tag(x_90) == 0) +lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; +x_91 = lean_ctor_get(x_7, 2); +x_92 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_92, 0, x_27); +lean_ctor_set(x_92, 1, x_14); +x_93 = lean_array_push(x_91, x_92); +lean_ctor_set(x_7, 2, x_93); +x_94 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__2___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_7, x_25); +if (lean_obj_tag(x_94) == 0) { -lean_object* x_91; lean_object* x_92; lean_object* x_93; -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_alloc_ctor(1, 1, 0); -lean_ctor_set(x_93, 0, x_91); -x_34 = x_93; -x_35 = x_92; -goto block_84; -} -else -{ -lean_object* x_94; lean_object* x_95; lean_object* x_96; -x_94 = lean_ctor_get(x_90, 0); -lean_inc(x_94); -x_95 = lean_ctor_get(x_90, 1); +lean_object* x_95; lean_object* x_96; lean_object* x_97; +x_95 = lean_ctor_get(x_94, 0); lean_inc(x_95); -lean_dec(x_90); -x_96 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_96, 0, x_94); -x_34 = x_96; -x_35 = x_95; -goto block_84; -} +x_96 = lean_ctor_get(x_94, 1); +lean_inc(x_96); +lean_dec(x_94); +x_97 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_97, 0, x_95); +x_34 = x_97; +x_35 = x_96; +goto block_88; } else { -lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; -x_97 = lean_ctor_get(x_7, 0); -x_98 = lean_ctor_get(x_7, 1); -x_99 = lean_ctor_get(x_7, 2); -x_100 = lean_ctor_get(x_7, 3); -x_101 = lean_ctor_get(x_7, 4); -lean_inc(x_101); -lean_inc(x_100); -lean_inc(x_99); +lean_object* x_98; lean_object* x_99; lean_object* x_100; +x_98 = lean_ctor_get(x_94, 0); lean_inc(x_98); -lean_inc(x_97); -lean_dec(x_7); -x_102 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_102, 0, x_27); -lean_ctor_set(x_102, 1, x_14); -x_103 = lean_array_push(x_99, x_102); -x_104 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_104, 0, x_97); -lean_ctor_set(x_104, 1, x_98); -lean_ctor_set(x_104, 2, x_103); -lean_ctor_set(x_104, 3, x_100); -lean_ctor_set(x_104, 4, x_101); -x_105 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__2___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_104, x_25); -if (lean_obj_tag(x_105) == 0) -{ -lean_object* x_106; lean_object* x_107; lean_object* x_108; -x_106 = lean_ctor_get(x_105, 0); -lean_inc(x_106); -x_107 = lean_ctor_get(x_105, 1); -lean_inc(x_107); -lean_dec(x_105); -x_108 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_108, 0, x_106); -x_34 = x_108; -x_35 = x_107; -goto block_84; +x_99 = lean_ctor_get(x_94, 1); +lean_inc(x_99); +lean_dec(x_94); +x_100 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_100, 0, x_98); +x_34 = x_100; +x_35 = x_99; +goto block_88; +} } else { -lean_object* x_109; lean_object* x_110; lean_object* x_111; -x_109 = lean_ctor_get(x_105, 0); -lean_inc(x_109); -x_110 = lean_ctor_get(x_105, 1); +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; +x_101 = lean_ctor_get(x_7, 0); +x_102 = lean_ctor_get(x_7, 1); +x_103 = lean_ctor_get(x_7, 2); +x_104 = lean_ctor_get(x_7, 3); +x_105 = lean_ctor_get(x_7, 4); +lean_inc(x_105); +lean_inc(x_104); +lean_inc(x_103); +lean_inc(x_102); +lean_inc(x_101); +lean_dec(x_7); +x_106 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_106, 0, x_27); +lean_ctor_set(x_106, 1, x_14); +x_107 = lean_array_push(x_103, x_106); +x_108 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_108, 0, x_101); +lean_ctor_set(x_108, 1, x_102); +lean_ctor_set(x_108, 2, x_107); +lean_ctor_set(x_108, 3, x_104); +lean_ctor_set(x_108, 4, x_105); +x_109 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__2___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_108, x_25); +if (lean_obj_tag(x_109) == 0) +{ +lean_object* x_110; lean_object* x_111; lean_object* x_112; +x_110 = lean_ctor_get(x_109, 0); lean_inc(x_110); -lean_dec(x_105); -x_111 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_111, 0, x_109); -x_34 = x_111; -x_35 = x_110; -goto block_84; +x_111 = lean_ctor_get(x_109, 1); +lean_inc(x_111); +lean_dec(x_109); +x_112 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_112, 0, x_110); +x_34 = x_112; +x_35 = x_111; +goto block_88; +} +else +{ +lean_object* x_113; lean_object* x_114; lean_object* x_115; +x_113 = lean_ctor_get(x_109, 0); +lean_inc(x_113); +x_114 = lean_ctor_get(x_109, 1); +lean_inc(x_114); +lean_dec(x_109); +x_115 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_115, 0, x_113); +x_34 = x_115; +x_35 = x_114; +goto block_88; } } -block_84: +block_88: { if (lean_obj_tag(x_34) == 0) { @@ -17512,1284 +17988,1262 @@ return x_42; } else { -lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; +lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; x_43 = lean_ctor_get(x_36, 0); x_44 = lean_ctor_get(x_36, 1); x_45 = lean_ctor_get(x_36, 3); +x_46 = lean_ctor_get(x_36, 4); +lean_inc(x_46); lean_inc(x_45); lean_inc(x_44); lean_inc(x_43); lean_dec(x_36); -x_46 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_46, 0, x_43); -lean_ctor_set(x_46, 1, x_44); -lean_ctor_set(x_46, 2, x_33); -lean_ctor_set(x_46, 3, x_45); -lean_ctor_set(x_35, 2, x_46); +x_47 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_47, 0, x_43); +lean_ctor_set(x_47, 1, x_44); +lean_ctor_set(x_47, 2, x_33); +lean_ctor_set(x_47, 3, x_45); +lean_ctor_set(x_47, 4, x_46); +lean_ctor_set(x_35, 2, x_47); if (lean_is_scalar(x_26)) { - x_47 = lean_alloc_ctor(1, 2, 0); + x_48 = lean_alloc_ctor(1, 2, 0); } else { - x_47 = x_26; - lean_ctor_set_tag(x_47, 1); + x_48 = x_26; + lean_ctor_set_tag(x_48, 1); } -lean_ctor_set(x_47, 0, x_37); -lean_ctor_set(x_47, 1, x_35); -return x_47; +lean_ctor_set(x_48, 0, x_37); +lean_ctor_set(x_48, 1, x_35); +return x_48; } } else { -lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; -x_48 = lean_ctor_get(x_35, 0); -x_49 = lean_ctor_get(x_35, 1); -x_50 = lean_ctor_get(x_35, 3); -x_51 = lean_ctor_get(x_35, 4); -x_52 = lean_ctor_get(x_35, 5); +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; +x_49 = lean_ctor_get(x_35, 0); +x_50 = lean_ctor_get(x_35, 1); +x_51 = lean_ctor_get(x_35, 3); +x_52 = lean_ctor_get(x_35, 4); +x_53 = lean_ctor_get(x_35, 5); +lean_inc(x_53); lean_inc(x_52); lean_inc(x_51); lean_inc(x_50); lean_inc(x_49); -lean_inc(x_48); lean_dec(x_35); -x_53 = lean_ctor_get(x_36, 0); -lean_inc(x_53); -x_54 = lean_ctor_get(x_36, 1); +x_54 = lean_ctor_get(x_36, 0); lean_inc(x_54); -x_55 = lean_ctor_get(x_36, 3); +x_55 = lean_ctor_get(x_36, 1); lean_inc(x_55); +x_56 = lean_ctor_get(x_36, 3); +lean_inc(x_56); +x_57 = lean_ctor_get(x_36, 4); +lean_inc(x_57); if (lean_is_exclusive(x_36)) { lean_ctor_release(x_36, 0); lean_ctor_release(x_36, 1); lean_ctor_release(x_36, 2); lean_ctor_release(x_36, 3); - x_56 = x_36; + lean_ctor_release(x_36, 4); + x_58 = x_36; } else { lean_dec_ref(x_36); - x_56 = lean_box(0); + x_58 = lean_box(0); } -if (lean_is_scalar(x_56)) { - x_57 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_58)) { + x_59 = lean_alloc_ctor(0, 5, 0); } else { - x_57 = x_56; + x_59 = x_58; } -lean_ctor_set(x_57, 0, x_53); -lean_ctor_set(x_57, 1, x_54); -lean_ctor_set(x_57, 2, x_33); -lean_ctor_set(x_57, 3, x_55); -x_58 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_58, 0, x_48); -lean_ctor_set(x_58, 1, x_49); -lean_ctor_set(x_58, 2, x_57); -lean_ctor_set(x_58, 3, x_50); -lean_ctor_set(x_58, 4, x_51); -lean_ctor_set(x_58, 5, x_52); +lean_ctor_set(x_59, 0, x_54); +lean_ctor_set(x_59, 1, x_55); +lean_ctor_set(x_59, 2, x_33); +lean_ctor_set(x_59, 3, x_56); +lean_ctor_set(x_59, 4, x_57); +x_60 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_60, 0, x_49); +lean_ctor_set(x_60, 1, x_50); +lean_ctor_set(x_60, 2, x_59); +lean_ctor_set(x_60, 3, x_51); +lean_ctor_set(x_60, 4, x_52); +lean_ctor_set(x_60, 5, x_53); if (lean_is_scalar(x_26)) { - x_59 = lean_alloc_ctor(1, 2, 0); + x_61 = lean_alloc_ctor(1, 2, 0); } else { - x_59 = x_26; - lean_ctor_set_tag(x_59, 1); + x_61 = x_26; + lean_ctor_set_tag(x_61, 1); } -lean_ctor_set(x_59, 0, x_37); -lean_ctor_set(x_59, 1, x_58); -return x_59; +lean_ctor_set(x_61, 0, x_37); +lean_ctor_set(x_61, 1, x_60); +return x_61; } } else { -lean_object* x_60; lean_object* x_61; uint8_t x_62; -x_60 = lean_ctor_get(x_35, 2); -lean_inc(x_60); -x_61 = lean_ctor_get(x_34, 0); -lean_inc(x_61); +lean_object* x_62; lean_object* x_63; uint8_t x_64; +x_62 = lean_ctor_get(x_35, 2); +lean_inc(x_62); +x_63 = lean_ctor_get(x_34, 0); +lean_inc(x_63); lean_dec(x_34); -x_62 = !lean_is_exclusive(x_35); -if (x_62 == 0) -{ -lean_object* x_63; uint8_t x_64; -x_63 = lean_ctor_get(x_35, 2); -lean_dec(x_63); -x_64 = !lean_is_exclusive(x_60); +x_64 = !lean_is_exclusive(x_35); if (x_64 == 0) { -lean_object* x_65; lean_object* x_66; -x_65 = lean_ctor_get(x_60, 2); +lean_object* x_65; uint8_t x_66; +x_65 = lean_ctor_get(x_35, 2); lean_dec(x_65); -lean_ctor_set(x_60, 2, x_33); +x_66 = !lean_is_exclusive(x_62); +if (x_66 == 0) +{ +lean_object* x_67; lean_object* x_68; +x_67 = lean_ctor_get(x_62, 2); +lean_dec(x_67); +lean_ctor_set(x_62, 2, x_33); if (lean_is_scalar(x_26)) { - x_66 = lean_alloc_ctor(0, 2, 0); + x_68 = lean_alloc_ctor(0, 2, 0); } else { - x_66 = x_26; + x_68 = x_26; } -lean_ctor_set(x_66, 0, x_61); -lean_ctor_set(x_66, 1, x_35); -return x_66; +lean_ctor_set(x_68, 0, x_63); +lean_ctor_set(x_68, 1, x_35); +return x_68; } else { -lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; -x_67 = lean_ctor_get(x_60, 0); -x_68 = lean_ctor_get(x_60, 1); -x_69 = lean_ctor_get(x_60, 3); +lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; +x_69 = lean_ctor_get(x_62, 0); +x_70 = lean_ctor_get(x_62, 1); +x_71 = lean_ctor_get(x_62, 3); +x_72 = lean_ctor_get(x_62, 4); +lean_inc(x_72); +lean_inc(x_71); +lean_inc(x_70); lean_inc(x_69); -lean_inc(x_68); -lean_inc(x_67); -lean_dec(x_60); -x_70 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_70, 0, x_67); -lean_ctor_set(x_70, 1, x_68); -lean_ctor_set(x_70, 2, x_33); -lean_ctor_set(x_70, 3, x_69); -lean_ctor_set(x_35, 2, x_70); +lean_dec(x_62); +x_73 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_73, 0, x_69); +lean_ctor_set(x_73, 1, x_70); +lean_ctor_set(x_73, 2, x_33); +lean_ctor_set(x_73, 3, x_71); +lean_ctor_set(x_73, 4, x_72); +lean_ctor_set(x_35, 2, x_73); if (lean_is_scalar(x_26)) { - x_71 = lean_alloc_ctor(0, 2, 0); + x_74 = lean_alloc_ctor(0, 2, 0); } else { - x_71 = x_26; + x_74 = x_26; } -lean_ctor_set(x_71, 0, x_61); -lean_ctor_set(x_71, 1, x_35); -return x_71; +lean_ctor_set(x_74, 0, x_63); +lean_ctor_set(x_74, 1, x_35); +return x_74; } } else { -lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; -x_72 = lean_ctor_get(x_35, 0); -x_73 = lean_ctor_get(x_35, 1); -x_74 = lean_ctor_get(x_35, 3); -x_75 = lean_ctor_get(x_35, 4); -x_76 = lean_ctor_get(x_35, 5); +lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; +x_75 = lean_ctor_get(x_35, 0); +x_76 = lean_ctor_get(x_35, 1); +x_77 = lean_ctor_get(x_35, 3); +x_78 = lean_ctor_get(x_35, 4); +x_79 = lean_ctor_get(x_35, 5); +lean_inc(x_79); +lean_inc(x_78); +lean_inc(x_77); lean_inc(x_76); lean_inc(x_75); -lean_inc(x_74); -lean_inc(x_73); -lean_inc(x_72); lean_dec(x_35); -x_77 = lean_ctor_get(x_60, 0); -lean_inc(x_77); -x_78 = lean_ctor_get(x_60, 1); -lean_inc(x_78); -x_79 = lean_ctor_get(x_60, 3); -lean_inc(x_79); -if (lean_is_exclusive(x_60)) { - lean_ctor_release(x_60, 0); - lean_ctor_release(x_60, 1); - lean_ctor_release(x_60, 2); - lean_ctor_release(x_60, 3); - x_80 = x_60; +x_80 = lean_ctor_get(x_62, 0); +lean_inc(x_80); +x_81 = lean_ctor_get(x_62, 1); +lean_inc(x_81); +x_82 = lean_ctor_get(x_62, 3); +lean_inc(x_82); +x_83 = lean_ctor_get(x_62, 4); +lean_inc(x_83); +if (lean_is_exclusive(x_62)) { + lean_ctor_release(x_62, 0); + lean_ctor_release(x_62, 1); + lean_ctor_release(x_62, 2); + lean_ctor_release(x_62, 3); + lean_ctor_release(x_62, 4); + x_84 = x_62; } else { - lean_dec_ref(x_60); - x_80 = lean_box(0); + lean_dec_ref(x_62); + x_84 = lean_box(0); } -if (lean_is_scalar(x_80)) { - x_81 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_84)) { + x_85 = lean_alloc_ctor(0, 5, 0); } else { - x_81 = x_80; + x_85 = x_84; } -lean_ctor_set(x_81, 0, x_77); -lean_ctor_set(x_81, 1, x_78); -lean_ctor_set(x_81, 2, x_33); -lean_ctor_set(x_81, 3, x_79); -x_82 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_82, 0, x_72); -lean_ctor_set(x_82, 1, x_73); -lean_ctor_set(x_82, 2, x_81); -lean_ctor_set(x_82, 3, x_74); -lean_ctor_set(x_82, 4, x_75); -lean_ctor_set(x_82, 5, x_76); +lean_ctor_set(x_85, 0, x_80); +lean_ctor_set(x_85, 1, x_81); +lean_ctor_set(x_85, 2, x_33); +lean_ctor_set(x_85, 3, x_82); +lean_ctor_set(x_85, 4, x_83); +x_86 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_86, 0, x_75); +lean_ctor_set(x_86, 1, x_76); +lean_ctor_set(x_86, 2, x_85); +lean_ctor_set(x_86, 3, x_77); +lean_ctor_set(x_86, 4, x_78); +lean_ctor_set(x_86, 5, x_79); if (lean_is_scalar(x_26)) { - x_83 = lean_alloc_ctor(0, 2, 0); + x_87 = lean_alloc_ctor(0, 2, 0); } else { - x_83 = x_26; + x_87 = x_26; } -lean_ctor_set(x_83, 0, x_61); -lean_ctor_set(x_83, 1, x_82); -return x_83; +lean_ctor_set(x_87, 0, x_63); +lean_ctor_set(x_87, 1, x_86); +return x_87; } } } } else { -lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_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; -x_112 = lean_ctor_get(x_31, 0); -x_113 = lean_ctor_get(x_31, 1); -x_114 = lean_ctor_get(x_31, 2); -x_115 = lean_ctor_get(x_31, 3); -lean_inc(x_115); -lean_inc(x_114); -lean_inc(x_113); -lean_inc(x_112); -lean_dec(x_31); -x_149 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_150 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_150, 0, x_112); -lean_ctor_set(x_150, 1, x_113); -lean_ctor_set(x_150, 2, x_149); -lean_ctor_set(x_150, 3, x_115); -lean_ctor_set(x_25, 2, x_150); -x_151 = lean_ctor_get(x_7, 0); -lean_inc(x_151); -x_152 = lean_ctor_get(x_7, 1); -lean_inc(x_152); -x_153 = lean_ctor_get(x_7, 2); -lean_inc(x_153); -x_154 = lean_ctor_get(x_7, 3); -lean_inc(x_154); -x_155 = lean_ctor_get(x_7, 4); -lean_inc(x_155); -if (lean_is_exclusive(x_7)) { - lean_ctor_release(x_7, 0); - lean_ctor_release(x_7, 1); - lean_ctor_release(x_7, 2); - lean_ctor_release(x_7, 3); - lean_ctor_release(x_7, 4); - x_156 = x_7; -} else { - lean_dec_ref(x_7); - x_156 = lean_box(0); -} -x_157 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_157, 0, x_27); -lean_ctor_set(x_157, 1, x_14); -x_158 = lean_array_push(x_153, x_157); -if (lean_is_scalar(x_156)) { - x_159 = lean_alloc_ctor(0, 5, 0); -} else { - x_159 = x_156; -} -lean_ctor_set(x_159, 0, x_151); -lean_ctor_set(x_159, 1, x_152); -lean_ctor_set(x_159, 2, x_158); -lean_ctor_set(x_159, 3, x_154); -lean_ctor_set(x_159, 4, x_155); -x_160 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__2___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_159, x_25); -if (lean_obj_tag(x_160) == 0) -{ -lean_object* x_161; lean_object* x_162; lean_object* x_163; -x_161 = lean_ctor_get(x_160, 0); -lean_inc(x_161); -x_162 = lean_ctor_get(x_160, 1); -lean_inc(x_162); -lean_dec(x_160); -x_163 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_163, 0, x_161); -x_116 = x_163; -x_117 = x_162; -goto block_148; -} -else -{ -lean_object* x_164; lean_object* x_165; lean_object* x_166; -x_164 = lean_ctor_get(x_160, 0); -lean_inc(x_164); -x_165 = lean_ctor_get(x_160, 1); -lean_inc(x_165); -lean_dec(x_160); -x_166 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_166, 0, x_164); -x_116 = x_166; -x_117 = x_165; -goto block_148; -} -block_148: -{ -if (lean_obj_tag(x_116) == 0) -{ -lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; -x_118 = lean_ctor_get(x_117, 2); -lean_inc(x_118); -x_119 = lean_ctor_get(x_116, 0); -lean_inc(x_119); -lean_dec(x_116); -x_120 = lean_ctor_get(x_117, 0); +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_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; +x_116 = lean_ctor_get(x_31, 0); +x_117 = lean_ctor_get(x_31, 1); +x_118 = lean_ctor_get(x_31, 2); +x_119 = lean_ctor_get(x_31, 3); +x_120 = lean_ctor_get(x_31, 4); lean_inc(x_120); -x_121 = lean_ctor_get(x_117, 1); -lean_inc(x_121); -x_122 = lean_ctor_get(x_117, 3); -lean_inc(x_122); -x_123 = lean_ctor_get(x_117, 4); -lean_inc(x_123); -x_124 = lean_ctor_get(x_117, 5); -lean_inc(x_124); -if (lean_is_exclusive(x_117)) { - lean_ctor_release(x_117, 0); - lean_ctor_release(x_117, 1); - lean_ctor_release(x_117, 2); - lean_ctor_release(x_117, 3); - lean_ctor_release(x_117, 4); - lean_ctor_release(x_117, 5); - x_125 = x_117; -} else { - lean_dec_ref(x_117); - x_125 = lean_box(0); -} -x_126 = lean_ctor_get(x_118, 0); -lean_inc(x_126); -x_127 = lean_ctor_get(x_118, 1); -lean_inc(x_127); -x_128 = lean_ctor_get(x_118, 3); -lean_inc(x_128); -if (lean_is_exclusive(x_118)) { - lean_ctor_release(x_118, 0); - lean_ctor_release(x_118, 1); - lean_ctor_release(x_118, 2); - lean_ctor_release(x_118, 3); - x_129 = x_118; -} else { - lean_dec_ref(x_118); - x_129 = lean_box(0); -} -if (lean_is_scalar(x_129)) { - x_130 = lean_alloc_ctor(0, 4, 0); -} else { - x_130 = x_129; -} -lean_ctor_set(x_130, 0, x_126); -lean_ctor_set(x_130, 1, x_127); -lean_ctor_set(x_130, 2, x_114); -lean_ctor_set(x_130, 3, x_128); -if (lean_is_scalar(x_125)) { - x_131 = lean_alloc_ctor(0, 6, 0); -} else { - x_131 = x_125; -} -lean_ctor_set(x_131, 0, x_120); -lean_ctor_set(x_131, 1, x_121); -lean_ctor_set(x_131, 2, x_130); -lean_ctor_set(x_131, 3, x_122); -lean_ctor_set(x_131, 4, x_123); -lean_ctor_set(x_131, 5, x_124); -if (lean_is_scalar(x_26)) { - x_132 = lean_alloc_ctor(1, 2, 0); -} else { - x_132 = x_26; - lean_ctor_set_tag(x_132, 1); -} -lean_ctor_set(x_132, 0, x_119); -lean_ctor_set(x_132, 1, x_131); -return x_132; -} -else -{ -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; -x_133 = lean_ctor_get(x_117, 2); -lean_inc(x_133); -x_134 = lean_ctor_get(x_116, 0); -lean_inc(x_134); -lean_dec(x_116); -x_135 = lean_ctor_get(x_117, 0); -lean_inc(x_135); -x_136 = lean_ctor_get(x_117, 1); -lean_inc(x_136); -x_137 = lean_ctor_get(x_117, 3); -lean_inc(x_137); -x_138 = lean_ctor_get(x_117, 4); -lean_inc(x_138); -x_139 = lean_ctor_get(x_117, 5); -lean_inc(x_139); -if (lean_is_exclusive(x_117)) { - lean_ctor_release(x_117, 0); - lean_ctor_release(x_117, 1); - lean_ctor_release(x_117, 2); - lean_ctor_release(x_117, 3); - lean_ctor_release(x_117, 4); - lean_ctor_release(x_117, 5); - x_140 = x_117; -} else { - lean_dec_ref(x_117); - x_140 = lean_box(0); -} -x_141 = lean_ctor_get(x_133, 0); -lean_inc(x_141); -x_142 = lean_ctor_get(x_133, 1); -lean_inc(x_142); -x_143 = lean_ctor_get(x_133, 3); -lean_inc(x_143); -if (lean_is_exclusive(x_133)) { - lean_ctor_release(x_133, 0); - lean_ctor_release(x_133, 1); - lean_ctor_release(x_133, 2); - lean_ctor_release(x_133, 3); - x_144 = x_133; -} else { - lean_dec_ref(x_133); - x_144 = lean_box(0); -} -if (lean_is_scalar(x_144)) { - x_145 = lean_alloc_ctor(0, 4, 0); -} else { - x_145 = x_144; -} -lean_ctor_set(x_145, 0, x_141); -lean_ctor_set(x_145, 1, x_142); -lean_ctor_set(x_145, 2, x_114); -lean_ctor_set(x_145, 3, x_143); -if (lean_is_scalar(x_140)) { - x_146 = lean_alloc_ctor(0, 6, 0); -} else { - x_146 = x_140; -} -lean_ctor_set(x_146, 0, x_135); -lean_ctor_set(x_146, 1, x_136); -lean_ctor_set(x_146, 2, x_145); -lean_ctor_set(x_146, 3, x_137); -lean_ctor_set(x_146, 4, x_138); -lean_ctor_set(x_146, 5, x_139); -if (lean_is_scalar(x_26)) { - x_147 = lean_alloc_ctor(0, 2, 0); -} else { - x_147 = x_26; -} -lean_ctor_set(x_147, 0, x_134); -lean_ctor_set(x_147, 1, x_146); -return x_147; -} -} -} -} -else -{ -lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; 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; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; -x_167 = lean_ctor_get(x_25, 2); -x_168 = lean_ctor_get(x_25, 0); -x_169 = lean_ctor_get(x_25, 1); -x_170 = lean_ctor_get(x_25, 3); -x_171 = lean_ctor_get(x_25, 4); -x_172 = lean_ctor_get(x_25, 5); -lean_inc(x_172); -lean_inc(x_171); -lean_inc(x_170); -lean_inc(x_167); -lean_inc(x_169); -lean_inc(x_168); -lean_dec(x_25); -x_173 = lean_ctor_get(x_167, 0); -lean_inc(x_173); -x_174 = lean_ctor_get(x_167, 1); -lean_inc(x_174); -x_175 = lean_ctor_get(x_167, 2); -lean_inc(x_175); -x_176 = lean_ctor_get(x_167, 3); -lean_inc(x_176); -if (lean_is_exclusive(x_167)) { - lean_ctor_release(x_167, 0); - lean_ctor_release(x_167, 1); - lean_ctor_release(x_167, 2); - lean_ctor_release(x_167, 3); - x_177 = x_167; -} else { - lean_dec_ref(x_167); - x_177 = lean_box(0); -} -x_211 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_177)) { - x_212 = lean_alloc_ctor(0, 4, 0); -} else { - x_212 = x_177; -} -lean_ctor_set(x_212, 0, x_173); -lean_ctor_set(x_212, 1, x_174); -lean_ctor_set(x_212, 2, x_211); -lean_ctor_set(x_212, 3, x_176); -x_213 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_213, 0, x_168); -lean_ctor_set(x_213, 1, x_169); -lean_ctor_set(x_213, 2, x_212); -lean_ctor_set(x_213, 3, x_170); -lean_ctor_set(x_213, 4, x_171); -lean_ctor_set(x_213, 5, x_172); -x_214 = lean_ctor_get(x_7, 0); -lean_inc(x_214); -x_215 = lean_ctor_get(x_7, 1); -lean_inc(x_215); -x_216 = lean_ctor_get(x_7, 2); -lean_inc(x_216); -x_217 = lean_ctor_get(x_7, 3); -lean_inc(x_217); -x_218 = lean_ctor_get(x_7, 4); -lean_inc(x_218); +lean_inc(x_119); +lean_inc(x_118); +lean_inc(x_117); +lean_inc(x_116); +lean_dec(x_31); +x_156 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_157 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_157, 0, x_116); +lean_ctor_set(x_157, 1, x_117); +lean_ctor_set(x_157, 2, x_156); +lean_ctor_set(x_157, 3, x_119); +lean_ctor_set(x_157, 4, x_120); +lean_ctor_set(x_25, 2, x_157); +x_158 = lean_ctor_get(x_7, 0); +lean_inc(x_158); +x_159 = lean_ctor_get(x_7, 1); +lean_inc(x_159); +x_160 = lean_ctor_get(x_7, 2); +lean_inc(x_160); +x_161 = lean_ctor_get(x_7, 3); +lean_inc(x_161); +x_162 = lean_ctor_get(x_7, 4); +lean_inc(x_162); if (lean_is_exclusive(x_7)) { lean_ctor_release(x_7, 0); lean_ctor_release(x_7, 1); lean_ctor_release(x_7, 2); lean_ctor_release(x_7, 3); lean_ctor_release(x_7, 4); - x_219 = x_7; + x_163 = x_7; } else { lean_dec_ref(x_7); - x_219 = lean_box(0); + x_163 = lean_box(0); } -x_220 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_220, 0, x_27); -lean_ctor_set(x_220, 1, x_14); -x_221 = lean_array_push(x_216, x_220); -if (lean_is_scalar(x_219)) { +x_164 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_164, 0, x_27); +lean_ctor_set(x_164, 1, x_14); +x_165 = lean_array_push(x_160, x_164); +if (lean_is_scalar(x_163)) { + x_166 = lean_alloc_ctor(0, 5, 0); +} else { + x_166 = x_163; +} +lean_ctor_set(x_166, 0, x_158); +lean_ctor_set(x_166, 1, x_159); +lean_ctor_set(x_166, 2, x_165); +lean_ctor_set(x_166, 3, x_161); +lean_ctor_set(x_166, 4, x_162); +x_167 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__2___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_166, x_25); +if (lean_obj_tag(x_167) == 0) +{ +lean_object* x_168; lean_object* x_169; lean_object* x_170; +x_168 = lean_ctor_get(x_167, 0); +lean_inc(x_168); +x_169 = lean_ctor_get(x_167, 1); +lean_inc(x_169); +lean_dec(x_167); +x_170 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_170, 0, x_168); +x_121 = x_170; +x_122 = x_169; +goto block_155; +} +else +{ +lean_object* x_171; lean_object* x_172; lean_object* x_173; +x_171 = lean_ctor_get(x_167, 0); +lean_inc(x_171); +x_172 = lean_ctor_get(x_167, 1); +lean_inc(x_172); +lean_dec(x_167); +x_173 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_173, 0, x_171); +x_121 = x_173; +x_122 = x_172; +goto block_155; +} +block_155: +{ +if (lean_obj_tag(x_121) == 0) +{ +lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; +x_123 = lean_ctor_get(x_122, 2); +lean_inc(x_123); +x_124 = lean_ctor_get(x_121, 0); +lean_inc(x_124); +lean_dec(x_121); +x_125 = lean_ctor_get(x_122, 0); +lean_inc(x_125); +x_126 = lean_ctor_get(x_122, 1); +lean_inc(x_126); +x_127 = lean_ctor_get(x_122, 3); +lean_inc(x_127); +x_128 = lean_ctor_get(x_122, 4); +lean_inc(x_128); +x_129 = lean_ctor_get(x_122, 5); +lean_inc(x_129); +if (lean_is_exclusive(x_122)) { + lean_ctor_release(x_122, 0); + lean_ctor_release(x_122, 1); + lean_ctor_release(x_122, 2); + lean_ctor_release(x_122, 3); + lean_ctor_release(x_122, 4); + lean_ctor_release(x_122, 5); + x_130 = x_122; +} else { + lean_dec_ref(x_122); + x_130 = lean_box(0); +} +x_131 = lean_ctor_get(x_123, 0); +lean_inc(x_131); +x_132 = lean_ctor_get(x_123, 1); +lean_inc(x_132); +x_133 = lean_ctor_get(x_123, 3); +lean_inc(x_133); +x_134 = lean_ctor_get(x_123, 4); +lean_inc(x_134); +if (lean_is_exclusive(x_123)) { + lean_ctor_release(x_123, 0); + lean_ctor_release(x_123, 1); + lean_ctor_release(x_123, 2); + lean_ctor_release(x_123, 3); + lean_ctor_release(x_123, 4); + x_135 = x_123; +} else { + lean_dec_ref(x_123); + x_135 = lean_box(0); +} +if (lean_is_scalar(x_135)) { + x_136 = lean_alloc_ctor(0, 5, 0); +} else { + x_136 = x_135; +} +lean_ctor_set(x_136, 0, x_131); +lean_ctor_set(x_136, 1, x_132); +lean_ctor_set(x_136, 2, x_118); +lean_ctor_set(x_136, 3, x_133); +lean_ctor_set(x_136, 4, x_134); +if (lean_is_scalar(x_130)) { + x_137 = lean_alloc_ctor(0, 6, 0); +} else { + x_137 = x_130; +} +lean_ctor_set(x_137, 0, x_125); +lean_ctor_set(x_137, 1, x_126); +lean_ctor_set(x_137, 2, x_136); +lean_ctor_set(x_137, 3, x_127); +lean_ctor_set(x_137, 4, x_128); +lean_ctor_set(x_137, 5, x_129); +if (lean_is_scalar(x_26)) { + x_138 = lean_alloc_ctor(1, 2, 0); +} else { + x_138 = x_26; + lean_ctor_set_tag(x_138, 1); +} +lean_ctor_set(x_138, 0, x_124); +lean_ctor_set(x_138, 1, x_137); +return x_138; +} +else +{ +lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_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; +x_139 = lean_ctor_get(x_122, 2); +lean_inc(x_139); +x_140 = lean_ctor_get(x_121, 0); +lean_inc(x_140); +lean_dec(x_121); +x_141 = lean_ctor_get(x_122, 0); +lean_inc(x_141); +x_142 = lean_ctor_get(x_122, 1); +lean_inc(x_142); +x_143 = lean_ctor_get(x_122, 3); +lean_inc(x_143); +x_144 = lean_ctor_get(x_122, 4); +lean_inc(x_144); +x_145 = lean_ctor_get(x_122, 5); +lean_inc(x_145); +if (lean_is_exclusive(x_122)) { + lean_ctor_release(x_122, 0); + lean_ctor_release(x_122, 1); + lean_ctor_release(x_122, 2); + lean_ctor_release(x_122, 3); + lean_ctor_release(x_122, 4); + lean_ctor_release(x_122, 5); + x_146 = x_122; +} else { + lean_dec_ref(x_122); + x_146 = lean_box(0); +} +x_147 = lean_ctor_get(x_139, 0); +lean_inc(x_147); +x_148 = lean_ctor_get(x_139, 1); +lean_inc(x_148); +x_149 = lean_ctor_get(x_139, 3); +lean_inc(x_149); +x_150 = lean_ctor_get(x_139, 4); +lean_inc(x_150); +if (lean_is_exclusive(x_139)) { + lean_ctor_release(x_139, 0); + lean_ctor_release(x_139, 1); + lean_ctor_release(x_139, 2); + lean_ctor_release(x_139, 3); + lean_ctor_release(x_139, 4); + x_151 = x_139; +} else { + lean_dec_ref(x_139); + x_151 = lean_box(0); +} +if (lean_is_scalar(x_151)) { + x_152 = lean_alloc_ctor(0, 5, 0); +} else { + x_152 = x_151; +} +lean_ctor_set(x_152, 0, x_147); +lean_ctor_set(x_152, 1, x_148); +lean_ctor_set(x_152, 2, x_118); +lean_ctor_set(x_152, 3, x_149); +lean_ctor_set(x_152, 4, x_150); +if (lean_is_scalar(x_146)) { + x_153 = lean_alloc_ctor(0, 6, 0); +} else { + x_153 = x_146; +} +lean_ctor_set(x_153, 0, x_141); +lean_ctor_set(x_153, 1, x_142); +lean_ctor_set(x_153, 2, x_152); +lean_ctor_set(x_153, 3, x_143); +lean_ctor_set(x_153, 4, x_144); +lean_ctor_set(x_153, 5, x_145); +if (lean_is_scalar(x_26)) { + x_154 = lean_alloc_ctor(0, 2, 0); +} else { + x_154 = x_26; +} +lean_ctor_set(x_154, 0, x_140); +lean_ctor_set(x_154, 1, x_153); +return x_154; +} +} +} +} +else +{ +lean_object* x_174; lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_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; lean_object* x_231; lean_object* x_232; lean_object* x_233; +x_174 = lean_ctor_get(x_25, 2); +x_175 = lean_ctor_get(x_25, 0); +x_176 = lean_ctor_get(x_25, 1); +x_177 = lean_ctor_get(x_25, 3); +x_178 = lean_ctor_get(x_25, 4); +x_179 = lean_ctor_get(x_25, 5); +lean_inc(x_179); +lean_inc(x_178); +lean_inc(x_177); +lean_inc(x_174); +lean_inc(x_176); +lean_inc(x_175); +lean_dec(x_25); +x_180 = lean_ctor_get(x_174, 0); +lean_inc(x_180); +x_181 = lean_ctor_get(x_174, 1); +lean_inc(x_181); +x_182 = lean_ctor_get(x_174, 2); +lean_inc(x_182); +x_183 = lean_ctor_get(x_174, 3); +lean_inc(x_183); +x_184 = lean_ctor_get(x_174, 4); +lean_inc(x_184); +if (lean_is_exclusive(x_174)) { + lean_ctor_release(x_174, 0); + lean_ctor_release(x_174, 1); + lean_ctor_release(x_174, 2); + lean_ctor_release(x_174, 3); + lean_ctor_release(x_174, 4); + x_185 = x_174; +} else { + lean_dec_ref(x_174); + x_185 = lean_box(0); +} +x_221 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_185)) { x_222 = lean_alloc_ctor(0, 5, 0); } else { - x_222 = x_219; + x_222 = x_185; } -lean_ctor_set(x_222, 0, x_214); -lean_ctor_set(x_222, 1, x_215); +lean_ctor_set(x_222, 0, x_180); +lean_ctor_set(x_222, 1, x_181); lean_ctor_set(x_222, 2, x_221); -lean_ctor_set(x_222, 3, x_217); -lean_ctor_set(x_222, 4, x_218); -x_223 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__2___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_222, x_213); -if (lean_obj_tag(x_223) == 0) -{ -lean_object* x_224; lean_object* x_225; lean_object* x_226; -x_224 = lean_ctor_get(x_223, 0); +lean_ctor_set(x_222, 3, x_183); +lean_ctor_set(x_222, 4, x_184); +x_223 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_223, 0, x_175); +lean_ctor_set(x_223, 1, x_176); +lean_ctor_set(x_223, 2, x_222); +lean_ctor_set(x_223, 3, x_177); +lean_ctor_set(x_223, 4, x_178); +lean_ctor_set(x_223, 5, x_179); +x_224 = lean_ctor_get(x_7, 0); lean_inc(x_224); -x_225 = lean_ctor_get(x_223, 1); +x_225 = lean_ctor_get(x_7, 1); lean_inc(x_225); -lean_dec(x_223); -x_226 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_226, 0, x_224); -x_178 = x_226; -x_179 = x_225; -goto block_210; -} -else -{ -lean_object* x_227; lean_object* x_228; lean_object* x_229; -x_227 = lean_ctor_get(x_223, 0); +x_226 = lean_ctor_get(x_7, 2); +lean_inc(x_226); +x_227 = lean_ctor_get(x_7, 3); lean_inc(x_227); -x_228 = lean_ctor_get(x_223, 1); +x_228 = lean_ctor_get(x_7, 4); lean_inc(x_228); -lean_dec(x_223); -x_229 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_229, 0, x_227); -x_178 = x_229; -x_179 = x_228; -goto block_210; +if (lean_is_exclusive(x_7)) { + lean_ctor_release(x_7, 0); + lean_ctor_release(x_7, 1); + lean_ctor_release(x_7, 2); + lean_ctor_release(x_7, 3); + lean_ctor_release(x_7, 4); + x_229 = x_7; +} else { + lean_dec_ref(x_7); + x_229 = lean_box(0); } -block_210: +x_230 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_230, 0, x_27); +lean_ctor_set(x_230, 1, x_14); +x_231 = lean_array_push(x_226, x_230); +if (lean_is_scalar(x_229)) { + x_232 = lean_alloc_ctor(0, 5, 0); +} else { + x_232 = x_229; +} +lean_ctor_set(x_232, 0, x_224); +lean_ctor_set(x_232, 1, x_225); +lean_ctor_set(x_232, 2, x_231); +lean_ctor_set(x_232, 3, x_227); +lean_ctor_set(x_232, 4, x_228); +x_233 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__2___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_232, x_223); +if (lean_obj_tag(x_233) == 0) { -if (lean_obj_tag(x_178) == 0) -{ -lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; -x_180 = lean_ctor_get(x_179, 2); -lean_inc(x_180); -x_181 = lean_ctor_get(x_178, 0); -lean_inc(x_181); -lean_dec(x_178); -x_182 = lean_ctor_get(x_179, 0); -lean_inc(x_182); -x_183 = lean_ctor_get(x_179, 1); -lean_inc(x_183); -x_184 = lean_ctor_get(x_179, 3); -lean_inc(x_184); -x_185 = lean_ctor_get(x_179, 4); -lean_inc(x_185); -x_186 = lean_ctor_get(x_179, 5); -lean_inc(x_186); -if (lean_is_exclusive(x_179)) { - lean_ctor_release(x_179, 0); - lean_ctor_release(x_179, 1); - lean_ctor_release(x_179, 2); - lean_ctor_release(x_179, 3); - lean_ctor_release(x_179, 4); - lean_ctor_release(x_179, 5); - x_187 = x_179; -} else { - lean_dec_ref(x_179); - x_187 = lean_box(0); -} -x_188 = lean_ctor_get(x_180, 0); -lean_inc(x_188); -x_189 = lean_ctor_get(x_180, 1); -lean_inc(x_189); -x_190 = lean_ctor_get(x_180, 3); -lean_inc(x_190); -if (lean_is_exclusive(x_180)) { - lean_ctor_release(x_180, 0); - lean_ctor_release(x_180, 1); - lean_ctor_release(x_180, 2); - lean_ctor_release(x_180, 3); - x_191 = x_180; -} else { - lean_dec_ref(x_180); - x_191 = lean_box(0); -} -if (lean_is_scalar(x_191)) { - x_192 = lean_alloc_ctor(0, 4, 0); -} else { - x_192 = x_191; -} -lean_ctor_set(x_192, 0, x_188); -lean_ctor_set(x_192, 1, x_189); -lean_ctor_set(x_192, 2, x_175); -lean_ctor_set(x_192, 3, x_190); -if (lean_is_scalar(x_187)) { - x_193 = lean_alloc_ctor(0, 6, 0); -} else { - x_193 = x_187; -} -lean_ctor_set(x_193, 0, x_182); -lean_ctor_set(x_193, 1, x_183); -lean_ctor_set(x_193, 2, x_192); -lean_ctor_set(x_193, 3, x_184); -lean_ctor_set(x_193, 4, x_185); -lean_ctor_set(x_193, 5, x_186); -if (lean_is_scalar(x_26)) { - x_194 = lean_alloc_ctor(1, 2, 0); -} else { - x_194 = x_26; - lean_ctor_set_tag(x_194, 1); -} -lean_ctor_set(x_194, 0, x_181); -lean_ctor_set(x_194, 1, x_193); -return x_194; +lean_object* x_234; lean_object* x_235; lean_object* x_236; +x_234 = lean_ctor_get(x_233, 0); +lean_inc(x_234); +x_235 = lean_ctor_get(x_233, 1); +lean_inc(x_235); +lean_dec(x_233); +x_236 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_236, 0, x_234); +x_186 = x_236; +x_187 = x_235; +goto block_220; } else { -lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; -x_195 = lean_ctor_get(x_179, 2); -lean_inc(x_195); -x_196 = lean_ctor_get(x_178, 0); +lean_object* x_237; lean_object* x_238; lean_object* x_239; +x_237 = lean_ctor_get(x_233, 0); +lean_inc(x_237); +x_238 = lean_ctor_get(x_233, 1); +lean_inc(x_238); +lean_dec(x_233); +x_239 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_239, 0, x_237); +x_186 = x_239; +x_187 = x_238; +goto block_220; +} +block_220: +{ +if (lean_obj_tag(x_186) == 0) +{ +lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; +x_188 = lean_ctor_get(x_187, 2); +lean_inc(x_188); +x_189 = lean_ctor_get(x_186, 0); +lean_inc(x_189); +lean_dec(x_186); +x_190 = lean_ctor_get(x_187, 0); +lean_inc(x_190); +x_191 = lean_ctor_get(x_187, 1); +lean_inc(x_191); +x_192 = lean_ctor_get(x_187, 3); +lean_inc(x_192); +x_193 = lean_ctor_get(x_187, 4); +lean_inc(x_193); +x_194 = lean_ctor_get(x_187, 5); +lean_inc(x_194); +if (lean_is_exclusive(x_187)) { + lean_ctor_release(x_187, 0); + lean_ctor_release(x_187, 1); + lean_ctor_release(x_187, 2); + lean_ctor_release(x_187, 3); + lean_ctor_release(x_187, 4); + lean_ctor_release(x_187, 5); + x_195 = x_187; +} else { + lean_dec_ref(x_187); + x_195 = lean_box(0); +} +x_196 = lean_ctor_get(x_188, 0); lean_inc(x_196); -lean_dec(x_178); -x_197 = lean_ctor_get(x_179, 0); +x_197 = lean_ctor_get(x_188, 1); lean_inc(x_197); -x_198 = lean_ctor_get(x_179, 1); +x_198 = lean_ctor_get(x_188, 3); lean_inc(x_198); -x_199 = lean_ctor_get(x_179, 3); +x_199 = lean_ctor_get(x_188, 4); lean_inc(x_199); -x_200 = lean_ctor_get(x_179, 4); -lean_inc(x_200); -x_201 = lean_ctor_get(x_179, 5); -lean_inc(x_201); -if (lean_is_exclusive(x_179)) { - lean_ctor_release(x_179, 0); - lean_ctor_release(x_179, 1); - lean_ctor_release(x_179, 2); - lean_ctor_release(x_179, 3); - lean_ctor_release(x_179, 4); - lean_ctor_release(x_179, 5); - x_202 = x_179; +if (lean_is_exclusive(x_188)) { + lean_ctor_release(x_188, 0); + lean_ctor_release(x_188, 1); + lean_ctor_release(x_188, 2); + lean_ctor_release(x_188, 3); + lean_ctor_release(x_188, 4); + x_200 = x_188; } else { - lean_dec_ref(x_179); - x_202 = lean_box(0); + lean_dec_ref(x_188); + x_200 = lean_box(0); } -x_203 = lean_ctor_get(x_195, 0); -lean_inc(x_203); -x_204 = lean_ctor_get(x_195, 1); -lean_inc(x_204); -x_205 = lean_ctor_get(x_195, 3); -lean_inc(x_205); -if (lean_is_exclusive(x_195)) { - lean_ctor_release(x_195, 0); - lean_ctor_release(x_195, 1); - lean_ctor_release(x_195, 2); - lean_ctor_release(x_195, 3); - x_206 = x_195; +if (lean_is_scalar(x_200)) { + x_201 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_195); - x_206 = lean_box(0); + x_201 = x_200; } -if (lean_is_scalar(x_206)) { - x_207 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_201, 0, x_196); +lean_ctor_set(x_201, 1, x_197); +lean_ctor_set(x_201, 2, x_182); +lean_ctor_set(x_201, 3, x_198); +lean_ctor_set(x_201, 4, x_199); +if (lean_is_scalar(x_195)) { + x_202 = lean_alloc_ctor(0, 6, 0); } else { - x_207 = x_206; + x_202 = x_195; } -lean_ctor_set(x_207, 0, x_203); -lean_ctor_set(x_207, 1, x_204); -lean_ctor_set(x_207, 2, x_175); -lean_ctor_set(x_207, 3, x_205); -if (lean_is_scalar(x_202)) { - x_208 = lean_alloc_ctor(0, 6, 0); -} else { - x_208 = x_202; -} -lean_ctor_set(x_208, 0, x_197); -lean_ctor_set(x_208, 1, x_198); -lean_ctor_set(x_208, 2, x_207); -lean_ctor_set(x_208, 3, x_199); -lean_ctor_set(x_208, 4, x_200); -lean_ctor_set(x_208, 5, x_201); +lean_ctor_set(x_202, 0, x_190); +lean_ctor_set(x_202, 1, x_191); +lean_ctor_set(x_202, 2, x_201); +lean_ctor_set(x_202, 3, x_192); +lean_ctor_set(x_202, 4, x_193); +lean_ctor_set(x_202, 5, x_194); if (lean_is_scalar(x_26)) { - x_209 = lean_alloc_ctor(0, 2, 0); + x_203 = lean_alloc_ctor(1, 2, 0); } else { - x_209 = x_26; + x_203 = x_26; + lean_ctor_set_tag(x_203, 1); } -lean_ctor_set(x_209, 0, x_196); -lean_ctor_set(x_209, 1, x_208); -return x_209; +lean_ctor_set(x_203, 0, x_189); +lean_ctor_set(x_203, 1, x_202); +return x_203; +} +else +{ +lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; +x_204 = lean_ctor_get(x_187, 2); +lean_inc(x_204); +x_205 = lean_ctor_get(x_186, 0); +lean_inc(x_205); +lean_dec(x_186); +x_206 = lean_ctor_get(x_187, 0); +lean_inc(x_206); +x_207 = lean_ctor_get(x_187, 1); +lean_inc(x_207); +x_208 = lean_ctor_get(x_187, 3); +lean_inc(x_208); +x_209 = lean_ctor_get(x_187, 4); +lean_inc(x_209); +x_210 = lean_ctor_get(x_187, 5); +lean_inc(x_210); +if (lean_is_exclusive(x_187)) { + lean_ctor_release(x_187, 0); + lean_ctor_release(x_187, 1); + lean_ctor_release(x_187, 2); + lean_ctor_release(x_187, 3); + lean_ctor_release(x_187, 4); + lean_ctor_release(x_187, 5); + x_211 = x_187; +} else { + lean_dec_ref(x_187); + x_211 = lean_box(0); +} +x_212 = lean_ctor_get(x_204, 0); +lean_inc(x_212); +x_213 = lean_ctor_get(x_204, 1); +lean_inc(x_213); +x_214 = lean_ctor_get(x_204, 3); +lean_inc(x_214); +x_215 = lean_ctor_get(x_204, 4); +lean_inc(x_215); +if (lean_is_exclusive(x_204)) { + lean_ctor_release(x_204, 0); + lean_ctor_release(x_204, 1); + lean_ctor_release(x_204, 2); + lean_ctor_release(x_204, 3); + lean_ctor_release(x_204, 4); + x_216 = x_204; +} else { + lean_dec_ref(x_204); + x_216 = lean_box(0); +} +if (lean_is_scalar(x_216)) { + x_217 = lean_alloc_ctor(0, 5, 0); +} else { + x_217 = x_216; +} +lean_ctor_set(x_217, 0, x_212); +lean_ctor_set(x_217, 1, x_213); +lean_ctor_set(x_217, 2, x_182); +lean_ctor_set(x_217, 3, x_214); +lean_ctor_set(x_217, 4, x_215); +if (lean_is_scalar(x_211)) { + x_218 = lean_alloc_ctor(0, 6, 0); +} else { + x_218 = x_211; +} +lean_ctor_set(x_218, 0, x_206); +lean_ctor_set(x_218, 1, x_207); +lean_ctor_set(x_218, 2, x_217); +lean_ctor_set(x_218, 3, x_208); +lean_ctor_set(x_218, 4, x_209); +lean_ctor_set(x_218, 5, x_210); +if (lean_is_scalar(x_26)) { + x_219 = lean_alloc_ctor(0, 2, 0); +} else { + x_219 = x_26; +} +lean_ctor_set(x_219, 0, x_205); +lean_ctor_set(x_219, 1, x_218); +return x_219; } } } } default: { -lean_object* x_230; lean_object* x_231; -x_230 = lean_ctor_get(x_19, 1); -lean_inc(x_230); +lean_object* x_240; lean_object* x_241; +x_240 = lean_ctor_get(x_19, 1); +lean_inc(x_240); lean_dec(x_19); lean_inc(x_7); -x_231 = l_Lean_Meta_isClassExpensive___main(x_18, x_7, x_230); -if (lean_obj_tag(x_231) == 0) +x_241 = l_Lean_Meta_isClassExpensive___main(x_18, x_7, x_240); +if (lean_obj_tag(x_241) == 0) { -lean_object* x_232; -x_232 = lean_ctor_get(x_231, 0); -lean_inc(x_232); -if (lean_obj_tag(x_232) == 0) +lean_object* x_242; +x_242 = lean_ctor_get(x_241, 0); +lean_inc(x_242); +if (lean_obj_tag(x_242) == 0) { -lean_object* x_233; lean_object* x_234; lean_object* x_235; +lean_object* x_243; lean_object* x_244; lean_object* x_245; lean_dec(x_14); -x_233 = lean_ctor_get(x_231, 1); -lean_inc(x_233); -lean_dec(x_231); -x_234 = lean_unsigned_to_nat(1u); -x_235 = lean_nat_add(x_6, x_234); +x_243 = lean_ctor_get(x_241, 1); +lean_inc(x_243); +lean_dec(x_241); +x_244 = lean_unsigned_to_nat(1u); +x_245 = lean_nat_add(x_6, x_244); lean_dec(x_6); -x_6 = x_235; -x_8 = x_233; +x_6 = x_245; +x_8 = x_243; goto _start; } else { -lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; uint8_t x_242; -x_237 = lean_ctor_get(x_231, 1); -lean_inc(x_237); -if (lean_is_exclusive(x_231)) { - lean_ctor_release(x_231, 0); - lean_ctor_release(x_231, 1); - x_238 = x_231; +lean_object* x_247; lean_object* x_248; lean_object* x_249; lean_object* x_250; lean_object* x_251; uint8_t x_252; +x_247 = lean_ctor_get(x_241, 1); +lean_inc(x_247); +if (lean_is_exclusive(x_241)) { + lean_ctor_release(x_241, 0); + lean_ctor_release(x_241, 1); + x_248 = x_241; } else { - lean_dec_ref(x_231); - x_238 = lean_box(0); + lean_dec_ref(x_241); + x_248 = lean_box(0); } -x_239 = lean_ctor_get(x_232, 0); -lean_inc(x_239); -lean_dec(x_232); -x_240 = lean_unsigned_to_nat(1u); -x_241 = lean_nat_add(x_6, x_240); -lean_dec(x_6); -x_242 = !lean_is_exclusive(x_237); -if (x_242 == 0) -{ -lean_object* x_243; uint8_t x_244; -x_243 = lean_ctor_get(x_237, 2); -x_244 = !lean_is_exclusive(x_243); -if (x_244 == 0) -{ -lean_object* x_245; lean_object* x_246; lean_object* x_247; lean_object* x_297; uint8_t x_298; -x_245 = lean_ctor_get(x_243, 2); -x_297 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_243, 2, x_297); -x_298 = !lean_is_exclusive(x_7); -if (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_7, 2); -x_300 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_300, 0, x_239); -lean_ctor_set(x_300, 1, x_14); -x_301 = lean_array_push(x_299, x_300); -lean_ctor_set(x_7, 2, x_301); -x_302 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__2___rarg(x_1, x_2, x_3, x_4, x_5, x_241, x_7, x_237); -if (lean_obj_tag(x_302) == 0) -{ -lean_object* x_303; lean_object* x_304; lean_object* x_305; -x_303 = lean_ctor_get(x_302, 0); -lean_inc(x_303); -x_304 = lean_ctor_get(x_302, 1); -lean_inc(x_304); -lean_dec(x_302); -x_305 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_305, 0, x_303); -x_246 = x_305; -x_247 = x_304; -goto block_296; -} -else -{ -lean_object* x_306; lean_object* x_307; lean_object* x_308; -x_306 = lean_ctor_get(x_302, 0); -lean_inc(x_306); -x_307 = lean_ctor_get(x_302, 1); -lean_inc(x_307); -lean_dec(x_302); -x_308 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_308, 0, x_306); -x_246 = x_308; -x_247 = x_307; -goto block_296; -} -} -else -{ -lean_object* x_309; lean_object* x_310; lean_object* x_311; lean_object* x_312; lean_object* x_313; lean_object* x_314; lean_object* x_315; lean_object* x_316; lean_object* x_317; -x_309 = lean_ctor_get(x_7, 0); -x_310 = lean_ctor_get(x_7, 1); -x_311 = lean_ctor_get(x_7, 2); -x_312 = lean_ctor_get(x_7, 3); -x_313 = lean_ctor_get(x_7, 4); -lean_inc(x_313); -lean_inc(x_312); -lean_inc(x_311); -lean_inc(x_310); -lean_inc(x_309); -lean_dec(x_7); -x_314 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_314, 0, x_239); -lean_ctor_set(x_314, 1, x_14); -x_315 = lean_array_push(x_311, x_314); -x_316 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_316, 0, x_309); -lean_ctor_set(x_316, 1, x_310); -lean_ctor_set(x_316, 2, x_315); -lean_ctor_set(x_316, 3, x_312); -lean_ctor_set(x_316, 4, x_313); -x_317 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__2___rarg(x_1, x_2, x_3, x_4, x_5, x_241, x_316, x_237); -if (lean_obj_tag(x_317) == 0) -{ -lean_object* x_318; lean_object* x_319; lean_object* x_320; -x_318 = lean_ctor_get(x_317, 0); -lean_inc(x_318); -x_319 = lean_ctor_get(x_317, 1); -lean_inc(x_319); -lean_dec(x_317); -x_320 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_320, 0, x_318); -x_246 = x_320; -x_247 = x_319; -goto block_296; -} -else -{ -lean_object* x_321; lean_object* x_322; lean_object* x_323; -x_321 = lean_ctor_get(x_317, 0); -lean_inc(x_321); -x_322 = lean_ctor_get(x_317, 1); -lean_inc(x_322); -lean_dec(x_317); -x_323 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_323, 0, x_321); -x_246 = x_323; -x_247 = x_322; -goto block_296; -} -} -block_296: -{ -if (lean_obj_tag(x_246) == 0) -{ -lean_object* x_248; lean_object* x_249; uint8_t x_250; -x_248 = lean_ctor_get(x_247, 2); -lean_inc(x_248); -x_249 = lean_ctor_get(x_246, 0); +x_249 = lean_ctor_get(x_242, 0); lean_inc(x_249); -lean_dec(x_246); -x_250 = !lean_is_exclusive(x_247); -if (x_250 == 0) -{ -lean_object* x_251; uint8_t x_252; -x_251 = lean_ctor_get(x_247, 2); -lean_dec(x_251); -x_252 = !lean_is_exclusive(x_248); +lean_dec(x_242); +x_250 = lean_unsigned_to_nat(1u); +x_251 = lean_nat_add(x_6, x_250); +lean_dec(x_6); +x_252 = !lean_is_exclusive(x_247); if (x_252 == 0) { -lean_object* x_253; lean_object* x_254; -x_253 = lean_ctor_get(x_248, 2); -lean_dec(x_253); -lean_ctor_set(x_248, 2, x_245); -if (lean_is_scalar(x_238)) { - x_254 = lean_alloc_ctor(1, 2, 0); -} else { - x_254 = x_238; - lean_ctor_set_tag(x_254, 1); -} -lean_ctor_set(x_254, 0, x_249); -lean_ctor_set(x_254, 1, x_247); -return x_254; +lean_object* x_253; uint8_t x_254; +x_253 = lean_ctor_get(x_247, 2); +x_254 = !lean_is_exclusive(x_253); +if (x_254 == 0) +{ +lean_object* x_255; lean_object* x_256; lean_object* x_257; lean_object* x_311; uint8_t x_312; +x_255 = lean_ctor_get(x_253, 2); +x_311 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_253, 2, x_311); +x_312 = !lean_is_exclusive(x_7); +if (x_312 == 0) +{ +lean_object* x_313; lean_object* x_314; lean_object* x_315; lean_object* x_316; +x_313 = lean_ctor_get(x_7, 2); +x_314 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_314, 0, x_249); +lean_ctor_set(x_314, 1, x_14); +x_315 = lean_array_push(x_313, x_314); +lean_ctor_set(x_7, 2, x_315); +x_316 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__2___rarg(x_1, x_2, x_3, x_4, x_5, x_251, x_7, x_247); +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); +x_319 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_319, 0, x_317); +x_256 = x_319; +x_257 = x_318; +goto block_310; } else { -lean_object* x_255; lean_object* x_256; lean_object* x_257; lean_object* x_258; lean_object* x_259; -x_255 = lean_ctor_get(x_248, 0); -x_256 = lean_ctor_get(x_248, 1); -x_257 = lean_ctor_get(x_248, 3); -lean_inc(x_257); -lean_inc(x_256); -lean_inc(x_255); -lean_dec(x_248); -x_258 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_258, 0, x_255); -lean_ctor_set(x_258, 1, x_256); -lean_ctor_set(x_258, 2, x_245); -lean_ctor_set(x_258, 3, x_257); -lean_ctor_set(x_247, 2, x_258); -if (lean_is_scalar(x_238)) { - x_259 = lean_alloc_ctor(1, 2, 0); -} else { - x_259 = x_238; - lean_ctor_set_tag(x_259, 1); -} -lean_ctor_set(x_259, 0, x_249); -lean_ctor_set(x_259, 1, x_247); -return x_259; +lean_object* x_320; lean_object* x_321; lean_object* x_322; +x_320 = lean_ctor_get(x_316, 0); +lean_inc(x_320); +x_321 = lean_ctor_get(x_316, 1); +lean_inc(x_321); +lean_dec(x_316); +x_322 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_322, 0, x_320); +x_256 = x_322; +x_257 = x_321; +goto block_310; } } else { -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_260 = lean_ctor_get(x_247, 0); -x_261 = lean_ctor_get(x_247, 1); -x_262 = lean_ctor_get(x_247, 3); -x_263 = lean_ctor_get(x_247, 4); -x_264 = lean_ctor_get(x_247, 5); -lean_inc(x_264); -lean_inc(x_263); -lean_inc(x_262); -lean_inc(x_261); -lean_inc(x_260); -lean_dec(x_247); -x_265 = lean_ctor_get(x_248, 0); -lean_inc(x_265); -x_266 = lean_ctor_get(x_248, 1); -lean_inc(x_266); -x_267 = lean_ctor_get(x_248, 3); +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; +x_323 = lean_ctor_get(x_7, 0); +x_324 = lean_ctor_get(x_7, 1); +x_325 = lean_ctor_get(x_7, 2); +x_326 = lean_ctor_get(x_7, 3); +x_327 = lean_ctor_get(x_7, 4); +lean_inc(x_327); +lean_inc(x_326); +lean_inc(x_325); +lean_inc(x_324); +lean_inc(x_323); +lean_dec(x_7); +x_328 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_328, 0, x_249); +lean_ctor_set(x_328, 1, x_14); +x_329 = lean_array_push(x_325, x_328); +x_330 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_330, 0, x_323); +lean_ctor_set(x_330, 1, x_324); +lean_ctor_set(x_330, 2, x_329); +lean_ctor_set(x_330, 3, x_326); +lean_ctor_set(x_330, 4, x_327); +x_331 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__2___rarg(x_1, x_2, x_3, x_4, x_5, x_251, x_330, x_247); +if (lean_obj_tag(x_331) == 0) +{ +lean_object* x_332; lean_object* x_333; lean_object* x_334; +x_332 = lean_ctor_get(x_331, 0); +lean_inc(x_332); +x_333 = lean_ctor_get(x_331, 1); +lean_inc(x_333); +lean_dec(x_331); +x_334 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_334, 0, x_332); +x_256 = x_334; +x_257 = x_333; +goto block_310; +} +else +{ +lean_object* x_335; lean_object* x_336; lean_object* x_337; +x_335 = lean_ctor_get(x_331, 0); +lean_inc(x_335); +x_336 = lean_ctor_get(x_331, 1); +lean_inc(x_336); +lean_dec(x_331); +x_337 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_337, 0, x_335); +x_256 = x_337; +x_257 = x_336; +goto block_310; +} +} +block_310: +{ +if (lean_obj_tag(x_256) == 0) +{ +lean_object* x_258; lean_object* x_259; uint8_t x_260; +x_258 = lean_ctor_get(x_257, 2); +lean_inc(x_258); +x_259 = lean_ctor_get(x_256, 0); +lean_inc(x_259); +lean_dec(x_256); +x_260 = !lean_is_exclusive(x_257); +if (x_260 == 0) +{ +lean_object* x_261; uint8_t x_262; +x_261 = lean_ctor_get(x_257, 2); +lean_dec(x_261); +x_262 = !lean_is_exclusive(x_258); +if (x_262 == 0) +{ +lean_object* x_263; lean_object* x_264; +x_263 = lean_ctor_get(x_258, 2); +lean_dec(x_263); +lean_ctor_set(x_258, 2, x_255); +if (lean_is_scalar(x_248)) { + x_264 = lean_alloc_ctor(1, 2, 0); +} else { + x_264 = x_248; + lean_ctor_set_tag(x_264, 1); +} +lean_ctor_set(x_264, 0, x_259); +lean_ctor_set(x_264, 1, x_257); +return x_264; +} +else +{ +lean_object* x_265; lean_object* x_266; lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_object* x_270; +x_265 = lean_ctor_get(x_258, 0); +x_266 = lean_ctor_get(x_258, 1); +x_267 = lean_ctor_get(x_258, 3); +x_268 = lean_ctor_get(x_258, 4); +lean_inc(x_268); lean_inc(x_267); -if (lean_is_exclusive(x_248)) { - lean_ctor_release(x_248, 0); - lean_ctor_release(x_248, 1); - lean_ctor_release(x_248, 2); - lean_ctor_release(x_248, 3); - x_268 = x_248; -} else { - lean_dec_ref(x_248); - x_268 = lean_box(0); -} -if (lean_is_scalar(x_268)) { - x_269 = lean_alloc_ctor(0, 4, 0); -} else { - x_269 = x_268; -} +lean_inc(x_266); +lean_inc(x_265); +lean_dec(x_258); +x_269 = lean_alloc_ctor(0, 5, 0); lean_ctor_set(x_269, 0, x_265); lean_ctor_set(x_269, 1, x_266); -lean_ctor_set(x_269, 2, x_245); +lean_ctor_set(x_269, 2, x_255); lean_ctor_set(x_269, 3, x_267); -x_270 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_270, 0, x_260); -lean_ctor_set(x_270, 1, x_261); -lean_ctor_set(x_270, 2, x_269); -lean_ctor_set(x_270, 3, x_262); -lean_ctor_set(x_270, 4, x_263); -lean_ctor_set(x_270, 5, x_264); -if (lean_is_scalar(x_238)) { - x_271 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_269, 4, x_268); +lean_ctor_set(x_257, 2, x_269); +if (lean_is_scalar(x_248)) { + x_270 = lean_alloc_ctor(1, 2, 0); } else { - x_271 = x_238; - lean_ctor_set_tag(x_271, 1); + x_270 = x_248; + lean_ctor_set_tag(x_270, 1); } -lean_ctor_set(x_271, 0, x_249); -lean_ctor_set(x_271, 1, x_270); -return x_271; +lean_ctor_set(x_270, 0, x_259); +lean_ctor_set(x_270, 1, x_257); +return x_270; } } else { -lean_object* x_272; lean_object* x_273; uint8_t x_274; -x_272 = lean_ctor_get(x_247, 2); -lean_inc(x_272); -x_273 = lean_ctor_get(x_246, 0); +lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_object* x_276; lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; lean_object* x_281; lean_object* x_282; lean_object* x_283; +x_271 = lean_ctor_get(x_257, 0); +x_272 = lean_ctor_get(x_257, 1); +x_273 = lean_ctor_get(x_257, 3); +x_274 = lean_ctor_get(x_257, 4); +x_275 = lean_ctor_get(x_257, 5); +lean_inc(x_275); +lean_inc(x_274); lean_inc(x_273); -lean_dec(x_246); -x_274 = !lean_is_exclusive(x_247); -if (x_274 == 0) -{ -lean_object* x_275; uint8_t x_276; -x_275 = lean_ctor_get(x_247, 2); -lean_dec(x_275); -x_276 = !lean_is_exclusive(x_272); -if (x_276 == 0) -{ -lean_object* x_277; lean_object* x_278; -x_277 = lean_ctor_get(x_272, 2); -lean_dec(x_277); -lean_ctor_set(x_272, 2, x_245); -if (lean_is_scalar(x_238)) { - x_278 = lean_alloc_ctor(0, 2, 0); -} else { - x_278 = x_238; -} -lean_ctor_set(x_278, 0, x_273); -lean_ctor_set(x_278, 1, x_247); -return x_278; -} -else -{ -lean_object* x_279; lean_object* x_280; lean_object* x_281; lean_object* x_282; lean_object* x_283; -x_279 = lean_ctor_get(x_272, 0); -x_280 = lean_ctor_get(x_272, 1); -x_281 = lean_ctor_get(x_272, 3); -lean_inc(x_281); -lean_inc(x_280); +lean_inc(x_272); +lean_inc(x_271); +lean_dec(x_257); +x_276 = lean_ctor_get(x_258, 0); +lean_inc(x_276); +x_277 = lean_ctor_get(x_258, 1); +lean_inc(x_277); +x_278 = lean_ctor_get(x_258, 3); +lean_inc(x_278); +x_279 = lean_ctor_get(x_258, 4); lean_inc(x_279); -lean_dec(x_272); -x_282 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_282, 0, x_279); -lean_ctor_set(x_282, 1, x_280); -lean_ctor_set(x_282, 2, x_245); -lean_ctor_set(x_282, 3, x_281); -lean_ctor_set(x_247, 2, x_282); -if (lean_is_scalar(x_238)) { - x_283 = lean_alloc_ctor(0, 2, 0); +if (lean_is_exclusive(x_258)) { + lean_ctor_release(x_258, 0); + lean_ctor_release(x_258, 1); + lean_ctor_release(x_258, 2); + lean_ctor_release(x_258, 3); + lean_ctor_release(x_258, 4); + x_280 = x_258; } else { - x_283 = x_238; + lean_dec_ref(x_258); + x_280 = lean_box(0); } -lean_ctor_set(x_283, 0, x_273); -lean_ctor_set(x_283, 1, x_247); +if (lean_is_scalar(x_280)) { + x_281 = lean_alloc_ctor(0, 5, 0); +} else { + x_281 = x_280; +} +lean_ctor_set(x_281, 0, x_276); +lean_ctor_set(x_281, 1, x_277); +lean_ctor_set(x_281, 2, x_255); +lean_ctor_set(x_281, 3, x_278); +lean_ctor_set(x_281, 4, x_279); +x_282 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_282, 0, x_271); +lean_ctor_set(x_282, 1, x_272); +lean_ctor_set(x_282, 2, x_281); +lean_ctor_set(x_282, 3, x_273); +lean_ctor_set(x_282, 4, x_274); +lean_ctor_set(x_282, 5, x_275); +if (lean_is_scalar(x_248)) { + x_283 = lean_alloc_ctor(1, 2, 0); +} else { + x_283 = x_248; + lean_ctor_set_tag(x_283, 1); +} +lean_ctor_set(x_283, 0, x_259); +lean_ctor_set(x_283, 1, x_282); return x_283; } } else { -lean_object* x_284; lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; lean_object* x_289; lean_object* x_290; lean_object* x_291; lean_object* x_292; lean_object* x_293; lean_object* x_294; lean_object* x_295; -x_284 = lean_ctor_get(x_247, 0); -x_285 = lean_ctor_get(x_247, 1); -x_286 = lean_ctor_get(x_247, 3); -x_287 = lean_ctor_get(x_247, 4); -x_288 = lean_ctor_get(x_247, 5); -lean_inc(x_288); -lean_inc(x_287); -lean_inc(x_286); -lean_inc(x_285); +lean_object* x_284; lean_object* x_285; uint8_t x_286; +x_284 = lean_ctor_get(x_257, 2); lean_inc(x_284); -lean_dec(x_247); -x_289 = lean_ctor_get(x_272, 0); -lean_inc(x_289); -x_290 = lean_ctor_get(x_272, 1); -lean_inc(x_290); -x_291 = lean_ctor_get(x_272, 3); +x_285 = lean_ctor_get(x_256, 0); +lean_inc(x_285); +lean_dec(x_256); +x_286 = !lean_is_exclusive(x_257); +if (x_286 == 0) +{ +lean_object* x_287; uint8_t x_288; +x_287 = lean_ctor_get(x_257, 2); +lean_dec(x_287); +x_288 = !lean_is_exclusive(x_284); +if (x_288 == 0) +{ +lean_object* x_289; lean_object* x_290; +x_289 = lean_ctor_get(x_284, 2); +lean_dec(x_289); +lean_ctor_set(x_284, 2, x_255); +if (lean_is_scalar(x_248)) { + x_290 = lean_alloc_ctor(0, 2, 0); +} else { + x_290 = x_248; +} +lean_ctor_set(x_290, 0, x_285); +lean_ctor_set(x_290, 1, x_257); +return x_290; +} +else +{ +lean_object* x_291; lean_object* x_292; lean_object* x_293; lean_object* x_294; lean_object* x_295; lean_object* x_296; +x_291 = lean_ctor_get(x_284, 0); +x_292 = lean_ctor_get(x_284, 1); +x_293 = lean_ctor_get(x_284, 3); +x_294 = lean_ctor_get(x_284, 4); +lean_inc(x_294); +lean_inc(x_293); +lean_inc(x_292); lean_inc(x_291); -if (lean_is_exclusive(x_272)) { - lean_ctor_release(x_272, 0); - lean_ctor_release(x_272, 1); - lean_ctor_release(x_272, 2); - lean_ctor_release(x_272, 3); - x_292 = x_272; +lean_dec(x_284); +x_295 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_295, 0, x_291); +lean_ctor_set(x_295, 1, x_292); +lean_ctor_set(x_295, 2, x_255); +lean_ctor_set(x_295, 3, x_293); +lean_ctor_set(x_295, 4, x_294); +lean_ctor_set(x_257, 2, x_295); +if (lean_is_scalar(x_248)) { + x_296 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_272); - x_292 = lean_box(0); + x_296 = x_248; } -if (lean_is_scalar(x_292)) { - x_293 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_296, 0, x_285); +lean_ctor_set(x_296, 1, x_257); +return x_296; +} +} +else +{ +lean_object* x_297; lean_object* x_298; lean_object* x_299; lean_object* x_300; lean_object* x_301; lean_object* x_302; lean_object* x_303; lean_object* x_304; lean_object* x_305; lean_object* x_306; lean_object* x_307; lean_object* x_308; lean_object* x_309; +x_297 = lean_ctor_get(x_257, 0); +x_298 = lean_ctor_get(x_257, 1); +x_299 = lean_ctor_get(x_257, 3); +x_300 = lean_ctor_get(x_257, 4); +x_301 = lean_ctor_get(x_257, 5); +lean_inc(x_301); +lean_inc(x_300); +lean_inc(x_299); +lean_inc(x_298); +lean_inc(x_297); +lean_dec(x_257); +x_302 = lean_ctor_get(x_284, 0); +lean_inc(x_302); +x_303 = lean_ctor_get(x_284, 1); +lean_inc(x_303); +x_304 = lean_ctor_get(x_284, 3); +lean_inc(x_304); +x_305 = lean_ctor_get(x_284, 4); +lean_inc(x_305); +if (lean_is_exclusive(x_284)) { + lean_ctor_release(x_284, 0); + lean_ctor_release(x_284, 1); + lean_ctor_release(x_284, 2); + lean_ctor_release(x_284, 3); + lean_ctor_release(x_284, 4); + x_306 = x_284; } else { - x_293 = x_292; + lean_dec_ref(x_284); + x_306 = lean_box(0); } -lean_ctor_set(x_293, 0, x_289); -lean_ctor_set(x_293, 1, x_290); -lean_ctor_set(x_293, 2, x_245); -lean_ctor_set(x_293, 3, x_291); -x_294 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_294, 0, x_284); -lean_ctor_set(x_294, 1, x_285); -lean_ctor_set(x_294, 2, x_293); -lean_ctor_set(x_294, 3, x_286); -lean_ctor_set(x_294, 4, x_287); -lean_ctor_set(x_294, 5, x_288); -if (lean_is_scalar(x_238)) { - x_295 = lean_alloc_ctor(0, 2, 0); +if (lean_is_scalar(x_306)) { + x_307 = lean_alloc_ctor(0, 5, 0); } else { - x_295 = x_238; + x_307 = x_306; } -lean_ctor_set(x_295, 0, x_273); -lean_ctor_set(x_295, 1, x_294); -return x_295; +lean_ctor_set(x_307, 0, x_302); +lean_ctor_set(x_307, 1, x_303); +lean_ctor_set(x_307, 2, x_255); +lean_ctor_set(x_307, 3, x_304); +lean_ctor_set(x_307, 4, x_305); +x_308 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_308, 0, x_297); +lean_ctor_set(x_308, 1, x_298); +lean_ctor_set(x_308, 2, x_307); +lean_ctor_set(x_308, 3, x_299); +lean_ctor_set(x_308, 4, x_300); +lean_ctor_set(x_308, 5, x_301); +if (lean_is_scalar(x_248)) { + x_309 = lean_alloc_ctor(0, 2, 0); +} else { + x_309 = x_248; +} +lean_ctor_set(x_309, 0, x_285); +lean_ctor_set(x_309, 1, x_308); +return x_309; } } } } else { -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_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; -x_324 = lean_ctor_get(x_243, 0); -x_325 = lean_ctor_get(x_243, 1); -x_326 = lean_ctor_get(x_243, 2); -x_327 = lean_ctor_get(x_243, 3); -lean_inc(x_327); -lean_inc(x_326); -lean_inc(x_325); -lean_inc(x_324); -lean_dec(x_243); -x_361 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_362 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_362, 0, x_324); -lean_ctor_set(x_362, 1, x_325); -lean_ctor_set(x_362, 2, x_361); -lean_ctor_set(x_362, 3, x_327); -lean_ctor_set(x_237, 2, x_362); -x_363 = lean_ctor_get(x_7, 0); -lean_inc(x_363); -x_364 = lean_ctor_get(x_7, 1); -lean_inc(x_364); -x_365 = lean_ctor_get(x_7, 2); -lean_inc(x_365); -x_366 = lean_ctor_get(x_7, 3); -lean_inc(x_366); -x_367 = lean_ctor_get(x_7, 4); -lean_inc(x_367); +lean_object* x_338; lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; lean_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; +x_338 = lean_ctor_get(x_253, 0); +x_339 = lean_ctor_get(x_253, 1); +x_340 = lean_ctor_get(x_253, 2); +x_341 = lean_ctor_get(x_253, 3); +x_342 = lean_ctor_get(x_253, 4); +lean_inc(x_342); +lean_inc(x_341); +lean_inc(x_340); +lean_inc(x_339); +lean_inc(x_338); +lean_dec(x_253); +x_378 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_379 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_379, 0, x_338); +lean_ctor_set(x_379, 1, x_339); +lean_ctor_set(x_379, 2, x_378); +lean_ctor_set(x_379, 3, x_341); +lean_ctor_set(x_379, 4, x_342); +lean_ctor_set(x_247, 2, x_379); +x_380 = lean_ctor_get(x_7, 0); +lean_inc(x_380); +x_381 = lean_ctor_get(x_7, 1); +lean_inc(x_381); +x_382 = lean_ctor_get(x_7, 2); +lean_inc(x_382); +x_383 = lean_ctor_get(x_7, 3); +lean_inc(x_383); +x_384 = lean_ctor_get(x_7, 4); +lean_inc(x_384); if (lean_is_exclusive(x_7)) { lean_ctor_release(x_7, 0); lean_ctor_release(x_7, 1); lean_ctor_release(x_7, 2); lean_ctor_release(x_7, 3); lean_ctor_release(x_7, 4); - x_368 = x_7; + x_385 = x_7; } else { lean_dec_ref(x_7); - x_368 = lean_box(0); + x_385 = lean_box(0); } -x_369 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_369, 0, x_239); -lean_ctor_set(x_369, 1, x_14); -x_370 = lean_array_push(x_365, x_369); -if (lean_is_scalar(x_368)) { - x_371 = lean_alloc_ctor(0, 5, 0); +x_386 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_386, 0, x_249); +lean_ctor_set(x_386, 1, x_14); +x_387 = lean_array_push(x_382, x_386); +if (lean_is_scalar(x_385)) { + x_388 = lean_alloc_ctor(0, 5, 0); } else { - x_371 = x_368; + x_388 = x_385; } -lean_ctor_set(x_371, 0, x_363); -lean_ctor_set(x_371, 1, x_364); -lean_ctor_set(x_371, 2, x_370); -lean_ctor_set(x_371, 3, x_366); -lean_ctor_set(x_371, 4, x_367); -x_372 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__2___rarg(x_1, x_2, x_3, x_4, x_5, x_241, x_371, x_237); -if (lean_obj_tag(x_372) == 0) +lean_ctor_set(x_388, 0, x_380); +lean_ctor_set(x_388, 1, x_381); +lean_ctor_set(x_388, 2, x_387); +lean_ctor_set(x_388, 3, x_383); +lean_ctor_set(x_388, 4, x_384); +x_389 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__2___rarg(x_1, x_2, x_3, x_4, x_5, x_251, x_388, x_247); +if (lean_obj_tag(x_389) == 0) { -lean_object* x_373; lean_object* x_374; lean_object* x_375; -x_373 = lean_ctor_get(x_372, 0); -lean_inc(x_373); -x_374 = lean_ctor_get(x_372, 1); -lean_inc(x_374); -lean_dec(x_372); -x_375 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_375, 0, x_373); -x_328 = x_375; -x_329 = x_374; -goto block_360; +lean_object* x_390; lean_object* x_391; lean_object* x_392; +x_390 = lean_ctor_get(x_389, 0); +lean_inc(x_390); +x_391 = lean_ctor_get(x_389, 1); +lean_inc(x_391); +lean_dec(x_389); +x_392 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_392, 0, x_390); +x_343 = x_392; +x_344 = x_391; +goto block_377; } else { -lean_object* x_376; lean_object* x_377; lean_object* x_378; -x_376 = lean_ctor_get(x_372, 0); -lean_inc(x_376); -x_377 = lean_ctor_get(x_372, 1); -lean_inc(x_377); -lean_dec(x_372); -x_378 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_378, 0, x_376); -x_328 = x_378; -x_329 = x_377; -goto block_360; +lean_object* x_393; lean_object* x_394; lean_object* x_395; +x_393 = lean_ctor_get(x_389, 0); +lean_inc(x_393); +x_394 = lean_ctor_get(x_389, 1); +lean_inc(x_394); +lean_dec(x_389); +x_395 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_395, 0, x_393); +x_343 = x_395; +x_344 = x_394; +goto block_377; } -block_360: +block_377: { -if (lean_obj_tag(x_328) == 0) +if (lean_obj_tag(x_343) == 0) { -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; lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; -x_330 = lean_ctor_get(x_329, 2); -lean_inc(x_330); -x_331 = lean_ctor_get(x_328, 0); -lean_inc(x_331); -lean_dec(x_328); -x_332 = lean_ctor_get(x_329, 0); -lean_inc(x_332); -x_333 = lean_ctor_get(x_329, 1); -lean_inc(x_333); -x_334 = lean_ctor_get(x_329, 3); -lean_inc(x_334); -x_335 = lean_ctor_get(x_329, 4); -lean_inc(x_335); -x_336 = lean_ctor_get(x_329, 5); -lean_inc(x_336); -if (lean_is_exclusive(x_329)) { - lean_ctor_release(x_329, 0); - lean_ctor_release(x_329, 1); - lean_ctor_release(x_329, 2); - lean_ctor_release(x_329, 3); - lean_ctor_release(x_329, 4); - lean_ctor_release(x_329, 5); - x_337 = x_329; -} else { - lean_dec_ref(x_329); - x_337 = lean_box(0); -} -x_338 = lean_ctor_get(x_330, 0); -lean_inc(x_338); -x_339 = lean_ctor_get(x_330, 1); -lean_inc(x_339); -x_340 = lean_ctor_get(x_330, 3); -lean_inc(x_340); -if (lean_is_exclusive(x_330)) { - lean_ctor_release(x_330, 0); - lean_ctor_release(x_330, 1); - lean_ctor_release(x_330, 2); - lean_ctor_release(x_330, 3); - x_341 = x_330; -} else { - lean_dec_ref(x_330); - x_341 = lean_box(0); -} -if (lean_is_scalar(x_341)) { - x_342 = lean_alloc_ctor(0, 4, 0); -} else { - x_342 = x_341; -} -lean_ctor_set(x_342, 0, x_338); -lean_ctor_set(x_342, 1, x_339); -lean_ctor_set(x_342, 2, x_326); -lean_ctor_set(x_342, 3, x_340); -if (lean_is_scalar(x_337)) { - x_343 = lean_alloc_ctor(0, 6, 0); -} else { - x_343 = x_337; -} -lean_ctor_set(x_343, 0, x_332); -lean_ctor_set(x_343, 1, x_333); -lean_ctor_set(x_343, 2, x_342); -lean_ctor_set(x_343, 3, x_334); -lean_ctor_set(x_343, 4, x_335); -lean_ctor_set(x_343, 5, x_336); -if (lean_is_scalar(x_238)) { - x_344 = lean_alloc_ctor(1, 2, 0); -} else { - x_344 = x_238; - lean_ctor_set_tag(x_344, 1); -} -lean_ctor_set(x_344, 0, x_331); -lean_ctor_set(x_344, 1, x_343); -return x_344; -} -else -{ -lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; lean_object* x_350; lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; lean_object* x_358; lean_object* x_359; -x_345 = lean_ctor_get(x_329, 2); +lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; lean_object* x_350; lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; lean_object* x_358; lean_object* x_359; lean_object* x_360; +x_345 = lean_ctor_get(x_344, 2); lean_inc(x_345); -x_346 = lean_ctor_get(x_328, 0); +x_346 = lean_ctor_get(x_343, 0); lean_inc(x_346); -lean_dec(x_328); -x_347 = lean_ctor_get(x_329, 0); +lean_dec(x_343); +x_347 = lean_ctor_get(x_344, 0); lean_inc(x_347); -x_348 = lean_ctor_get(x_329, 1); +x_348 = lean_ctor_get(x_344, 1); lean_inc(x_348); -x_349 = lean_ctor_get(x_329, 3); +x_349 = lean_ctor_get(x_344, 3); lean_inc(x_349); -x_350 = lean_ctor_get(x_329, 4); +x_350 = lean_ctor_get(x_344, 4); lean_inc(x_350); -x_351 = lean_ctor_get(x_329, 5); +x_351 = lean_ctor_get(x_344, 5); lean_inc(x_351); -if (lean_is_exclusive(x_329)) { - lean_ctor_release(x_329, 0); - lean_ctor_release(x_329, 1); - lean_ctor_release(x_329, 2); - lean_ctor_release(x_329, 3); - lean_ctor_release(x_329, 4); - lean_ctor_release(x_329, 5); - x_352 = x_329; +if (lean_is_exclusive(x_344)) { + lean_ctor_release(x_344, 0); + lean_ctor_release(x_344, 1); + lean_ctor_release(x_344, 2); + lean_ctor_release(x_344, 3); + lean_ctor_release(x_344, 4); + lean_ctor_release(x_344, 5); + x_352 = x_344; } else { - lean_dec_ref(x_329); + lean_dec_ref(x_344); x_352 = lean_box(0); } x_353 = lean_ctor_get(x_345, 0); @@ -18798,315 +19252,411 @@ x_354 = lean_ctor_get(x_345, 1); lean_inc(x_354); x_355 = lean_ctor_get(x_345, 3); lean_inc(x_355); +x_356 = lean_ctor_get(x_345, 4); +lean_inc(x_356); if (lean_is_exclusive(x_345)) { lean_ctor_release(x_345, 0); lean_ctor_release(x_345, 1); lean_ctor_release(x_345, 2); lean_ctor_release(x_345, 3); - x_356 = x_345; + lean_ctor_release(x_345, 4); + x_357 = x_345; } else { lean_dec_ref(x_345); - x_356 = lean_box(0); + x_357 = lean_box(0); } -if (lean_is_scalar(x_356)) { - x_357 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_357)) { + x_358 = lean_alloc_ctor(0, 5, 0); } else { - x_357 = x_356; + x_358 = x_357; } -lean_ctor_set(x_357, 0, x_353); -lean_ctor_set(x_357, 1, x_354); -lean_ctor_set(x_357, 2, x_326); -lean_ctor_set(x_357, 3, x_355); +lean_ctor_set(x_358, 0, x_353); +lean_ctor_set(x_358, 1, x_354); +lean_ctor_set(x_358, 2, x_340); +lean_ctor_set(x_358, 3, x_355); +lean_ctor_set(x_358, 4, x_356); if (lean_is_scalar(x_352)) { - x_358 = lean_alloc_ctor(0, 6, 0); + x_359 = lean_alloc_ctor(0, 6, 0); } else { - x_358 = x_352; + x_359 = x_352; } -lean_ctor_set(x_358, 0, x_347); -lean_ctor_set(x_358, 1, x_348); -lean_ctor_set(x_358, 2, x_357); -lean_ctor_set(x_358, 3, x_349); -lean_ctor_set(x_358, 4, x_350); -lean_ctor_set(x_358, 5, x_351); -if (lean_is_scalar(x_238)) { - x_359 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_359, 0, x_347); +lean_ctor_set(x_359, 1, x_348); +lean_ctor_set(x_359, 2, x_358); +lean_ctor_set(x_359, 3, x_349); +lean_ctor_set(x_359, 4, x_350); +lean_ctor_set(x_359, 5, x_351); +if (lean_is_scalar(x_248)) { + x_360 = lean_alloc_ctor(1, 2, 0); } else { - x_359 = x_238; + x_360 = x_248; + lean_ctor_set_tag(x_360, 1); } -lean_ctor_set(x_359, 0, x_346); -lean_ctor_set(x_359, 1, x_358); -return x_359; +lean_ctor_set(x_360, 0, x_346); +lean_ctor_set(x_360, 1, x_359); +return x_360; +} +else +{ +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; lean_object* x_374; lean_object* x_375; lean_object* x_376; +x_361 = lean_ctor_get(x_344, 2); +lean_inc(x_361); +x_362 = lean_ctor_get(x_343, 0); +lean_inc(x_362); +lean_dec(x_343); +x_363 = lean_ctor_get(x_344, 0); +lean_inc(x_363); +x_364 = lean_ctor_get(x_344, 1); +lean_inc(x_364); +x_365 = lean_ctor_get(x_344, 3); +lean_inc(x_365); +x_366 = lean_ctor_get(x_344, 4); +lean_inc(x_366); +x_367 = lean_ctor_get(x_344, 5); +lean_inc(x_367); +if (lean_is_exclusive(x_344)) { + lean_ctor_release(x_344, 0); + lean_ctor_release(x_344, 1); + lean_ctor_release(x_344, 2); + lean_ctor_release(x_344, 3); + lean_ctor_release(x_344, 4); + lean_ctor_release(x_344, 5); + x_368 = x_344; +} else { + lean_dec_ref(x_344); + x_368 = lean_box(0); +} +x_369 = lean_ctor_get(x_361, 0); +lean_inc(x_369); +x_370 = lean_ctor_get(x_361, 1); +lean_inc(x_370); +x_371 = lean_ctor_get(x_361, 3); +lean_inc(x_371); +x_372 = lean_ctor_get(x_361, 4); +lean_inc(x_372); +if (lean_is_exclusive(x_361)) { + lean_ctor_release(x_361, 0); + lean_ctor_release(x_361, 1); + lean_ctor_release(x_361, 2); + lean_ctor_release(x_361, 3); + lean_ctor_release(x_361, 4); + x_373 = x_361; +} else { + lean_dec_ref(x_361); + x_373 = lean_box(0); +} +if (lean_is_scalar(x_373)) { + x_374 = lean_alloc_ctor(0, 5, 0); +} else { + x_374 = x_373; +} +lean_ctor_set(x_374, 0, x_369); +lean_ctor_set(x_374, 1, x_370); +lean_ctor_set(x_374, 2, x_340); +lean_ctor_set(x_374, 3, x_371); +lean_ctor_set(x_374, 4, x_372); +if (lean_is_scalar(x_368)) { + x_375 = lean_alloc_ctor(0, 6, 0); +} else { + x_375 = x_368; +} +lean_ctor_set(x_375, 0, x_363); +lean_ctor_set(x_375, 1, x_364); +lean_ctor_set(x_375, 2, x_374); +lean_ctor_set(x_375, 3, x_365); +lean_ctor_set(x_375, 4, x_366); +lean_ctor_set(x_375, 5, x_367); +if (lean_is_scalar(x_248)) { + x_376 = lean_alloc_ctor(0, 2, 0); +} else { + x_376 = x_248; +} +lean_ctor_set(x_376, 0, x_362); +lean_ctor_set(x_376, 1, x_375); +return x_376; } } } } else { -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; lean_object* x_391; lean_object* x_423; lean_object* x_424; lean_object* x_425; lean_object* x_426; lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; lean_object* x_432; lean_object* x_433; lean_object* x_434; lean_object* x_435; -x_379 = lean_ctor_get(x_237, 2); -x_380 = lean_ctor_get(x_237, 0); -x_381 = lean_ctor_get(x_237, 1); -x_382 = lean_ctor_get(x_237, 3); -x_383 = lean_ctor_get(x_237, 4); -x_384 = lean_ctor_get(x_237, 5); -lean_inc(x_384); -lean_inc(x_383); -lean_inc(x_382); -lean_inc(x_379); -lean_inc(x_381); -lean_inc(x_380); -lean_dec(x_237); -x_385 = lean_ctor_get(x_379, 0); -lean_inc(x_385); -x_386 = lean_ctor_get(x_379, 1); -lean_inc(x_386); -x_387 = lean_ctor_get(x_379, 2); -lean_inc(x_387); -x_388 = lean_ctor_get(x_379, 3); -lean_inc(x_388); -if (lean_is_exclusive(x_379)) { - lean_ctor_release(x_379, 0); - lean_ctor_release(x_379, 1); - lean_ctor_release(x_379, 2); - lean_ctor_release(x_379, 3); - x_389 = x_379; +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; lean_object* x_408; lean_object* x_409; lean_object* x_443; lean_object* x_444; lean_object* x_445; lean_object* x_446; lean_object* x_447; lean_object* x_448; lean_object* x_449; lean_object* x_450; lean_object* x_451; lean_object* x_452; lean_object* x_453; lean_object* x_454; lean_object* x_455; +x_396 = lean_ctor_get(x_247, 2); +x_397 = lean_ctor_get(x_247, 0); +x_398 = lean_ctor_get(x_247, 1); +x_399 = lean_ctor_get(x_247, 3); +x_400 = lean_ctor_get(x_247, 4); +x_401 = lean_ctor_get(x_247, 5); +lean_inc(x_401); +lean_inc(x_400); +lean_inc(x_399); +lean_inc(x_396); +lean_inc(x_398); +lean_inc(x_397); +lean_dec(x_247); +x_402 = lean_ctor_get(x_396, 0); +lean_inc(x_402); +x_403 = lean_ctor_get(x_396, 1); +lean_inc(x_403); +x_404 = lean_ctor_get(x_396, 2); +lean_inc(x_404); +x_405 = lean_ctor_get(x_396, 3); +lean_inc(x_405); +x_406 = lean_ctor_get(x_396, 4); +lean_inc(x_406); +if (lean_is_exclusive(x_396)) { + lean_ctor_release(x_396, 0); + lean_ctor_release(x_396, 1); + lean_ctor_release(x_396, 2); + lean_ctor_release(x_396, 3); + lean_ctor_release(x_396, 4); + x_407 = x_396; } else { - lean_dec_ref(x_379); - x_389 = lean_box(0); + lean_dec_ref(x_396); + x_407 = lean_box(0); } -x_423 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_389)) { - x_424 = lean_alloc_ctor(0, 4, 0); +x_443 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_407)) { + x_444 = lean_alloc_ctor(0, 5, 0); } else { - x_424 = x_389; + x_444 = x_407; } -lean_ctor_set(x_424, 0, x_385); -lean_ctor_set(x_424, 1, x_386); -lean_ctor_set(x_424, 2, x_423); -lean_ctor_set(x_424, 3, x_388); -x_425 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_425, 0, x_380); -lean_ctor_set(x_425, 1, x_381); -lean_ctor_set(x_425, 2, x_424); -lean_ctor_set(x_425, 3, x_382); -lean_ctor_set(x_425, 4, x_383); -lean_ctor_set(x_425, 5, x_384); -x_426 = lean_ctor_get(x_7, 0); -lean_inc(x_426); -x_427 = lean_ctor_get(x_7, 1); -lean_inc(x_427); -x_428 = lean_ctor_get(x_7, 2); -lean_inc(x_428); -x_429 = lean_ctor_get(x_7, 3); -lean_inc(x_429); -x_430 = lean_ctor_get(x_7, 4); -lean_inc(x_430); +lean_ctor_set(x_444, 0, x_402); +lean_ctor_set(x_444, 1, x_403); +lean_ctor_set(x_444, 2, x_443); +lean_ctor_set(x_444, 3, x_405); +lean_ctor_set(x_444, 4, x_406); +x_445 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_445, 0, x_397); +lean_ctor_set(x_445, 1, x_398); +lean_ctor_set(x_445, 2, x_444); +lean_ctor_set(x_445, 3, x_399); +lean_ctor_set(x_445, 4, x_400); +lean_ctor_set(x_445, 5, x_401); +x_446 = lean_ctor_get(x_7, 0); +lean_inc(x_446); +x_447 = lean_ctor_get(x_7, 1); +lean_inc(x_447); +x_448 = lean_ctor_get(x_7, 2); +lean_inc(x_448); +x_449 = lean_ctor_get(x_7, 3); +lean_inc(x_449); +x_450 = lean_ctor_get(x_7, 4); +lean_inc(x_450); if (lean_is_exclusive(x_7)) { lean_ctor_release(x_7, 0); lean_ctor_release(x_7, 1); lean_ctor_release(x_7, 2); lean_ctor_release(x_7, 3); lean_ctor_release(x_7, 4); - x_431 = x_7; + x_451 = x_7; } else { lean_dec_ref(x_7); - x_431 = lean_box(0); + x_451 = lean_box(0); } -x_432 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_432, 0, x_239); -lean_ctor_set(x_432, 1, x_14); -x_433 = lean_array_push(x_428, x_432); -if (lean_is_scalar(x_431)) { - x_434 = lean_alloc_ctor(0, 5, 0); +x_452 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_452, 0, x_249); +lean_ctor_set(x_452, 1, x_14); +x_453 = lean_array_push(x_448, x_452); +if (lean_is_scalar(x_451)) { + x_454 = lean_alloc_ctor(0, 5, 0); } else { - x_434 = x_431; + x_454 = x_451; } -lean_ctor_set(x_434, 0, x_426); -lean_ctor_set(x_434, 1, x_427); -lean_ctor_set(x_434, 2, x_433); -lean_ctor_set(x_434, 3, x_429); -lean_ctor_set(x_434, 4, x_430); -x_435 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__2___rarg(x_1, x_2, x_3, x_4, x_5, x_241, x_434, x_425); -if (lean_obj_tag(x_435) == 0) +lean_ctor_set(x_454, 0, x_446); +lean_ctor_set(x_454, 1, x_447); +lean_ctor_set(x_454, 2, x_453); +lean_ctor_set(x_454, 3, x_449); +lean_ctor_set(x_454, 4, x_450); +x_455 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__2___rarg(x_1, x_2, x_3, x_4, x_5, x_251, x_454, x_445); +if (lean_obj_tag(x_455) == 0) { -lean_object* x_436; lean_object* x_437; lean_object* x_438; -x_436 = lean_ctor_get(x_435, 0); -lean_inc(x_436); -x_437 = lean_ctor_get(x_435, 1); -lean_inc(x_437); -lean_dec(x_435); -x_438 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_438, 0, x_436); -x_390 = x_438; -x_391 = x_437; -goto block_422; +lean_object* x_456; lean_object* x_457; lean_object* x_458; +x_456 = lean_ctor_get(x_455, 0); +lean_inc(x_456); +x_457 = lean_ctor_get(x_455, 1); +lean_inc(x_457); +lean_dec(x_455); +x_458 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_458, 0, x_456); +x_408 = x_458; +x_409 = x_457; +goto block_442; } else { -lean_object* x_439; lean_object* x_440; lean_object* x_441; -x_439 = lean_ctor_get(x_435, 0); -lean_inc(x_439); -x_440 = lean_ctor_get(x_435, 1); -lean_inc(x_440); -lean_dec(x_435); -x_441 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_441, 0, x_439); -x_390 = x_441; -x_391 = x_440; -goto block_422; +lean_object* x_459; lean_object* x_460; lean_object* x_461; +x_459 = lean_ctor_get(x_455, 0); +lean_inc(x_459); +x_460 = lean_ctor_get(x_455, 1); +lean_inc(x_460); +lean_dec(x_455); +x_461 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_461, 0, x_459); +x_408 = x_461; +x_409 = x_460; +goto block_442; } -block_422: +block_442: { -if (lean_obj_tag(x_390) == 0) +if (lean_obj_tag(x_408) == 0) { -lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; lean_object* x_400; lean_object* x_401; lean_object* x_402; lean_object* x_403; lean_object* x_404; lean_object* x_405; lean_object* x_406; -x_392 = lean_ctor_get(x_391, 2); -lean_inc(x_392); -x_393 = lean_ctor_get(x_390, 0); -lean_inc(x_393); -lean_dec(x_390); -x_394 = lean_ctor_get(x_391, 0); -lean_inc(x_394); -x_395 = lean_ctor_get(x_391, 1); -lean_inc(x_395); -x_396 = lean_ctor_get(x_391, 3); -lean_inc(x_396); -x_397 = lean_ctor_get(x_391, 4); -lean_inc(x_397); -x_398 = lean_ctor_get(x_391, 5); -lean_inc(x_398); -if (lean_is_exclusive(x_391)) { - lean_ctor_release(x_391, 0); - lean_ctor_release(x_391, 1); - lean_ctor_release(x_391, 2); - lean_ctor_release(x_391, 3); - lean_ctor_release(x_391, 4); - lean_ctor_release(x_391, 5); - x_399 = x_391; -} else { - lean_dec_ref(x_391); - x_399 = lean_box(0); -} -x_400 = lean_ctor_get(x_392, 0); -lean_inc(x_400); -x_401 = lean_ctor_get(x_392, 1); -lean_inc(x_401); -x_402 = lean_ctor_get(x_392, 3); -lean_inc(x_402); -if (lean_is_exclusive(x_392)) { - lean_ctor_release(x_392, 0); - lean_ctor_release(x_392, 1); - lean_ctor_release(x_392, 2); - lean_ctor_release(x_392, 3); - x_403 = x_392; -} else { - lean_dec_ref(x_392); - x_403 = lean_box(0); -} -if (lean_is_scalar(x_403)) { - x_404 = lean_alloc_ctor(0, 4, 0); -} else { - x_404 = x_403; -} -lean_ctor_set(x_404, 0, x_400); -lean_ctor_set(x_404, 1, x_401); -lean_ctor_set(x_404, 2, x_387); -lean_ctor_set(x_404, 3, x_402); -if (lean_is_scalar(x_399)) { - x_405 = lean_alloc_ctor(0, 6, 0); -} else { - x_405 = x_399; -} -lean_ctor_set(x_405, 0, x_394); -lean_ctor_set(x_405, 1, x_395); -lean_ctor_set(x_405, 2, x_404); -lean_ctor_set(x_405, 3, x_396); -lean_ctor_set(x_405, 4, x_397); -lean_ctor_set(x_405, 5, x_398); -if (lean_is_scalar(x_238)) { - x_406 = lean_alloc_ctor(1, 2, 0); -} else { - x_406 = x_238; - lean_ctor_set_tag(x_406, 1); -} -lean_ctor_set(x_406, 0, x_393); -lean_ctor_set(x_406, 1, x_405); -return x_406; -} -else -{ -lean_object* x_407; lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_object* x_412; lean_object* x_413; lean_object* x_414; lean_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; -x_407 = lean_ctor_get(x_391, 2); -lean_inc(x_407); -x_408 = lean_ctor_get(x_390, 0); -lean_inc(x_408); -lean_dec(x_390); -x_409 = lean_ctor_get(x_391, 0); -lean_inc(x_409); -x_410 = lean_ctor_get(x_391, 1); +lean_object* x_410; 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_410 = lean_ctor_get(x_409, 2); lean_inc(x_410); -x_411 = lean_ctor_get(x_391, 3); +x_411 = lean_ctor_get(x_408, 0); lean_inc(x_411); -x_412 = lean_ctor_get(x_391, 4); +lean_dec(x_408); +x_412 = lean_ctor_get(x_409, 0); lean_inc(x_412); -x_413 = lean_ctor_get(x_391, 5); +x_413 = lean_ctor_get(x_409, 1); lean_inc(x_413); -if (lean_is_exclusive(x_391)) { - lean_ctor_release(x_391, 0); - lean_ctor_release(x_391, 1); - lean_ctor_release(x_391, 2); - lean_ctor_release(x_391, 3); - lean_ctor_release(x_391, 4); - lean_ctor_release(x_391, 5); - x_414 = x_391; -} else { - lean_dec_ref(x_391); - x_414 = lean_box(0); -} -x_415 = lean_ctor_get(x_407, 0); +x_414 = lean_ctor_get(x_409, 3); +lean_inc(x_414); +x_415 = lean_ctor_get(x_409, 4); lean_inc(x_415); -x_416 = lean_ctor_get(x_407, 1); +x_416 = lean_ctor_get(x_409, 5); lean_inc(x_416); -x_417 = lean_ctor_get(x_407, 3); -lean_inc(x_417); -if (lean_is_exclusive(x_407)) { - lean_ctor_release(x_407, 0); - lean_ctor_release(x_407, 1); - lean_ctor_release(x_407, 2); - lean_ctor_release(x_407, 3); - x_418 = x_407; +if (lean_is_exclusive(x_409)) { + lean_ctor_release(x_409, 0); + lean_ctor_release(x_409, 1); + lean_ctor_release(x_409, 2); + lean_ctor_release(x_409, 3); + lean_ctor_release(x_409, 4); + lean_ctor_release(x_409, 5); + x_417 = x_409; } else { - lean_dec_ref(x_407); - x_418 = lean_box(0); + lean_dec_ref(x_409); + x_417 = lean_box(0); } -if (lean_is_scalar(x_418)) { - x_419 = lean_alloc_ctor(0, 4, 0); +x_418 = lean_ctor_get(x_410, 0); +lean_inc(x_418); +x_419 = lean_ctor_get(x_410, 1); +lean_inc(x_419); +x_420 = lean_ctor_get(x_410, 3); +lean_inc(x_420); +x_421 = lean_ctor_get(x_410, 4); +lean_inc(x_421); +if (lean_is_exclusive(x_410)) { + lean_ctor_release(x_410, 0); + lean_ctor_release(x_410, 1); + lean_ctor_release(x_410, 2); + lean_ctor_release(x_410, 3); + lean_ctor_release(x_410, 4); + x_422 = x_410; } else { - x_419 = x_418; + lean_dec_ref(x_410); + x_422 = lean_box(0); } -lean_ctor_set(x_419, 0, x_415); -lean_ctor_set(x_419, 1, x_416); -lean_ctor_set(x_419, 2, x_387); -lean_ctor_set(x_419, 3, x_417); -if (lean_is_scalar(x_414)) { - x_420 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_422)) { + x_423 = lean_alloc_ctor(0, 5, 0); } else { - x_420 = x_414; + x_423 = x_422; } -lean_ctor_set(x_420, 0, x_409); -lean_ctor_set(x_420, 1, x_410); -lean_ctor_set(x_420, 2, x_419); -lean_ctor_set(x_420, 3, x_411); -lean_ctor_set(x_420, 4, x_412); -lean_ctor_set(x_420, 5, x_413); -if (lean_is_scalar(x_238)) { - x_421 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_423, 0, x_418); +lean_ctor_set(x_423, 1, x_419); +lean_ctor_set(x_423, 2, x_404); +lean_ctor_set(x_423, 3, x_420); +lean_ctor_set(x_423, 4, x_421); +if (lean_is_scalar(x_417)) { + x_424 = lean_alloc_ctor(0, 6, 0); } else { - x_421 = x_238; + x_424 = x_417; } -lean_ctor_set(x_421, 0, x_408); -lean_ctor_set(x_421, 1, x_420); -return x_421; +lean_ctor_set(x_424, 0, x_412); +lean_ctor_set(x_424, 1, x_413); +lean_ctor_set(x_424, 2, x_423); +lean_ctor_set(x_424, 3, x_414); +lean_ctor_set(x_424, 4, x_415); +lean_ctor_set(x_424, 5, x_416); +if (lean_is_scalar(x_248)) { + x_425 = lean_alloc_ctor(1, 2, 0); +} else { + x_425 = x_248; + lean_ctor_set_tag(x_425, 1); +} +lean_ctor_set(x_425, 0, x_411); +lean_ctor_set(x_425, 1, x_424); +return x_425; +} +else +{ +lean_object* x_426; lean_object* x_427; 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; +x_426 = lean_ctor_get(x_409, 2); +lean_inc(x_426); +x_427 = lean_ctor_get(x_408, 0); +lean_inc(x_427); +lean_dec(x_408); +x_428 = lean_ctor_get(x_409, 0); +lean_inc(x_428); +x_429 = lean_ctor_get(x_409, 1); +lean_inc(x_429); +x_430 = lean_ctor_get(x_409, 3); +lean_inc(x_430); +x_431 = lean_ctor_get(x_409, 4); +lean_inc(x_431); +x_432 = lean_ctor_get(x_409, 5); +lean_inc(x_432); +if (lean_is_exclusive(x_409)) { + lean_ctor_release(x_409, 0); + lean_ctor_release(x_409, 1); + lean_ctor_release(x_409, 2); + lean_ctor_release(x_409, 3); + lean_ctor_release(x_409, 4); + lean_ctor_release(x_409, 5); + x_433 = x_409; +} else { + lean_dec_ref(x_409); + x_433 = lean_box(0); +} +x_434 = lean_ctor_get(x_426, 0); +lean_inc(x_434); +x_435 = lean_ctor_get(x_426, 1); +lean_inc(x_435); +x_436 = lean_ctor_get(x_426, 3); +lean_inc(x_436); +x_437 = lean_ctor_get(x_426, 4); +lean_inc(x_437); +if (lean_is_exclusive(x_426)) { + lean_ctor_release(x_426, 0); + lean_ctor_release(x_426, 1); + lean_ctor_release(x_426, 2); + lean_ctor_release(x_426, 3); + lean_ctor_release(x_426, 4); + x_438 = x_426; +} else { + lean_dec_ref(x_426); + x_438 = lean_box(0); +} +if (lean_is_scalar(x_438)) { + x_439 = lean_alloc_ctor(0, 5, 0); +} else { + x_439 = x_438; +} +lean_ctor_set(x_439, 0, x_434); +lean_ctor_set(x_439, 1, x_435); +lean_ctor_set(x_439, 2, x_404); +lean_ctor_set(x_439, 3, x_436); +lean_ctor_set(x_439, 4, x_437); +if (lean_is_scalar(x_433)) { + x_440 = lean_alloc_ctor(0, 6, 0); +} else { + x_440 = x_433; +} +lean_ctor_set(x_440, 0, x_428); +lean_ctor_set(x_440, 1, x_429); +lean_ctor_set(x_440, 2, x_439); +lean_ctor_set(x_440, 3, x_430); +lean_ctor_set(x_440, 4, x_431); +lean_ctor_set(x_440, 5, x_432); +if (lean_is_scalar(x_248)) { + x_441 = lean_alloc_ctor(0, 2, 0); +} else { + x_441 = x_248; +} +lean_ctor_set(x_441, 0, x_427); +lean_ctor_set(x_441, 1, x_440); +return x_441; } } } @@ -19114,29 +19664,29 @@ return x_421; } else { -uint8_t x_442; +uint8_t x_462; lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_442 = !lean_is_exclusive(x_231); -if (x_442 == 0) +x_462 = !lean_is_exclusive(x_241); +if (x_462 == 0) { -return x_231; +return x_241; } else { -lean_object* x_443; lean_object* x_444; lean_object* x_445; -x_443 = lean_ctor_get(x_231, 0); -x_444 = lean_ctor_get(x_231, 1); -lean_inc(x_444); -lean_inc(x_443); -lean_dec(x_231); -x_445 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_445, 0, x_443); -lean_ctor_set(x_445, 1, x_444); -return x_445; +lean_object* x_463; lean_object* x_464; lean_object* x_465; +x_463 = lean_ctor_get(x_241, 0); +x_464 = lean_ctor_get(x_241, 1); +lean_inc(x_464); +lean_inc(x_463); +lean_dec(x_241); +x_465 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_465, 0, x_463); +lean_ctor_set(x_465, 1, x_464); +return x_465; } } } @@ -19144,58 +19694,58 @@ return x_445; } else { -uint8_t x_446; +uint8_t x_466; lean_dec(x_18); lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_446 = !lean_is_exclusive(x_19); -if (x_446 == 0) +x_466 = !lean_is_exclusive(x_19); +if (x_466 == 0) { return x_19; } else { -lean_object* x_447; lean_object* x_448; lean_object* x_449; -x_447 = lean_ctor_get(x_19, 0); -x_448 = lean_ctor_get(x_19, 1); -lean_inc(x_448); -lean_inc(x_447); +lean_object* x_467; lean_object* x_468; lean_object* x_469; +x_467 = lean_ctor_get(x_19, 0); +x_468 = lean_ctor_get(x_19, 1); +lean_inc(x_468); +lean_inc(x_467); lean_dec(x_19); -x_449 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_449, 0, x_447); -lean_ctor_set(x_449, 1, x_448); -return x_449; +x_469 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_469, 0, x_467); +lean_ctor_set(x_469, 1, x_468); +return x_469; } } } else { -uint8_t x_450; +uint8_t x_470; lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_450 = !lean_is_exclusive(x_15); -if (x_450 == 0) +x_470 = !lean_is_exclusive(x_15); +if (x_470 == 0) { return x_15; } else { -lean_object* x_451; lean_object* x_452; lean_object* x_453; -x_451 = lean_ctor_get(x_15, 0); -x_452 = lean_ctor_get(x_15, 1); -lean_inc(x_452); -lean_inc(x_451); +lean_object* x_471; lean_object* x_472; lean_object* x_473; +x_471 = lean_ctor_get(x_15, 0); +x_472 = lean_ctor_get(x_15, 1); +lean_inc(x_472); +lean_inc(x_471); lean_dec(x_15); -x_453 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_453, 0, x_451); -lean_ctor_set(x_453, 1, x_452); -return x_453; +x_473 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_473, 0, x_471); +lean_ctor_set(x_473, 1, x_472); +return x_473; } } } @@ -19341,105 +19891,105 @@ x_37 = lean_ctor_get(x_31, 2); x_38 = !lean_is_exclusive(x_37); if (x_38 == 0) { -lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_91; uint8_t x_92; +lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_95; uint8_t x_96; x_39 = lean_ctor_get(x_37, 2); -x_91 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_37, 2, x_91); -x_92 = !lean_is_exclusive(x_12); -if (x_92 == 0) +x_95 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_37, 2, x_95); +x_96 = !lean_is_exclusive(x_12); +if (x_96 == 0) { -lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; -x_93 = lean_ctor_get(x_12, 2); -x_94 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_94, 0, x_33); -lean_ctor_set(x_94, 1, x_20); -x_95 = lean_array_push(x_93, x_94); -lean_ctor_set(x_12, 2, x_95); -x_96 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_35, x_12, x_31); -if (lean_obj_tag(x_96) == 0) +lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; +x_97 = lean_ctor_get(x_12, 2); +x_98 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_98, 0, x_33); +lean_ctor_set(x_98, 1, x_20); +x_99 = lean_array_push(x_97, x_98); +lean_ctor_set(x_12, 2, x_99); +x_100 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_35, x_12, x_31); +if (lean_obj_tag(x_100) == 0) { -lean_object* x_97; lean_object* x_98; lean_object* x_99; -x_97 = lean_ctor_get(x_96, 0); -lean_inc(x_97); -x_98 = lean_ctor_get(x_96, 1); -lean_inc(x_98); -lean_dec(x_96); -x_99 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_99, 0, x_97); -x_40 = x_99; -x_41 = x_98; -goto block_90; -} -else -{ -lean_object* x_100; lean_object* x_101; lean_object* x_102; -x_100 = lean_ctor_get(x_96, 0); -lean_inc(x_100); -x_101 = lean_ctor_get(x_96, 1); +lean_object* x_101; lean_object* x_102; lean_object* x_103; +x_101 = lean_ctor_get(x_100, 0); lean_inc(x_101); -lean_dec(x_96); -x_102 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_102, 0, x_100); -x_40 = x_102; -x_41 = x_101; -goto block_90; -} +x_102 = lean_ctor_get(x_100, 1); +lean_inc(x_102); +lean_dec(x_100); +x_103 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_103, 0, x_101); +x_40 = x_103; +x_41 = x_102; +goto block_94; } else { -lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; -x_103 = lean_ctor_get(x_12, 0); -x_104 = lean_ctor_get(x_12, 1); -x_105 = lean_ctor_get(x_12, 2); -x_106 = lean_ctor_get(x_12, 3); -x_107 = lean_ctor_get(x_12, 4); -lean_inc(x_107); -lean_inc(x_106); -lean_inc(x_105); +lean_object* x_104; lean_object* x_105; lean_object* x_106; +x_104 = lean_ctor_get(x_100, 0); lean_inc(x_104); -lean_inc(x_103); -lean_dec(x_12); -x_108 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_108, 0, x_33); -lean_ctor_set(x_108, 1, x_20); -x_109 = lean_array_push(x_105, x_108); -x_110 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_110, 0, x_103); -lean_ctor_set(x_110, 1, x_104); -lean_ctor_set(x_110, 2, x_109); -lean_ctor_set(x_110, 3, x_106); -lean_ctor_set(x_110, 4, x_107); -x_111 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_35, x_110, x_31); -if (lean_obj_tag(x_111) == 0) -{ -lean_object* x_112; lean_object* x_113; lean_object* x_114; -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_alloc_ctor(1, 1, 0); -lean_ctor_set(x_114, 0, x_112); -x_40 = x_114; -x_41 = x_113; -goto block_90; +x_105 = lean_ctor_get(x_100, 1); +lean_inc(x_105); +lean_dec(x_100); +x_106 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_106, 0, x_104); +x_40 = x_106; +x_41 = x_105; +goto block_94; +} } else { -lean_object* x_115; lean_object* x_116; lean_object* x_117; -x_115 = lean_ctor_get(x_111, 0); -lean_inc(x_115); -x_116 = lean_ctor_get(x_111, 1); +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; +x_107 = lean_ctor_get(x_12, 0); +x_108 = lean_ctor_get(x_12, 1); +x_109 = lean_ctor_get(x_12, 2); +x_110 = lean_ctor_get(x_12, 3); +x_111 = lean_ctor_get(x_12, 4); +lean_inc(x_111); +lean_inc(x_110); +lean_inc(x_109); +lean_inc(x_108); +lean_inc(x_107); +lean_dec(x_12); +x_112 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_112, 0, x_33); +lean_ctor_set(x_112, 1, x_20); +x_113 = lean_array_push(x_109, x_112); +x_114 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_114, 0, x_107); +lean_ctor_set(x_114, 1, x_108); +lean_ctor_set(x_114, 2, x_113); +lean_ctor_set(x_114, 3, x_110); +lean_ctor_set(x_114, 4, x_111); +x_115 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_35, x_114, x_31); +if (lean_obj_tag(x_115) == 0) +{ +lean_object* x_116; lean_object* x_117; lean_object* x_118; +x_116 = lean_ctor_get(x_115, 0); lean_inc(x_116); -lean_dec(x_111); -x_117 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_117, 0, x_115); -x_40 = x_117; -x_41 = x_116; -goto block_90; +x_117 = lean_ctor_get(x_115, 1); +lean_inc(x_117); +lean_dec(x_115); +x_118 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_118, 0, x_116); +x_40 = x_118; +x_41 = x_117; +goto block_94; +} +else +{ +lean_object* x_119; lean_object* x_120; lean_object* x_121; +x_119 = lean_ctor_get(x_115, 0); +lean_inc(x_119); +x_120 = lean_ctor_get(x_115, 1); +lean_inc(x_120); +lean_dec(x_115); +x_121 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_121, 0, x_119); +x_40 = x_121; +x_41 = x_120; +goto block_94; } } -block_90: +block_94: { if (lean_obj_tag(x_40) == 0) { @@ -19474,1284 +20024,1262 @@ return x_48; } else { -lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; +lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; x_49 = lean_ctor_get(x_42, 0); x_50 = lean_ctor_get(x_42, 1); x_51 = lean_ctor_get(x_42, 3); +x_52 = lean_ctor_get(x_42, 4); +lean_inc(x_52); lean_inc(x_51); lean_inc(x_50); lean_inc(x_49); lean_dec(x_42); -x_52 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_52, 0, x_49); -lean_ctor_set(x_52, 1, x_50); -lean_ctor_set(x_52, 2, x_39); -lean_ctor_set(x_52, 3, x_51); -lean_ctor_set(x_41, 2, x_52); +x_53 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_53, 0, x_49); +lean_ctor_set(x_53, 1, x_50); +lean_ctor_set(x_53, 2, x_39); +lean_ctor_set(x_53, 3, x_51); +lean_ctor_set(x_53, 4, x_52); +lean_ctor_set(x_41, 2, x_53); if (lean_is_scalar(x_32)) { - x_53 = lean_alloc_ctor(1, 2, 0); + x_54 = lean_alloc_ctor(1, 2, 0); } else { - x_53 = x_32; - lean_ctor_set_tag(x_53, 1); + x_54 = x_32; + lean_ctor_set_tag(x_54, 1); } -lean_ctor_set(x_53, 0, x_43); -lean_ctor_set(x_53, 1, x_41); -return x_53; +lean_ctor_set(x_54, 0, x_43); +lean_ctor_set(x_54, 1, x_41); +return x_54; } } else { -lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; -x_54 = lean_ctor_get(x_41, 0); -x_55 = lean_ctor_get(x_41, 1); -x_56 = lean_ctor_get(x_41, 3); -x_57 = lean_ctor_get(x_41, 4); -x_58 = lean_ctor_get(x_41, 5); +lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; +x_55 = lean_ctor_get(x_41, 0); +x_56 = lean_ctor_get(x_41, 1); +x_57 = lean_ctor_get(x_41, 3); +x_58 = lean_ctor_get(x_41, 4); +x_59 = lean_ctor_get(x_41, 5); +lean_inc(x_59); lean_inc(x_58); lean_inc(x_57); lean_inc(x_56); lean_inc(x_55); -lean_inc(x_54); lean_dec(x_41); -x_59 = lean_ctor_get(x_42, 0); -lean_inc(x_59); -x_60 = lean_ctor_get(x_42, 1); +x_60 = lean_ctor_get(x_42, 0); lean_inc(x_60); -x_61 = lean_ctor_get(x_42, 3); +x_61 = lean_ctor_get(x_42, 1); lean_inc(x_61); +x_62 = lean_ctor_get(x_42, 3); +lean_inc(x_62); +x_63 = lean_ctor_get(x_42, 4); +lean_inc(x_63); if (lean_is_exclusive(x_42)) { lean_ctor_release(x_42, 0); lean_ctor_release(x_42, 1); lean_ctor_release(x_42, 2); lean_ctor_release(x_42, 3); - x_62 = x_42; + lean_ctor_release(x_42, 4); + x_64 = x_42; } else { lean_dec_ref(x_42); - x_62 = lean_box(0); + x_64 = lean_box(0); } -if (lean_is_scalar(x_62)) { - x_63 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_64)) { + x_65 = lean_alloc_ctor(0, 5, 0); } else { - x_63 = x_62; + x_65 = x_64; } -lean_ctor_set(x_63, 0, x_59); -lean_ctor_set(x_63, 1, x_60); -lean_ctor_set(x_63, 2, x_39); -lean_ctor_set(x_63, 3, x_61); -x_64 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_64, 0, x_54); -lean_ctor_set(x_64, 1, x_55); -lean_ctor_set(x_64, 2, x_63); -lean_ctor_set(x_64, 3, x_56); -lean_ctor_set(x_64, 4, x_57); -lean_ctor_set(x_64, 5, x_58); +lean_ctor_set(x_65, 0, x_60); +lean_ctor_set(x_65, 1, x_61); +lean_ctor_set(x_65, 2, x_39); +lean_ctor_set(x_65, 3, x_62); +lean_ctor_set(x_65, 4, x_63); +x_66 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_66, 0, x_55); +lean_ctor_set(x_66, 1, x_56); +lean_ctor_set(x_66, 2, x_65); +lean_ctor_set(x_66, 3, x_57); +lean_ctor_set(x_66, 4, x_58); +lean_ctor_set(x_66, 5, x_59); if (lean_is_scalar(x_32)) { - x_65 = lean_alloc_ctor(1, 2, 0); + x_67 = lean_alloc_ctor(1, 2, 0); } else { - x_65 = x_32; - lean_ctor_set_tag(x_65, 1); + x_67 = x_32; + lean_ctor_set_tag(x_67, 1); } -lean_ctor_set(x_65, 0, x_43); -lean_ctor_set(x_65, 1, x_64); -return x_65; +lean_ctor_set(x_67, 0, x_43); +lean_ctor_set(x_67, 1, x_66); +return x_67; } } else { -lean_object* x_66; lean_object* x_67; uint8_t x_68; -x_66 = lean_ctor_get(x_41, 2); -lean_inc(x_66); -x_67 = lean_ctor_get(x_40, 0); -lean_inc(x_67); +lean_object* x_68; lean_object* x_69; uint8_t x_70; +x_68 = lean_ctor_get(x_41, 2); +lean_inc(x_68); +x_69 = lean_ctor_get(x_40, 0); +lean_inc(x_69); lean_dec(x_40); -x_68 = !lean_is_exclusive(x_41); -if (x_68 == 0) -{ -lean_object* x_69; uint8_t x_70; -x_69 = lean_ctor_get(x_41, 2); -lean_dec(x_69); -x_70 = !lean_is_exclusive(x_66); +x_70 = !lean_is_exclusive(x_41); if (x_70 == 0) { -lean_object* x_71; lean_object* x_72; -x_71 = lean_ctor_get(x_66, 2); +lean_object* x_71; uint8_t x_72; +x_71 = lean_ctor_get(x_41, 2); lean_dec(x_71); -lean_ctor_set(x_66, 2, x_39); +x_72 = !lean_is_exclusive(x_68); +if (x_72 == 0) +{ +lean_object* x_73; lean_object* x_74; +x_73 = lean_ctor_get(x_68, 2); +lean_dec(x_73); +lean_ctor_set(x_68, 2, x_39); if (lean_is_scalar(x_32)) { - x_72 = lean_alloc_ctor(0, 2, 0); + x_74 = lean_alloc_ctor(0, 2, 0); } else { - x_72 = x_32; + x_74 = x_32; } -lean_ctor_set(x_72, 0, x_67); -lean_ctor_set(x_72, 1, x_41); -return x_72; +lean_ctor_set(x_74, 0, x_69); +lean_ctor_set(x_74, 1, x_41); +return x_74; } else { -lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; -x_73 = lean_ctor_get(x_66, 0); -x_74 = lean_ctor_get(x_66, 1); -x_75 = lean_ctor_get(x_66, 3); +lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; +x_75 = lean_ctor_get(x_68, 0); +x_76 = lean_ctor_get(x_68, 1); +x_77 = lean_ctor_get(x_68, 3); +x_78 = lean_ctor_get(x_68, 4); +lean_inc(x_78); +lean_inc(x_77); +lean_inc(x_76); lean_inc(x_75); -lean_inc(x_74); -lean_inc(x_73); -lean_dec(x_66); -x_76 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_76, 0, x_73); -lean_ctor_set(x_76, 1, x_74); -lean_ctor_set(x_76, 2, x_39); -lean_ctor_set(x_76, 3, x_75); -lean_ctor_set(x_41, 2, x_76); +lean_dec(x_68); +x_79 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_79, 0, x_75); +lean_ctor_set(x_79, 1, x_76); +lean_ctor_set(x_79, 2, x_39); +lean_ctor_set(x_79, 3, x_77); +lean_ctor_set(x_79, 4, x_78); +lean_ctor_set(x_41, 2, x_79); if (lean_is_scalar(x_32)) { - x_77 = lean_alloc_ctor(0, 2, 0); + x_80 = lean_alloc_ctor(0, 2, 0); } else { - x_77 = x_32; + x_80 = x_32; } -lean_ctor_set(x_77, 0, x_67); -lean_ctor_set(x_77, 1, x_41); -return x_77; +lean_ctor_set(x_80, 0, x_69); +lean_ctor_set(x_80, 1, x_41); +return x_80; } } else { -lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; -x_78 = lean_ctor_get(x_41, 0); -x_79 = lean_ctor_get(x_41, 1); -x_80 = lean_ctor_get(x_41, 3); -x_81 = lean_ctor_get(x_41, 4); -x_82 = lean_ctor_get(x_41, 5); +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; +x_81 = lean_ctor_get(x_41, 0); +x_82 = lean_ctor_get(x_41, 1); +x_83 = lean_ctor_get(x_41, 3); +x_84 = lean_ctor_get(x_41, 4); +x_85 = lean_ctor_get(x_41, 5); +lean_inc(x_85); +lean_inc(x_84); +lean_inc(x_83); lean_inc(x_82); lean_inc(x_81); -lean_inc(x_80); -lean_inc(x_79); -lean_inc(x_78); lean_dec(x_41); -x_83 = lean_ctor_get(x_66, 0); -lean_inc(x_83); -x_84 = lean_ctor_get(x_66, 1); -lean_inc(x_84); -x_85 = lean_ctor_get(x_66, 3); -lean_inc(x_85); -if (lean_is_exclusive(x_66)) { - lean_ctor_release(x_66, 0); - lean_ctor_release(x_66, 1); - lean_ctor_release(x_66, 2); - lean_ctor_release(x_66, 3); - x_86 = x_66; +x_86 = lean_ctor_get(x_68, 0); +lean_inc(x_86); +x_87 = lean_ctor_get(x_68, 1); +lean_inc(x_87); +x_88 = lean_ctor_get(x_68, 3); +lean_inc(x_88); +x_89 = lean_ctor_get(x_68, 4); +lean_inc(x_89); +if (lean_is_exclusive(x_68)) { + lean_ctor_release(x_68, 0); + lean_ctor_release(x_68, 1); + lean_ctor_release(x_68, 2); + lean_ctor_release(x_68, 3); + lean_ctor_release(x_68, 4); + x_90 = x_68; } else { - lean_dec_ref(x_66); - x_86 = lean_box(0); + lean_dec_ref(x_68); + x_90 = lean_box(0); } -if (lean_is_scalar(x_86)) { - x_87 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_90)) { + x_91 = lean_alloc_ctor(0, 5, 0); } else { - x_87 = x_86; + x_91 = x_90; } -lean_ctor_set(x_87, 0, x_83); -lean_ctor_set(x_87, 1, x_84); -lean_ctor_set(x_87, 2, x_39); -lean_ctor_set(x_87, 3, x_85); -x_88 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_88, 0, x_78); -lean_ctor_set(x_88, 1, x_79); -lean_ctor_set(x_88, 2, x_87); -lean_ctor_set(x_88, 3, x_80); -lean_ctor_set(x_88, 4, x_81); -lean_ctor_set(x_88, 5, x_82); +lean_ctor_set(x_91, 0, x_86); +lean_ctor_set(x_91, 1, x_87); +lean_ctor_set(x_91, 2, x_39); +lean_ctor_set(x_91, 3, x_88); +lean_ctor_set(x_91, 4, x_89); +x_92 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_92, 0, x_81); +lean_ctor_set(x_92, 1, x_82); +lean_ctor_set(x_92, 2, x_91); +lean_ctor_set(x_92, 3, x_83); +lean_ctor_set(x_92, 4, x_84); +lean_ctor_set(x_92, 5, x_85); if (lean_is_scalar(x_32)) { - x_89 = lean_alloc_ctor(0, 2, 0); + x_93 = lean_alloc_ctor(0, 2, 0); } else { - x_89 = x_32; + x_93 = x_32; } -lean_ctor_set(x_89, 0, x_67); -lean_ctor_set(x_89, 1, x_88); -return x_89; +lean_ctor_set(x_93, 0, x_69); +lean_ctor_set(x_93, 1, x_92); +return x_93; } } } } else { -lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_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; -x_118 = lean_ctor_get(x_37, 0); -x_119 = lean_ctor_get(x_37, 1); -x_120 = lean_ctor_get(x_37, 2); -x_121 = lean_ctor_get(x_37, 3); -lean_inc(x_121); -lean_inc(x_120); -lean_inc(x_119); -lean_inc(x_118); -lean_dec(x_37); -x_155 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_156 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_156, 0, x_118); -lean_ctor_set(x_156, 1, x_119); -lean_ctor_set(x_156, 2, x_155); -lean_ctor_set(x_156, 3, x_121); -lean_ctor_set(x_31, 2, x_156); -x_157 = lean_ctor_get(x_12, 0); -lean_inc(x_157); -x_158 = lean_ctor_get(x_12, 1); -lean_inc(x_158); -x_159 = lean_ctor_get(x_12, 2); -lean_inc(x_159); -x_160 = lean_ctor_get(x_12, 3); -lean_inc(x_160); -x_161 = lean_ctor_get(x_12, 4); -lean_inc(x_161); -if (lean_is_exclusive(x_12)) { - lean_ctor_release(x_12, 0); - lean_ctor_release(x_12, 1); - lean_ctor_release(x_12, 2); - lean_ctor_release(x_12, 3); - lean_ctor_release(x_12, 4); - x_162 = x_12; -} else { - lean_dec_ref(x_12); - x_162 = lean_box(0); -} -x_163 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_163, 0, x_33); -lean_ctor_set(x_163, 1, x_20); -x_164 = lean_array_push(x_159, x_163); -if (lean_is_scalar(x_162)) { - x_165 = lean_alloc_ctor(0, 5, 0); -} else { - x_165 = x_162; -} -lean_ctor_set(x_165, 0, x_157); -lean_ctor_set(x_165, 1, x_158); -lean_ctor_set(x_165, 2, x_164); -lean_ctor_set(x_165, 3, x_160); -lean_ctor_set(x_165, 4, x_161); -x_166 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_35, x_165, x_31); -if (lean_obj_tag(x_166) == 0) -{ -lean_object* x_167; lean_object* x_168; lean_object* x_169; -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, 1, 0); -lean_ctor_set(x_169, 0, x_167); -x_122 = x_169; -x_123 = x_168; -goto block_154; -} -else -{ -lean_object* x_170; lean_object* x_171; lean_object* x_172; -x_170 = lean_ctor_get(x_166, 0); -lean_inc(x_170); -x_171 = lean_ctor_get(x_166, 1); -lean_inc(x_171); -lean_dec(x_166); -x_172 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_172, 0, x_170); -x_122 = x_172; -x_123 = x_171; -goto block_154; -} -block_154: -{ -if (lean_obj_tag(x_122) == 0) -{ -lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; -x_124 = lean_ctor_get(x_123, 2); -lean_inc(x_124); -x_125 = lean_ctor_get(x_122, 0); -lean_inc(x_125); -lean_dec(x_122); -x_126 = lean_ctor_get(x_123, 0); +lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; lean_object* x_173; +x_122 = lean_ctor_get(x_37, 0); +x_123 = lean_ctor_get(x_37, 1); +x_124 = lean_ctor_get(x_37, 2); +x_125 = lean_ctor_get(x_37, 3); +x_126 = lean_ctor_get(x_37, 4); lean_inc(x_126); -x_127 = lean_ctor_get(x_123, 1); -lean_inc(x_127); -x_128 = lean_ctor_get(x_123, 3); -lean_inc(x_128); -x_129 = lean_ctor_get(x_123, 4); -lean_inc(x_129); -x_130 = lean_ctor_get(x_123, 5); -lean_inc(x_130); -if (lean_is_exclusive(x_123)) { - lean_ctor_release(x_123, 0); - lean_ctor_release(x_123, 1); - lean_ctor_release(x_123, 2); - lean_ctor_release(x_123, 3); - lean_ctor_release(x_123, 4); - lean_ctor_release(x_123, 5); - x_131 = x_123; -} else { - lean_dec_ref(x_123); - x_131 = lean_box(0); -} -x_132 = lean_ctor_get(x_124, 0); -lean_inc(x_132); -x_133 = lean_ctor_get(x_124, 1); -lean_inc(x_133); -x_134 = lean_ctor_get(x_124, 3); -lean_inc(x_134); -if (lean_is_exclusive(x_124)) { - lean_ctor_release(x_124, 0); - lean_ctor_release(x_124, 1); - lean_ctor_release(x_124, 2); - lean_ctor_release(x_124, 3); - x_135 = x_124; -} else { - lean_dec_ref(x_124); - x_135 = lean_box(0); -} -if (lean_is_scalar(x_135)) { - x_136 = lean_alloc_ctor(0, 4, 0); -} else { - x_136 = x_135; -} -lean_ctor_set(x_136, 0, x_132); -lean_ctor_set(x_136, 1, x_133); -lean_ctor_set(x_136, 2, x_120); -lean_ctor_set(x_136, 3, x_134); -if (lean_is_scalar(x_131)) { - x_137 = lean_alloc_ctor(0, 6, 0); -} else { - x_137 = x_131; -} -lean_ctor_set(x_137, 0, x_126); -lean_ctor_set(x_137, 1, x_127); -lean_ctor_set(x_137, 2, x_136); -lean_ctor_set(x_137, 3, x_128); -lean_ctor_set(x_137, 4, x_129); -lean_ctor_set(x_137, 5, x_130); -if (lean_is_scalar(x_32)) { - x_138 = lean_alloc_ctor(1, 2, 0); -} else { - x_138 = x_32; - lean_ctor_set_tag(x_138, 1); -} -lean_ctor_set(x_138, 0, x_125); -lean_ctor_set(x_138, 1, x_137); -return x_138; -} -else -{ -lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_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; -x_139 = lean_ctor_get(x_123, 2); -lean_inc(x_139); -x_140 = lean_ctor_get(x_122, 0); -lean_inc(x_140); -lean_dec(x_122); -x_141 = lean_ctor_get(x_123, 0); -lean_inc(x_141); -x_142 = lean_ctor_get(x_123, 1); -lean_inc(x_142); -x_143 = lean_ctor_get(x_123, 3); -lean_inc(x_143); -x_144 = lean_ctor_get(x_123, 4); -lean_inc(x_144); -x_145 = lean_ctor_get(x_123, 5); -lean_inc(x_145); -if (lean_is_exclusive(x_123)) { - lean_ctor_release(x_123, 0); - lean_ctor_release(x_123, 1); - lean_ctor_release(x_123, 2); - lean_ctor_release(x_123, 3); - lean_ctor_release(x_123, 4); - lean_ctor_release(x_123, 5); - x_146 = x_123; -} else { - lean_dec_ref(x_123); - x_146 = lean_box(0); -} -x_147 = lean_ctor_get(x_139, 0); -lean_inc(x_147); -x_148 = lean_ctor_get(x_139, 1); -lean_inc(x_148); -x_149 = lean_ctor_get(x_139, 3); -lean_inc(x_149); -if (lean_is_exclusive(x_139)) { - lean_ctor_release(x_139, 0); - lean_ctor_release(x_139, 1); - lean_ctor_release(x_139, 2); - lean_ctor_release(x_139, 3); - x_150 = x_139; -} else { - lean_dec_ref(x_139); - x_150 = lean_box(0); -} -if (lean_is_scalar(x_150)) { - x_151 = lean_alloc_ctor(0, 4, 0); -} else { - x_151 = x_150; -} -lean_ctor_set(x_151, 0, x_147); -lean_ctor_set(x_151, 1, x_148); -lean_ctor_set(x_151, 2, x_120); -lean_ctor_set(x_151, 3, x_149); -if (lean_is_scalar(x_146)) { - x_152 = lean_alloc_ctor(0, 6, 0); -} else { - x_152 = x_146; -} -lean_ctor_set(x_152, 0, x_141); -lean_ctor_set(x_152, 1, x_142); -lean_ctor_set(x_152, 2, x_151); -lean_ctor_set(x_152, 3, x_143); -lean_ctor_set(x_152, 4, x_144); -lean_ctor_set(x_152, 5, x_145); -if (lean_is_scalar(x_32)) { - x_153 = lean_alloc_ctor(0, 2, 0); -} else { - x_153 = x_32; -} -lean_ctor_set(x_153, 0, x_140); -lean_ctor_set(x_153, 1, x_152); -return x_153; -} -} -} -} -else -{ -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; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; lean_object* x_224; lean_object* x_225; lean_object* x_226; lean_object* x_227; lean_object* x_228; lean_object* x_229; -x_173 = lean_ctor_get(x_31, 2); -x_174 = lean_ctor_get(x_31, 0); -x_175 = lean_ctor_get(x_31, 1); -x_176 = lean_ctor_get(x_31, 3); -x_177 = lean_ctor_get(x_31, 4); -x_178 = lean_ctor_get(x_31, 5); -lean_inc(x_178); -lean_inc(x_177); -lean_inc(x_176); -lean_inc(x_173); -lean_inc(x_175); -lean_inc(x_174); -lean_dec(x_31); -x_179 = lean_ctor_get(x_173, 0); -lean_inc(x_179); -x_180 = lean_ctor_get(x_173, 1); -lean_inc(x_180); -x_181 = lean_ctor_get(x_173, 2); -lean_inc(x_181); -x_182 = lean_ctor_get(x_173, 3); -lean_inc(x_182); -if (lean_is_exclusive(x_173)) { - lean_ctor_release(x_173, 0); - lean_ctor_release(x_173, 1); - lean_ctor_release(x_173, 2); - lean_ctor_release(x_173, 3); - x_183 = x_173; -} else { - lean_dec_ref(x_173); - x_183 = lean_box(0); -} -x_217 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_183)) { - x_218 = lean_alloc_ctor(0, 4, 0); -} else { - x_218 = x_183; -} -lean_ctor_set(x_218, 0, x_179); -lean_ctor_set(x_218, 1, x_180); -lean_ctor_set(x_218, 2, x_217); -lean_ctor_set(x_218, 3, x_182); -x_219 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_219, 0, x_174); -lean_ctor_set(x_219, 1, x_175); -lean_ctor_set(x_219, 2, x_218); -lean_ctor_set(x_219, 3, x_176); -lean_ctor_set(x_219, 4, x_177); -lean_ctor_set(x_219, 5, x_178); -x_220 = lean_ctor_get(x_12, 0); -lean_inc(x_220); -x_221 = lean_ctor_get(x_12, 1); -lean_inc(x_221); -x_222 = lean_ctor_get(x_12, 2); -lean_inc(x_222); -x_223 = lean_ctor_get(x_12, 3); -lean_inc(x_223); -x_224 = lean_ctor_get(x_12, 4); -lean_inc(x_224); +lean_inc(x_125); +lean_inc(x_124); +lean_inc(x_123); +lean_inc(x_122); +lean_dec(x_37); +x_162 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_163 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_163, 0, x_122); +lean_ctor_set(x_163, 1, x_123); +lean_ctor_set(x_163, 2, x_162); +lean_ctor_set(x_163, 3, x_125); +lean_ctor_set(x_163, 4, x_126); +lean_ctor_set(x_31, 2, x_163); +x_164 = lean_ctor_get(x_12, 0); +lean_inc(x_164); +x_165 = lean_ctor_get(x_12, 1); +lean_inc(x_165); +x_166 = lean_ctor_get(x_12, 2); +lean_inc(x_166); +x_167 = lean_ctor_get(x_12, 3); +lean_inc(x_167); +x_168 = lean_ctor_get(x_12, 4); +lean_inc(x_168); if (lean_is_exclusive(x_12)) { lean_ctor_release(x_12, 0); lean_ctor_release(x_12, 1); lean_ctor_release(x_12, 2); lean_ctor_release(x_12, 3); lean_ctor_release(x_12, 4); - x_225 = x_12; + x_169 = x_12; } else { lean_dec_ref(x_12); - x_225 = lean_box(0); + x_169 = lean_box(0); } -x_226 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_226, 0, x_33); -lean_ctor_set(x_226, 1, x_20); -x_227 = lean_array_push(x_222, x_226); -if (lean_is_scalar(x_225)) { +x_170 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_170, 0, x_33); +lean_ctor_set(x_170, 1, x_20); +x_171 = lean_array_push(x_166, x_170); +if (lean_is_scalar(x_169)) { + x_172 = lean_alloc_ctor(0, 5, 0); +} else { + x_172 = x_169; +} +lean_ctor_set(x_172, 0, x_164); +lean_ctor_set(x_172, 1, x_165); +lean_ctor_set(x_172, 2, x_171); +lean_ctor_set(x_172, 3, x_167); +lean_ctor_set(x_172, 4, x_168); +x_173 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_35, x_172, x_31); +if (lean_obj_tag(x_173) == 0) +{ +lean_object* x_174; lean_object* x_175; lean_object* x_176; +x_174 = lean_ctor_get(x_173, 0); +lean_inc(x_174); +x_175 = lean_ctor_get(x_173, 1); +lean_inc(x_175); +lean_dec(x_173); +x_176 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_176, 0, x_174); +x_127 = x_176; +x_128 = x_175; +goto block_161; +} +else +{ +lean_object* x_177; lean_object* x_178; lean_object* x_179; +x_177 = lean_ctor_get(x_173, 0); +lean_inc(x_177); +x_178 = lean_ctor_get(x_173, 1); +lean_inc(x_178); +lean_dec(x_173); +x_179 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_179, 0, x_177); +x_127 = x_179; +x_128 = x_178; +goto block_161; +} +block_161: +{ +if (lean_obj_tag(x_127) == 0) +{ +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; +x_129 = lean_ctor_get(x_128, 2); +lean_inc(x_129); +x_130 = lean_ctor_get(x_127, 0); +lean_inc(x_130); +lean_dec(x_127); +x_131 = lean_ctor_get(x_128, 0); +lean_inc(x_131); +x_132 = lean_ctor_get(x_128, 1); +lean_inc(x_132); +x_133 = lean_ctor_get(x_128, 3); +lean_inc(x_133); +x_134 = lean_ctor_get(x_128, 4); +lean_inc(x_134); +x_135 = lean_ctor_get(x_128, 5); +lean_inc(x_135); +if (lean_is_exclusive(x_128)) { + lean_ctor_release(x_128, 0); + lean_ctor_release(x_128, 1); + lean_ctor_release(x_128, 2); + lean_ctor_release(x_128, 3); + lean_ctor_release(x_128, 4); + lean_ctor_release(x_128, 5); + x_136 = x_128; +} else { + lean_dec_ref(x_128); + x_136 = lean_box(0); +} +x_137 = lean_ctor_get(x_129, 0); +lean_inc(x_137); +x_138 = lean_ctor_get(x_129, 1); +lean_inc(x_138); +x_139 = lean_ctor_get(x_129, 3); +lean_inc(x_139); +x_140 = lean_ctor_get(x_129, 4); +lean_inc(x_140); +if (lean_is_exclusive(x_129)) { + lean_ctor_release(x_129, 0); + lean_ctor_release(x_129, 1); + lean_ctor_release(x_129, 2); + lean_ctor_release(x_129, 3); + lean_ctor_release(x_129, 4); + x_141 = x_129; +} else { + lean_dec_ref(x_129); + x_141 = lean_box(0); +} +if (lean_is_scalar(x_141)) { + x_142 = lean_alloc_ctor(0, 5, 0); +} else { + x_142 = x_141; +} +lean_ctor_set(x_142, 0, x_137); +lean_ctor_set(x_142, 1, x_138); +lean_ctor_set(x_142, 2, x_124); +lean_ctor_set(x_142, 3, x_139); +lean_ctor_set(x_142, 4, x_140); +if (lean_is_scalar(x_136)) { + x_143 = lean_alloc_ctor(0, 6, 0); +} else { + x_143 = x_136; +} +lean_ctor_set(x_143, 0, x_131); +lean_ctor_set(x_143, 1, x_132); +lean_ctor_set(x_143, 2, x_142); +lean_ctor_set(x_143, 3, x_133); +lean_ctor_set(x_143, 4, x_134); +lean_ctor_set(x_143, 5, x_135); +if (lean_is_scalar(x_32)) { + x_144 = lean_alloc_ctor(1, 2, 0); +} else { + x_144 = x_32; + lean_ctor_set_tag(x_144, 1); +} +lean_ctor_set(x_144, 0, x_130); +lean_ctor_set(x_144, 1, x_143); +return x_144; +} +else +{ +lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_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; +x_145 = lean_ctor_get(x_128, 2); +lean_inc(x_145); +x_146 = lean_ctor_get(x_127, 0); +lean_inc(x_146); +lean_dec(x_127); +x_147 = lean_ctor_get(x_128, 0); +lean_inc(x_147); +x_148 = lean_ctor_get(x_128, 1); +lean_inc(x_148); +x_149 = lean_ctor_get(x_128, 3); +lean_inc(x_149); +x_150 = lean_ctor_get(x_128, 4); +lean_inc(x_150); +x_151 = lean_ctor_get(x_128, 5); +lean_inc(x_151); +if (lean_is_exclusive(x_128)) { + lean_ctor_release(x_128, 0); + lean_ctor_release(x_128, 1); + lean_ctor_release(x_128, 2); + lean_ctor_release(x_128, 3); + lean_ctor_release(x_128, 4); + lean_ctor_release(x_128, 5); + x_152 = x_128; +} else { + lean_dec_ref(x_128); + x_152 = lean_box(0); +} +x_153 = lean_ctor_get(x_145, 0); +lean_inc(x_153); +x_154 = lean_ctor_get(x_145, 1); +lean_inc(x_154); +x_155 = lean_ctor_get(x_145, 3); +lean_inc(x_155); +x_156 = lean_ctor_get(x_145, 4); +lean_inc(x_156); +if (lean_is_exclusive(x_145)) { + lean_ctor_release(x_145, 0); + lean_ctor_release(x_145, 1); + lean_ctor_release(x_145, 2); + lean_ctor_release(x_145, 3); + lean_ctor_release(x_145, 4); + x_157 = x_145; +} else { + lean_dec_ref(x_145); + x_157 = lean_box(0); +} +if (lean_is_scalar(x_157)) { + x_158 = lean_alloc_ctor(0, 5, 0); +} else { + x_158 = x_157; +} +lean_ctor_set(x_158, 0, x_153); +lean_ctor_set(x_158, 1, x_154); +lean_ctor_set(x_158, 2, x_124); +lean_ctor_set(x_158, 3, x_155); +lean_ctor_set(x_158, 4, x_156); +if (lean_is_scalar(x_152)) { + x_159 = lean_alloc_ctor(0, 6, 0); +} else { + x_159 = x_152; +} +lean_ctor_set(x_159, 0, x_147); +lean_ctor_set(x_159, 1, x_148); +lean_ctor_set(x_159, 2, x_158); +lean_ctor_set(x_159, 3, x_149); +lean_ctor_set(x_159, 4, x_150); +lean_ctor_set(x_159, 5, x_151); +if (lean_is_scalar(x_32)) { + x_160 = lean_alloc_ctor(0, 2, 0); +} else { + x_160 = x_32; +} +lean_ctor_set(x_160, 0, x_146); +lean_ctor_set(x_160, 1, x_159); +return x_160; +} +} +} +} +else +{ +lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; 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_227; lean_object* x_228; lean_object* x_229; lean_object* x_230; lean_object* x_231; lean_object* x_232; lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_object* x_236; lean_object* x_237; lean_object* x_238; lean_object* x_239; +x_180 = lean_ctor_get(x_31, 2); +x_181 = lean_ctor_get(x_31, 0); +x_182 = lean_ctor_get(x_31, 1); +x_183 = lean_ctor_get(x_31, 3); +x_184 = lean_ctor_get(x_31, 4); +x_185 = lean_ctor_get(x_31, 5); +lean_inc(x_185); +lean_inc(x_184); +lean_inc(x_183); +lean_inc(x_180); +lean_inc(x_182); +lean_inc(x_181); +lean_dec(x_31); +x_186 = lean_ctor_get(x_180, 0); +lean_inc(x_186); +x_187 = lean_ctor_get(x_180, 1); +lean_inc(x_187); +x_188 = lean_ctor_get(x_180, 2); +lean_inc(x_188); +x_189 = lean_ctor_get(x_180, 3); +lean_inc(x_189); +x_190 = lean_ctor_get(x_180, 4); +lean_inc(x_190); +if (lean_is_exclusive(x_180)) { + lean_ctor_release(x_180, 0); + lean_ctor_release(x_180, 1); + lean_ctor_release(x_180, 2); + lean_ctor_release(x_180, 3); + lean_ctor_release(x_180, 4); + x_191 = x_180; +} else { + lean_dec_ref(x_180); + x_191 = lean_box(0); +} +x_227 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_191)) { x_228 = lean_alloc_ctor(0, 5, 0); } else { - x_228 = x_225; + x_228 = x_191; } -lean_ctor_set(x_228, 0, x_220); -lean_ctor_set(x_228, 1, x_221); +lean_ctor_set(x_228, 0, x_186); +lean_ctor_set(x_228, 1, x_187); lean_ctor_set(x_228, 2, x_227); -lean_ctor_set(x_228, 3, x_223); -lean_ctor_set(x_228, 4, x_224); -x_229 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_35, x_228, x_219); -if (lean_obj_tag(x_229) == 0) -{ -lean_object* x_230; lean_object* x_231; lean_object* x_232; -x_230 = lean_ctor_get(x_229, 0); +lean_ctor_set(x_228, 3, x_189); +lean_ctor_set(x_228, 4, x_190); +x_229 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_229, 0, x_181); +lean_ctor_set(x_229, 1, x_182); +lean_ctor_set(x_229, 2, x_228); +lean_ctor_set(x_229, 3, x_183); +lean_ctor_set(x_229, 4, x_184); +lean_ctor_set(x_229, 5, x_185); +x_230 = lean_ctor_get(x_12, 0); lean_inc(x_230); -x_231 = lean_ctor_get(x_229, 1); +x_231 = lean_ctor_get(x_12, 1); lean_inc(x_231); -lean_dec(x_229); -x_232 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_232, 0, x_230); -x_184 = x_232; -x_185 = x_231; -goto block_216; -} -else -{ -lean_object* x_233; lean_object* x_234; lean_object* x_235; -x_233 = lean_ctor_get(x_229, 0); +x_232 = lean_ctor_get(x_12, 2); +lean_inc(x_232); +x_233 = lean_ctor_get(x_12, 3); lean_inc(x_233); -x_234 = lean_ctor_get(x_229, 1); +x_234 = lean_ctor_get(x_12, 4); lean_inc(x_234); -lean_dec(x_229); -x_235 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_235, 0, x_233); -x_184 = x_235; -x_185 = x_234; -goto block_216; +if (lean_is_exclusive(x_12)) { + lean_ctor_release(x_12, 0); + lean_ctor_release(x_12, 1); + lean_ctor_release(x_12, 2); + lean_ctor_release(x_12, 3); + lean_ctor_release(x_12, 4); + x_235 = x_12; +} else { + lean_dec_ref(x_12); + x_235 = lean_box(0); } -block_216: +x_236 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_236, 0, x_33); +lean_ctor_set(x_236, 1, x_20); +x_237 = lean_array_push(x_232, x_236); +if (lean_is_scalar(x_235)) { + x_238 = lean_alloc_ctor(0, 5, 0); +} else { + x_238 = x_235; +} +lean_ctor_set(x_238, 0, x_230); +lean_ctor_set(x_238, 1, x_231); +lean_ctor_set(x_238, 2, x_237); +lean_ctor_set(x_238, 3, x_233); +lean_ctor_set(x_238, 4, x_234); +x_239 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_35, x_238, x_229); +if (lean_obj_tag(x_239) == 0) { -if (lean_obj_tag(x_184) == 0) -{ -lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; -x_186 = lean_ctor_get(x_185, 2); -lean_inc(x_186); -x_187 = lean_ctor_get(x_184, 0); -lean_inc(x_187); -lean_dec(x_184); -x_188 = lean_ctor_get(x_185, 0); -lean_inc(x_188); -x_189 = lean_ctor_get(x_185, 1); -lean_inc(x_189); -x_190 = lean_ctor_get(x_185, 3); -lean_inc(x_190); -x_191 = lean_ctor_get(x_185, 4); -lean_inc(x_191); -x_192 = lean_ctor_get(x_185, 5); -lean_inc(x_192); -if (lean_is_exclusive(x_185)) { - lean_ctor_release(x_185, 0); - lean_ctor_release(x_185, 1); - lean_ctor_release(x_185, 2); - lean_ctor_release(x_185, 3); - lean_ctor_release(x_185, 4); - lean_ctor_release(x_185, 5); - x_193 = x_185; -} else { - lean_dec_ref(x_185); - x_193 = lean_box(0); -} -x_194 = lean_ctor_get(x_186, 0); -lean_inc(x_194); -x_195 = lean_ctor_get(x_186, 1); -lean_inc(x_195); -x_196 = lean_ctor_get(x_186, 3); -lean_inc(x_196); -if (lean_is_exclusive(x_186)) { - lean_ctor_release(x_186, 0); - lean_ctor_release(x_186, 1); - lean_ctor_release(x_186, 2); - lean_ctor_release(x_186, 3); - x_197 = x_186; -} else { - lean_dec_ref(x_186); - x_197 = lean_box(0); -} -if (lean_is_scalar(x_197)) { - x_198 = lean_alloc_ctor(0, 4, 0); -} else { - x_198 = x_197; -} -lean_ctor_set(x_198, 0, x_194); -lean_ctor_set(x_198, 1, x_195); -lean_ctor_set(x_198, 2, x_181); -lean_ctor_set(x_198, 3, x_196); -if (lean_is_scalar(x_193)) { - x_199 = lean_alloc_ctor(0, 6, 0); -} else { - x_199 = x_193; -} -lean_ctor_set(x_199, 0, x_188); -lean_ctor_set(x_199, 1, x_189); -lean_ctor_set(x_199, 2, x_198); -lean_ctor_set(x_199, 3, x_190); -lean_ctor_set(x_199, 4, x_191); -lean_ctor_set(x_199, 5, x_192); -if (lean_is_scalar(x_32)) { - x_200 = lean_alloc_ctor(1, 2, 0); -} else { - x_200 = x_32; - lean_ctor_set_tag(x_200, 1); -} -lean_ctor_set(x_200, 0, x_187); -lean_ctor_set(x_200, 1, x_199); -return x_200; +lean_object* x_240; lean_object* x_241; lean_object* x_242; +x_240 = lean_ctor_get(x_239, 0); +lean_inc(x_240); +x_241 = lean_ctor_get(x_239, 1); +lean_inc(x_241); +lean_dec(x_239); +x_242 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_242, 0, x_240); +x_192 = x_242; +x_193 = x_241; +goto block_226; } else { -lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; -x_201 = lean_ctor_get(x_185, 2); -lean_inc(x_201); -x_202 = lean_ctor_get(x_184, 0); +lean_object* x_243; lean_object* x_244; lean_object* x_245; +x_243 = lean_ctor_get(x_239, 0); +lean_inc(x_243); +x_244 = lean_ctor_get(x_239, 1); +lean_inc(x_244); +lean_dec(x_239); +x_245 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_245, 0, x_243); +x_192 = x_245; +x_193 = x_244; +goto block_226; +} +block_226: +{ +if (lean_obj_tag(x_192) == 0) +{ +lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; +x_194 = lean_ctor_get(x_193, 2); +lean_inc(x_194); +x_195 = lean_ctor_get(x_192, 0); +lean_inc(x_195); +lean_dec(x_192); +x_196 = lean_ctor_get(x_193, 0); +lean_inc(x_196); +x_197 = lean_ctor_get(x_193, 1); +lean_inc(x_197); +x_198 = lean_ctor_get(x_193, 3); +lean_inc(x_198); +x_199 = lean_ctor_get(x_193, 4); +lean_inc(x_199); +x_200 = lean_ctor_get(x_193, 5); +lean_inc(x_200); +if (lean_is_exclusive(x_193)) { + lean_ctor_release(x_193, 0); + lean_ctor_release(x_193, 1); + lean_ctor_release(x_193, 2); + lean_ctor_release(x_193, 3); + lean_ctor_release(x_193, 4); + lean_ctor_release(x_193, 5); + x_201 = x_193; +} else { + lean_dec_ref(x_193); + x_201 = lean_box(0); +} +x_202 = lean_ctor_get(x_194, 0); lean_inc(x_202); -lean_dec(x_184); -x_203 = lean_ctor_get(x_185, 0); +x_203 = lean_ctor_get(x_194, 1); lean_inc(x_203); -x_204 = lean_ctor_get(x_185, 1); +x_204 = lean_ctor_get(x_194, 3); lean_inc(x_204); -x_205 = lean_ctor_get(x_185, 3); +x_205 = lean_ctor_get(x_194, 4); lean_inc(x_205); -x_206 = lean_ctor_get(x_185, 4); -lean_inc(x_206); -x_207 = lean_ctor_get(x_185, 5); -lean_inc(x_207); -if (lean_is_exclusive(x_185)) { - lean_ctor_release(x_185, 0); - lean_ctor_release(x_185, 1); - lean_ctor_release(x_185, 2); - lean_ctor_release(x_185, 3); - lean_ctor_release(x_185, 4); - lean_ctor_release(x_185, 5); - x_208 = x_185; +if (lean_is_exclusive(x_194)) { + lean_ctor_release(x_194, 0); + lean_ctor_release(x_194, 1); + lean_ctor_release(x_194, 2); + lean_ctor_release(x_194, 3); + lean_ctor_release(x_194, 4); + x_206 = x_194; } else { - lean_dec_ref(x_185); - x_208 = lean_box(0); + lean_dec_ref(x_194); + x_206 = lean_box(0); } -x_209 = lean_ctor_get(x_201, 0); -lean_inc(x_209); -x_210 = lean_ctor_get(x_201, 1); -lean_inc(x_210); -x_211 = lean_ctor_get(x_201, 3); -lean_inc(x_211); -if (lean_is_exclusive(x_201)) { - lean_ctor_release(x_201, 0); - lean_ctor_release(x_201, 1); - lean_ctor_release(x_201, 2); - lean_ctor_release(x_201, 3); - x_212 = x_201; +if (lean_is_scalar(x_206)) { + x_207 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_201); - x_212 = lean_box(0); + x_207 = x_206; } -if (lean_is_scalar(x_212)) { - x_213 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_207, 0, x_202); +lean_ctor_set(x_207, 1, x_203); +lean_ctor_set(x_207, 2, x_188); +lean_ctor_set(x_207, 3, x_204); +lean_ctor_set(x_207, 4, x_205); +if (lean_is_scalar(x_201)) { + x_208 = lean_alloc_ctor(0, 6, 0); } else { - x_213 = x_212; + x_208 = x_201; } -lean_ctor_set(x_213, 0, x_209); -lean_ctor_set(x_213, 1, x_210); -lean_ctor_set(x_213, 2, x_181); -lean_ctor_set(x_213, 3, x_211); -if (lean_is_scalar(x_208)) { - x_214 = lean_alloc_ctor(0, 6, 0); -} else { - x_214 = x_208; -} -lean_ctor_set(x_214, 0, x_203); -lean_ctor_set(x_214, 1, x_204); -lean_ctor_set(x_214, 2, x_213); -lean_ctor_set(x_214, 3, x_205); -lean_ctor_set(x_214, 4, x_206); -lean_ctor_set(x_214, 5, x_207); +lean_ctor_set(x_208, 0, x_196); +lean_ctor_set(x_208, 1, x_197); +lean_ctor_set(x_208, 2, x_207); +lean_ctor_set(x_208, 3, x_198); +lean_ctor_set(x_208, 4, x_199); +lean_ctor_set(x_208, 5, x_200); if (lean_is_scalar(x_32)) { - x_215 = lean_alloc_ctor(0, 2, 0); + x_209 = lean_alloc_ctor(1, 2, 0); } else { - x_215 = x_32; + x_209 = x_32; + lean_ctor_set_tag(x_209, 1); } -lean_ctor_set(x_215, 0, x_202); -lean_ctor_set(x_215, 1, x_214); -return x_215; +lean_ctor_set(x_209, 0, x_195); +lean_ctor_set(x_209, 1, x_208); +return x_209; +} +else +{ +lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; lean_object* x_224; lean_object* x_225; +x_210 = lean_ctor_get(x_193, 2); +lean_inc(x_210); +x_211 = lean_ctor_get(x_192, 0); +lean_inc(x_211); +lean_dec(x_192); +x_212 = lean_ctor_get(x_193, 0); +lean_inc(x_212); +x_213 = lean_ctor_get(x_193, 1); +lean_inc(x_213); +x_214 = lean_ctor_get(x_193, 3); +lean_inc(x_214); +x_215 = lean_ctor_get(x_193, 4); +lean_inc(x_215); +x_216 = lean_ctor_get(x_193, 5); +lean_inc(x_216); +if (lean_is_exclusive(x_193)) { + lean_ctor_release(x_193, 0); + lean_ctor_release(x_193, 1); + lean_ctor_release(x_193, 2); + lean_ctor_release(x_193, 3); + lean_ctor_release(x_193, 4); + lean_ctor_release(x_193, 5); + x_217 = x_193; +} else { + lean_dec_ref(x_193); + x_217 = lean_box(0); +} +x_218 = lean_ctor_get(x_210, 0); +lean_inc(x_218); +x_219 = lean_ctor_get(x_210, 1); +lean_inc(x_219); +x_220 = lean_ctor_get(x_210, 3); +lean_inc(x_220); +x_221 = lean_ctor_get(x_210, 4); +lean_inc(x_221); +if (lean_is_exclusive(x_210)) { + lean_ctor_release(x_210, 0); + lean_ctor_release(x_210, 1); + lean_ctor_release(x_210, 2); + lean_ctor_release(x_210, 3); + lean_ctor_release(x_210, 4); + x_222 = x_210; +} else { + lean_dec_ref(x_210); + x_222 = lean_box(0); +} +if (lean_is_scalar(x_222)) { + x_223 = lean_alloc_ctor(0, 5, 0); +} else { + x_223 = x_222; +} +lean_ctor_set(x_223, 0, x_218); +lean_ctor_set(x_223, 1, x_219); +lean_ctor_set(x_223, 2, x_188); +lean_ctor_set(x_223, 3, x_220); +lean_ctor_set(x_223, 4, x_221); +if (lean_is_scalar(x_217)) { + x_224 = lean_alloc_ctor(0, 6, 0); +} else { + x_224 = x_217; +} +lean_ctor_set(x_224, 0, x_212); +lean_ctor_set(x_224, 1, x_213); +lean_ctor_set(x_224, 2, x_223); +lean_ctor_set(x_224, 3, x_214); +lean_ctor_set(x_224, 4, x_215); +lean_ctor_set(x_224, 5, x_216); +if (lean_is_scalar(x_32)) { + x_225 = lean_alloc_ctor(0, 2, 0); +} else { + x_225 = x_32; +} +lean_ctor_set(x_225, 0, x_211); +lean_ctor_set(x_225, 1, x_224); +return x_225; } } } } default: { -lean_object* x_236; lean_object* x_237; -x_236 = lean_ctor_get(x_25, 1); -lean_inc(x_236); +lean_object* x_246; lean_object* x_247; +x_246 = lean_ctor_get(x_25, 1); +lean_inc(x_246); lean_dec(x_25); lean_inc(x_12); -x_237 = l_Lean_Meta_isClassExpensive___main(x_24, x_12, x_236); -if (lean_obj_tag(x_237) == 0) +x_247 = l_Lean_Meta_isClassExpensive___main(x_24, x_12, x_246); +if (lean_obj_tag(x_247) == 0) { -lean_object* x_238; -x_238 = lean_ctor_get(x_237, 0); -lean_inc(x_238); -if (lean_obj_tag(x_238) == 0) +lean_object* x_248; +x_248 = lean_ctor_get(x_247, 0); +lean_inc(x_248); +if (lean_obj_tag(x_248) == 0) { -lean_object* x_239; lean_object* x_240; lean_object* x_241; +lean_object* x_249; lean_object* x_250; lean_object* x_251; lean_dec(x_20); -x_239 = lean_ctor_get(x_237, 1); -lean_inc(x_239); -lean_dec(x_237); -x_240 = lean_unsigned_to_nat(1u); -x_241 = lean_nat_add(x_11, x_240); +x_249 = lean_ctor_get(x_247, 1); +lean_inc(x_249); +lean_dec(x_247); +x_250 = lean_unsigned_to_nat(1u); +x_251 = lean_nat_add(x_11, x_250); lean_dec(x_11); -x_11 = x_241; -x_13 = x_239; +x_11 = x_251; +x_13 = x_249; goto _start; } else { -lean_object* x_243; lean_object* x_244; lean_object* x_245; lean_object* x_246; lean_object* x_247; uint8_t x_248; -x_243 = lean_ctor_get(x_237, 1); -lean_inc(x_243); -if (lean_is_exclusive(x_237)) { - lean_ctor_release(x_237, 0); - lean_ctor_release(x_237, 1); - x_244 = x_237; +lean_object* x_253; lean_object* x_254; lean_object* x_255; lean_object* x_256; lean_object* x_257; uint8_t x_258; +x_253 = lean_ctor_get(x_247, 1); +lean_inc(x_253); +if (lean_is_exclusive(x_247)) { + lean_ctor_release(x_247, 0); + lean_ctor_release(x_247, 1); + x_254 = x_247; } else { - lean_dec_ref(x_237); - x_244 = lean_box(0); + lean_dec_ref(x_247); + x_254 = lean_box(0); } -x_245 = lean_ctor_get(x_238, 0); -lean_inc(x_245); -lean_dec(x_238); -x_246 = lean_unsigned_to_nat(1u); -x_247 = lean_nat_add(x_11, x_246); -lean_dec(x_11); -x_248 = !lean_is_exclusive(x_243); -if (x_248 == 0) -{ -lean_object* x_249; uint8_t x_250; -x_249 = lean_ctor_get(x_243, 2); -x_250 = !lean_is_exclusive(x_249); -if (x_250 == 0) -{ -lean_object* x_251; lean_object* x_252; lean_object* x_253; lean_object* x_303; uint8_t x_304; -x_251 = lean_ctor_get(x_249, 2); -x_303 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_249, 2, x_303); -x_304 = !lean_is_exclusive(x_12); -if (x_304 == 0) -{ -lean_object* x_305; lean_object* x_306; lean_object* x_307; lean_object* x_308; -x_305 = lean_ctor_get(x_12, 2); -x_306 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_306, 0, x_245); -lean_ctor_set(x_306, 1, x_20); -x_307 = lean_array_push(x_305, x_306); -lean_ctor_set(x_12, 2, x_307); -x_308 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_247, x_12, x_243); -if (lean_obj_tag(x_308) == 0) -{ -lean_object* x_309; lean_object* x_310; lean_object* x_311; -x_309 = lean_ctor_get(x_308, 0); -lean_inc(x_309); -x_310 = lean_ctor_get(x_308, 1); -lean_inc(x_310); -lean_dec(x_308); -x_311 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_311, 0, x_309); -x_252 = x_311; -x_253 = x_310; -goto block_302; -} -else -{ -lean_object* x_312; lean_object* x_313; lean_object* x_314; -x_312 = lean_ctor_get(x_308, 0); -lean_inc(x_312); -x_313 = lean_ctor_get(x_308, 1); -lean_inc(x_313); -lean_dec(x_308); -x_314 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_314, 0, x_312); -x_252 = x_314; -x_253 = x_313; -goto block_302; -} -} -else -{ -lean_object* x_315; lean_object* x_316; lean_object* x_317; lean_object* x_318; lean_object* x_319; lean_object* x_320; lean_object* x_321; lean_object* x_322; lean_object* x_323; -x_315 = lean_ctor_get(x_12, 0); -x_316 = lean_ctor_get(x_12, 1); -x_317 = lean_ctor_get(x_12, 2); -x_318 = lean_ctor_get(x_12, 3); -x_319 = lean_ctor_get(x_12, 4); -lean_inc(x_319); -lean_inc(x_318); -lean_inc(x_317); -lean_inc(x_316); -lean_inc(x_315); -lean_dec(x_12); -x_320 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_320, 0, x_245); -lean_ctor_set(x_320, 1, x_20); -x_321 = lean_array_push(x_317, x_320); -x_322 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_322, 0, x_315); -lean_ctor_set(x_322, 1, x_316); -lean_ctor_set(x_322, 2, x_321); -lean_ctor_set(x_322, 3, x_318); -lean_ctor_set(x_322, 4, x_319); -x_323 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_247, x_322, x_243); -if (lean_obj_tag(x_323) == 0) -{ -lean_object* x_324; lean_object* x_325; lean_object* x_326; -x_324 = lean_ctor_get(x_323, 0); -lean_inc(x_324); -x_325 = lean_ctor_get(x_323, 1); -lean_inc(x_325); -lean_dec(x_323); -x_326 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_326, 0, x_324); -x_252 = x_326; -x_253 = x_325; -goto block_302; -} -else -{ -lean_object* x_327; lean_object* x_328; lean_object* x_329; -x_327 = lean_ctor_get(x_323, 0); -lean_inc(x_327); -x_328 = lean_ctor_get(x_323, 1); -lean_inc(x_328); -lean_dec(x_323); -x_329 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_329, 0, x_327); -x_252 = x_329; -x_253 = x_328; -goto block_302; -} -} -block_302: -{ -if (lean_obj_tag(x_252) == 0) -{ -lean_object* x_254; lean_object* x_255; uint8_t x_256; -x_254 = lean_ctor_get(x_253, 2); -lean_inc(x_254); -x_255 = lean_ctor_get(x_252, 0); +x_255 = lean_ctor_get(x_248, 0); lean_inc(x_255); -lean_dec(x_252); -x_256 = !lean_is_exclusive(x_253); -if (x_256 == 0) -{ -lean_object* x_257; uint8_t x_258; -x_257 = lean_ctor_get(x_253, 2); -lean_dec(x_257); -x_258 = !lean_is_exclusive(x_254); +lean_dec(x_248); +x_256 = lean_unsigned_to_nat(1u); +x_257 = lean_nat_add(x_11, x_256); +lean_dec(x_11); +x_258 = !lean_is_exclusive(x_253); if (x_258 == 0) { -lean_object* x_259; lean_object* x_260; -x_259 = lean_ctor_get(x_254, 2); -lean_dec(x_259); -lean_ctor_set(x_254, 2, x_251); -if (lean_is_scalar(x_244)) { - x_260 = lean_alloc_ctor(1, 2, 0); -} else { - x_260 = x_244; - lean_ctor_set_tag(x_260, 1); -} -lean_ctor_set(x_260, 0, x_255); -lean_ctor_set(x_260, 1, x_253); -return x_260; +lean_object* x_259; uint8_t x_260; +x_259 = lean_ctor_get(x_253, 2); +x_260 = !lean_is_exclusive(x_259); +if (x_260 == 0) +{ +lean_object* x_261; lean_object* x_262; lean_object* x_263; lean_object* x_317; uint8_t x_318; +x_261 = lean_ctor_get(x_259, 2); +x_317 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_259, 2, x_317); +x_318 = !lean_is_exclusive(x_12); +if (x_318 == 0) +{ +lean_object* x_319; lean_object* x_320; lean_object* x_321; lean_object* x_322; +x_319 = lean_ctor_get(x_12, 2); +x_320 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_320, 0, x_255); +lean_ctor_set(x_320, 1, x_20); +x_321 = lean_array_push(x_319, x_320); +lean_ctor_set(x_12, 2, x_321); +x_322 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_257, x_12, x_253); +if (lean_obj_tag(x_322) == 0) +{ +lean_object* x_323; lean_object* x_324; lean_object* x_325; +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_alloc_ctor(1, 1, 0); +lean_ctor_set(x_325, 0, x_323); +x_262 = x_325; +x_263 = x_324; +goto block_316; } else { -lean_object* x_261; lean_object* x_262; lean_object* x_263; lean_object* x_264; lean_object* x_265; -x_261 = lean_ctor_get(x_254, 0); -x_262 = lean_ctor_get(x_254, 1); -x_263 = lean_ctor_get(x_254, 3); -lean_inc(x_263); -lean_inc(x_262); -lean_inc(x_261); -lean_dec(x_254); -x_264 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_264, 0, x_261); -lean_ctor_set(x_264, 1, x_262); -lean_ctor_set(x_264, 2, x_251); -lean_ctor_set(x_264, 3, x_263); -lean_ctor_set(x_253, 2, x_264); -if (lean_is_scalar(x_244)) { - x_265 = lean_alloc_ctor(1, 2, 0); -} else { - x_265 = x_244; - lean_ctor_set_tag(x_265, 1); -} -lean_ctor_set(x_265, 0, x_255); -lean_ctor_set(x_265, 1, x_253); -return x_265; +lean_object* x_326; lean_object* x_327; lean_object* x_328; +x_326 = lean_ctor_get(x_322, 0); +lean_inc(x_326); +x_327 = lean_ctor_get(x_322, 1); +lean_inc(x_327); +lean_dec(x_322); +x_328 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_328, 0, x_326); +x_262 = x_328; +x_263 = x_327; +goto block_316; } } else { -lean_object* x_266; lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_object* x_270; lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_object* x_276; lean_object* x_277; -x_266 = lean_ctor_get(x_253, 0); -x_267 = lean_ctor_get(x_253, 1); -x_268 = lean_ctor_get(x_253, 3); -x_269 = lean_ctor_get(x_253, 4); -x_270 = lean_ctor_get(x_253, 5); -lean_inc(x_270); -lean_inc(x_269); -lean_inc(x_268); -lean_inc(x_267); -lean_inc(x_266); -lean_dec(x_253); -x_271 = lean_ctor_get(x_254, 0); -lean_inc(x_271); -x_272 = lean_ctor_get(x_254, 1); -lean_inc(x_272); -x_273 = lean_ctor_get(x_254, 3); +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; +x_329 = lean_ctor_get(x_12, 0); +x_330 = lean_ctor_get(x_12, 1); +x_331 = lean_ctor_get(x_12, 2); +x_332 = lean_ctor_get(x_12, 3); +x_333 = lean_ctor_get(x_12, 4); +lean_inc(x_333); +lean_inc(x_332); +lean_inc(x_331); +lean_inc(x_330); +lean_inc(x_329); +lean_dec(x_12); +x_334 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_334, 0, x_255); +lean_ctor_set(x_334, 1, x_20); +x_335 = lean_array_push(x_331, x_334); +x_336 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_336, 0, x_329); +lean_ctor_set(x_336, 1, x_330); +lean_ctor_set(x_336, 2, x_335); +lean_ctor_set(x_336, 3, x_332); +lean_ctor_set(x_336, 4, x_333); +x_337 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_257, x_336, x_253); +if (lean_obj_tag(x_337) == 0) +{ +lean_object* x_338; lean_object* x_339; lean_object* x_340; +x_338 = lean_ctor_get(x_337, 0); +lean_inc(x_338); +x_339 = lean_ctor_get(x_337, 1); +lean_inc(x_339); +lean_dec(x_337); +x_340 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_340, 0, x_338); +x_262 = x_340; +x_263 = x_339; +goto block_316; +} +else +{ +lean_object* x_341; lean_object* x_342; lean_object* x_343; +x_341 = lean_ctor_get(x_337, 0); +lean_inc(x_341); +x_342 = lean_ctor_get(x_337, 1); +lean_inc(x_342); +lean_dec(x_337); +x_343 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_343, 0, x_341); +x_262 = x_343; +x_263 = x_342; +goto block_316; +} +} +block_316: +{ +if (lean_obj_tag(x_262) == 0) +{ +lean_object* x_264; lean_object* x_265; uint8_t x_266; +x_264 = lean_ctor_get(x_263, 2); +lean_inc(x_264); +x_265 = lean_ctor_get(x_262, 0); +lean_inc(x_265); +lean_dec(x_262); +x_266 = !lean_is_exclusive(x_263); +if (x_266 == 0) +{ +lean_object* x_267; uint8_t x_268; +x_267 = lean_ctor_get(x_263, 2); +lean_dec(x_267); +x_268 = !lean_is_exclusive(x_264); +if (x_268 == 0) +{ +lean_object* x_269; lean_object* x_270; +x_269 = lean_ctor_get(x_264, 2); +lean_dec(x_269); +lean_ctor_set(x_264, 2, x_261); +if (lean_is_scalar(x_254)) { + x_270 = lean_alloc_ctor(1, 2, 0); +} else { + x_270 = x_254; + lean_ctor_set_tag(x_270, 1); +} +lean_ctor_set(x_270, 0, x_265); +lean_ctor_set(x_270, 1, x_263); +return x_270; +} +else +{ +lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_object* x_276; +x_271 = lean_ctor_get(x_264, 0); +x_272 = lean_ctor_get(x_264, 1); +x_273 = lean_ctor_get(x_264, 3); +x_274 = lean_ctor_get(x_264, 4); +lean_inc(x_274); lean_inc(x_273); -if (lean_is_exclusive(x_254)) { - lean_ctor_release(x_254, 0); - lean_ctor_release(x_254, 1); - lean_ctor_release(x_254, 2); - lean_ctor_release(x_254, 3); - x_274 = x_254; -} else { - lean_dec_ref(x_254); - x_274 = lean_box(0); -} -if (lean_is_scalar(x_274)) { - x_275 = lean_alloc_ctor(0, 4, 0); -} else { - x_275 = x_274; -} +lean_inc(x_272); +lean_inc(x_271); +lean_dec(x_264); +x_275 = lean_alloc_ctor(0, 5, 0); lean_ctor_set(x_275, 0, x_271); lean_ctor_set(x_275, 1, x_272); -lean_ctor_set(x_275, 2, x_251); +lean_ctor_set(x_275, 2, x_261); lean_ctor_set(x_275, 3, x_273); -x_276 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_276, 0, x_266); -lean_ctor_set(x_276, 1, x_267); -lean_ctor_set(x_276, 2, x_275); -lean_ctor_set(x_276, 3, x_268); -lean_ctor_set(x_276, 4, x_269); -lean_ctor_set(x_276, 5, x_270); -if (lean_is_scalar(x_244)) { - x_277 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_275, 4, x_274); +lean_ctor_set(x_263, 2, x_275); +if (lean_is_scalar(x_254)) { + x_276 = lean_alloc_ctor(1, 2, 0); } else { - x_277 = x_244; - lean_ctor_set_tag(x_277, 1); + x_276 = x_254; + lean_ctor_set_tag(x_276, 1); } -lean_ctor_set(x_277, 0, x_255); -lean_ctor_set(x_277, 1, x_276); -return x_277; +lean_ctor_set(x_276, 0, x_265); +lean_ctor_set(x_276, 1, x_263); +return x_276; } } else { -lean_object* x_278; lean_object* x_279; uint8_t x_280; -x_278 = lean_ctor_get(x_253, 2); -lean_inc(x_278); -x_279 = lean_ctor_get(x_252, 0); +lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; lean_object* x_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; lean_object* x_289; +x_277 = lean_ctor_get(x_263, 0); +x_278 = lean_ctor_get(x_263, 1); +x_279 = lean_ctor_get(x_263, 3); +x_280 = lean_ctor_get(x_263, 4); +x_281 = lean_ctor_get(x_263, 5); +lean_inc(x_281); +lean_inc(x_280); lean_inc(x_279); -lean_dec(x_252); -x_280 = !lean_is_exclusive(x_253); -if (x_280 == 0) -{ -lean_object* x_281; uint8_t x_282; -x_281 = lean_ctor_get(x_253, 2); -lean_dec(x_281); -x_282 = !lean_is_exclusive(x_278); -if (x_282 == 0) -{ -lean_object* x_283; lean_object* x_284; -x_283 = lean_ctor_get(x_278, 2); -lean_dec(x_283); -lean_ctor_set(x_278, 2, x_251); -if (lean_is_scalar(x_244)) { - x_284 = lean_alloc_ctor(0, 2, 0); -} else { - x_284 = x_244; -} -lean_ctor_set(x_284, 0, x_279); -lean_ctor_set(x_284, 1, x_253); -return x_284; -} -else -{ -lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; lean_object* x_289; -x_285 = lean_ctor_get(x_278, 0); -x_286 = lean_ctor_get(x_278, 1); -x_287 = lean_ctor_get(x_278, 3); -lean_inc(x_287); -lean_inc(x_286); +lean_inc(x_278); +lean_inc(x_277); +lean_dec(x_263); +x_282 = lean_ctor_get(x_264, 0); +lean_inc(x_282); +x_283 = lean_ctor_get(x_264, 1); +lean_inc(x_283); +x_284 = lean_ctor_get(x_264, 3); +lean_inc(x_284); +x_285 = lean_ctor_get(x_264, 4); lean_inc(x_285); -lean_dec(x_278); -x_288 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_288, 0, x_285); -lean_ctor_set(x_288, 1, x_286); -lean_ctor_set(x_288, 2, x_251); -lean_ctor_set(x_288, 3, x_287); -lean_ctor_set(x_253, 2, x_288); -if (lean_is_scalar(x_244)) { - x_289 = lean_alloc_ctor(0, 2, 0); +if (lean_is_exclusive(x_264)) { + lean_ctor_release(x_264, 0); + lean_ctor_release(x_264, 1); + lean_ctor_release(x_264, 2); + lean_ctor_release(x_264, 3); + lean_ctor_release(x_264, 4); + x_286 = x_264; } else { - x_289 = x_244; + lean_dec_ref(x_264); + x_286 = lean_box(0); } -lean_ctor_set(x_289, 0, x_279); -lean_ctor_set(x_289, 1, x_253); +if (lean_is_scalar(x_286)) { + x_287 = lean_alloc_ctor(0, 5, 0); +} else { + x_287 = x_286; +} +lean_ctor_set(x_287, 0, x_282); +lean_ctor_set(x_287, 1, x_283); +lean_ctor_set(x_287, 2, x_261); +lean_ctor_set(x_287, 3, x_284); +lean_ctor_set(x_287, 4, x_285); +x_288 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_288, 0, x_277); +lean_ctor_set(x_288, 1, x_278); +lean_ctor_set(x_288, 2, x_287); +lean_ctor_set(x_288, 3, x_279); +lean_ctor_set(x_288, 4, x_280); +lean_ctor_set(x_288, 5, x_281); +if (lean_is_scalar(x_254)) { + x_289 = lean_alloc_ctor(1, 2, 0); +} else { + x_289 = x_254; + lean_ctor_set_tag(x_289, 1); +} +lean_ctor_set(x_289, 0, x_265); +lean_ctor_set(x_289, 1, x_288); return x_289; } } else { -lean_object* x_290; lean_object* x_291; lean_object* x_292; lean_object* x_293; lean_object* x_294; lean_object* x_295; lean_object* x_296; lean_object* x_297; lean_object* x_298; lean_object* x_299; lean_object* x_300; lean_object* x_301; -x_290 = lean_ctor_get(x_253, 0); -x_291 = lean_ctor_get(x_253, 1); -x_292 = lean_ctor_get(x_253, 3); -x_293 = lean_ctor_get(x_253, 4); -x_294 = lean_ctor_get(x_253, 5); -lean_inc(x_294); -lean_inc(x_293); -lean_inc(x_292); -lean_inc(x_291); +lean_object* x_290; lean_object* x_291; uint8_t x_292; +x_290 = lean_ctor_get(x_263, 2); lean_inc(x_290); -lean_dec(x_253); -x_295 = lean_ctor_get(x_278, 0); -lean_inc(x_295); -x_296 = lean_ctor_get(x_278, 1); -lean_inc(x_296); -x_297 = lean_ctor_get(x_278, 3); +x_291 = lean_ctor_get(x_262, 0); +lean_inc(x_291); +lean_dec(x_262); +x_292 = !lean_is_exclusive(x_263); +if (x_292 == 0) +{ +lean_object* x_293; uint8_t x_294; +x_293 = lean_ctor_get(x_263, 2); +lean_dec(x_293); +x_294 = !lean_is_exclusive(x_290); +if (x_294 == 0) +{ +lean_object* x_295; lean_object* x_296; +x_295 = lean_ctor_get(x_290, 2); +lean_dec(x_295); +lean_ctor_set(x_290, 2, x_261); +if (lean_is_scalar(x_254)) { + x_296 = lean_alloc_ctor(0, 2, 0); +} else { + x_296 = x_254; +} +lean_ctor_set(x_296, 0, x_291); +lean_ctor_set(x_296, 1, x_263); +return x_296; +} +else +{ +lean_object* x_297; lean_object* x_298; lean_object* x_299; lean_object* x_300; lean_object* x_301; lean_object* x_302; +x_297 = lean_ctor_get(x_290, 0); +x_298 = lean_ctor_get(x_290, 1); +x_299 = lean_ctor_get(x_290, 3); +x_300 = lean_ctor_get(x_290, 4); +lean_inc(x_300); +lean_inc(x_299); +lean_inc(x_298); lean_inc(x_297); -if (lean_is_exclusive(x_278)) { - lean_ctor_release(x_278, 0); - lean_ctor_release(x_278, 1); - lean_ctor_release(x_278, 2); - lean_ctor_release(x_278, 3); - x_298 = x_278; +lean_dec(x_290); +x_301 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_301, 0, x_297); +lean_ctor_set(x_301, 1, x_298); +lean_ctor_set(x_301, 2, x_261); +lean_ctor_set(x_301, 3, x_299); +lean_ctor_set(x_301, 4, x_300); +lean_ctor_set(x_263, 2, x_301); +if (lean_is_scalar(x_254)) { + x_302 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_278); - x_298 = lean_box(0); + x_302 = x_254; } -if (lean_is_scalar(x_298)) { - x_299 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_302, 0, x_291); +lean_ctor_set(x_302, 1, x_263); +return x_302; +} +} +else +{ +lean_object* x_303; lean_object* x_304; lean_object* x_305; lean_object* x_306; lean_object* x_307; lean_object* x_308; lean_object* x_309; lean_object* x_310; lean_object* x_311; lean_object* x_312; lean_object* x_313; lean_object* x_314; lean_object* x_315; +x_303 = lean_ctor_get(x_263, 0); +x_304 = lean_ctor_get(x_263, 1); +x_305 = lean_ctor_get(x_263, 3); +x_306 = lean_ctor_get(x_263, 4); +x_307 = lean_ctor_get(x_263, 5); +lean_inc(x_307); +lean_inc(x_306); +lean_inc(x_305); +lean_inc(x_304); +lean_inc(x_303); +lean_dec(x_263); +x_308 = lean_ctor_get(x_290, 0); +lean_inc(x_308); +x_309 = lean_ctor_get(x_290, 1); +lean_inc(x_309); +x_310 = lean_ctor_get(x_290, 3); +lean_inc(x_310); +x_311 = lean_ctor_get(x_290, 4); +lean_inc(x_311); +if (lean_is_exclusive(x_290)) { + lean_ctor_release(x_290, 0); + lean_ctor_release(x_290, 1); + lean_ctor_release(x_290, 2); + lean_ctor_release(x_290, 3); + lean_ctor_release(x_290, 4); + x_312 = x_290; } else { - x_299 = x_298; + lean_dec_ref(x_290); + x_312 = lean_box(0); } -lean_ctor_set(x_299, 0, x_295); -lean_ctor_set(x_299, 1, x_296); -lean_ctor_set(x_299, 2, x_251); -lean_ctor_set(x_299, 3, x_297); -x_300 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_300, 0, x_290); -lean_ctor_set(x_300, 1, x_291); -lean_ctor_set(x_300, 2, x_299); -lean_ctor_set(x_300, 3, x_292); -lean_ctor_set(x_300, 4, x_293); -lean_ctor_set(x_300, 5, x_294); -if (lean_is_scalar(x_244)) { - x_301 = lean_alloc_ctor(0, 2, 0); +if (lean_is_scalar(x_312)) { + x_313 = lean_alloc_ctor(0, 5, 0); } else { - x_301 = x_244; + x_313 = x_312; } -lean_ctor_set(x_301, 0, x_279); -lean_ctor_set(x_301, 1, x_300); -return x_301; +lean_ctor_set(x_313, 0, x_308); +lean_ctor_set(x_313, 1, x_309); +lean_ctor_set(x_313, 2, x_261); +lean_ctor_set(x_313, 3, x_310); +lean_ctor_set(x_313, 4, x_311); +x_314 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_314, 0, x_303); +lean_ctor_set(x_314, 1, x_304); +lean_ctor_set(x_314, 2, x_313); +lean_ctor_set(x_314, 3, x_305); +lean_ctor_set(x_314, 4, x_306); +lean_ctor_set(x_314, 5, x_307); +if (lean_is_scalar(x_254)) { + x_315 = lean_alloc_ctor(0, 2, 0); +} else { + x_315 = x_254; +} +lean_ctor_set(x_315, 0, x_291); +lean_ctor_set(x_315, 1, x_314); +return x_315; } } } } else { -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_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; lean_object* x_374; lean_object* x_375; lean_object* x_376; lean_object* x_377; lean_object* x_378; -x_330 = lean_ctor_get(x_249, 0); -x_331 = lean_ctor_get(x_249, 1); -x_332 = lean_ctor_get(x_249, 2); -x_333 = lean_ctor_get(x_249, 3); -lean_inc(x_333); -lean_inc(x_332); -lean_inc(x_331); -lean_inc(x_330); -lean_dec(x_249); -x_367 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_368 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_368, 0, x_330); -lean_ctor_set(x_368, 1, x_331); -lean_ctor_set(x_368, 2, x_367); -lean_ctor_set(x_368, 3, x_333); -lean_ctor_set(x_243, 2, x_368); -x_369 = lean_ctor_get(x_12, 0); -lean_inc(x_369); -x_370 = lean_ctor_get(x_12, 1); -lean_inc(x_370); -x_371 = lean_ctor_get(x_12, 2); -lean_inc(x_371); -x_372 = lean_ctor_get(x_12, 3); -lean_inc(x_372); -x_373 = lean_ctor_get(x_12, 4); -lean_inc(x_373); +lean_object* x_344; lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; lean_object* x_350; 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; lean_object* x_391; lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; +x_344 = lean_ctor_get(x_259, 0); +x_345 = lean_ctor_get(x_259, 1); +x_346 = lean_ctor_get(x_259, 2); +x_347 = lean_ctor_get(x_259, 3); +x_348 = lean_ctor_get(x_259, 4); +lean_inc(x_348); +lean_inc(x_347); +lean_inc(x_346); +lean_inc(x_345); +lean_inc(x_344); +lean_dec(x_259); +x_384 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_385 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_385, 0, x_344); +lean_ctor_set(x_385, 1, x_345); +lean_ctor_set(x_385, 2, x_384); +lean_ctor_set(x_385, 3, x_347); +lean_ctor_set(x_385, 4, x_348); +lean_ctor_set(x_253, 2, x_385); +x_386 = lean_ctor_get(x_12, 0); +lean_inc(x_386); +x_387 = lean_ctor_get(x_12, 1); +lean_inc(x_387); +x_388 = lean_ctor_get(x_12, 2); +lean_inc(x_388); +x_389 = lean_ctor_get(x_12, 3); +lean_inc(x_389); +x_390 = lean_ctor_get(x_12, 4); +lean_inc(x_390); if (lean_is_exclusive(x_12)) { lean_ctor_release(x_12, 0); lean_ctor_release(x_12, 1); lean_ctor_release(x_12, 2); lean_ctor_release(x_12, 3); lean_ctor_release(x_12, 4); - x_374 = x_12; + x_391 = x_12; } else { lean_dec_ref(x_12); - x_374 = lean_box(0); + x_391 = lean_box(0); } -x_375 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_375, 0, x_245); -lean_ctor_set(x_375, 1, x_20); -x_376 = lean_array_push(x_371, x_375); -if (lean_is_scalar(x_374)) { - x_377 = lean_alloc_ctor(0, 5, 0); +x_392 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_392, 0, x_255); +lean_ctor_set(x_392, 1, x_20); +x_393 = lean_array_push(x_388, x_392); +if (lean_is_scalar(x_391)) { + x_394 = lean_alloc_ctor(0, 5, 0); } else { - x_377 = x_374; + x_394 = x_391; } -lean_ctor_set(x_377, 0, x_369); -lean_ctor_set(x_377, 1, x_370); -lean_ctor_set(x_377, 2, x_376); -lean_ctor_set(x_377, 3, x_372); -lean_ctor_set(x_377, 4, x_373); -x_378 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_247, x_377, x_243); -if (lean_obj_tag(x_378) == 0) +lean_ctor_set(x_394, 0, x_386); +lean_ctor_set(x_394, 1, x_387); +lean_ctor_set(x_394, 2, x_393); +lean_ctor_set(x_394, 3, x_389); +lean_ctor_set(x_394, 4, x_390); +x_395 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_257, x_394, x_253); +if (lean_obj_tag(x_395) == 0) { -lean_object* x_379; lean_object* x_380; lean_object* x_381; -x_379 = lean_ctor_get(x_378, 0); -lean_inc(x_379); -x_380 = lean_ctor_get(x_378, 1); -lean_inc(x_380); -lean_dec(x_378); -x_381 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_381, 0, x_379); -x_334 = x_381; -x_335 = x_380; -goto block_366; +lean_object* x_396; lean_object* x_397; lean_object* x_398; +x_396 = lean_ctor_get(x_395, 0); +lean_inc(x_396); +x_397 = lean_ctor_get(x_395, 1); +lean_inc(x_397); +lean_dec(x_395); +x_398 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_398, 0, x_396); +x_349 = x_398; +x_350 = x_397; +goto block_383; } else { -lean_object* x_382; lean_object* x_383; lean_object* x_384; -x_382 = lean_ctor_get(x_378, 0); -lean_inc(x_382); -x_383 = lean_ctor_get(x_378, 1); -lean_inc(x_383); -lean_dec(x_378); -x_384 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_384, 0, x_382); -x_334 = x_384; -x_335 = x_383; -goto block_366; +lean_object* x_399; lean_object* x_400; lean_object* x_401; +x_399 = lean_ctor_get(x_395, 0); +lean_inc(x_399); +x_400 = lean_ctor_get(x_395, 1); +lean_inc(x_400); +lean_dec(x_395); +x_401 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_401, 0, x_399); +x_349 = x_401; +x_350 = x_400; +goto block_383; } -block_366: +block_383: { -if (lean_obj_tag(x_334) == 0) +if (lean_obj_tag(x_349) == 0) { -lean_object* x_336; lean_object* x_337; lean_object* x_338; lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; lean_object* x_350; -x_336 = lean_ctor_get(x_335, 2); -lean_inc(x_336); -x_337 = lean_ctor_get(x_334, 0); -lean_inc(x_337); -lean_dec(x_334); -x_338 = lean_ctor_get(x_335, 0); -lean_inc(x_338); -x_339 = lean_ctor_get(x_335, 1); -lean_inc(x_339); -x_340 = lean_ctor_get(x_335, 3); -lean_inc(x_340); -x_341 = lean_ctor_get(x_335, 4); -lean_inc(x_341); -x_342 = lean_ctor_get(x_335, 5); -lean_inc(x_342); -if (lean_is_exclusive(x_335)) { - lean_ctor_release(x_335, 0); - lean_ctor_release(x_335, 1); - lean_ctor_release(x_335, 2); - lean_ctor_release(x_335, 3); - lean_ctor_release(x_335, 4); - lean_ctor_release(x_335, 5); - x_343 = x_335; -} else { - lean_dec_ref(x_335); - x_343 = lean_box(0); -} -x_344 = lean_ctor_get(x_336, 0); -lean_inc(x_344); -x_345 = lean_ctor_get(x_336, 1); -lean_inc(x_345); -x_346 = lean_ctor_get(x_336, 3); -lean_inc(x_346); -if (lean_is_exclusive(x_336)) { - lean_ctor_release(x_336, 0); - lean_ctor_release(x_336, 1); - lean_ctor_release(x_336, 2); - lean_ctor_release(x_336, 3); - x_347 = x_336; -} else { - lean_dec_ref(x_336); - x_347 = lean_box(0); -} -if (lean_is_scalar(x_347)) { - x_348 = lean_alloc_ctor(0, 4, 0); -} else { - x_348 = x_347; -} -lean_ctor_set(x_348, 0, x_344); -lean_ctor_set(x_348, 1, x_345); -lean_ctor_set(x_348, 2, x_332); -lean_ctor_set(x_348, 3, x_346); -if (lean_is_scalar(x_343)) { - x_349 = lean_alloc_ctor(0, 6, 0); -} else { - x_349 = x_343; -} -lean_ctor_set(x_349, 0, x_338); -lean_ctor_set(x_349, 1, x_339); -lean_ctor_set(x_349, 2, x_348); -lean_ctor_set(x_349, 3, x_340); -lean_ctor_set(x_349, 4, x_341); -lean_ctor_set(x_349, 5, x_342); -if (lean_is_scalar(x_244)) { - x_350 = lean_alloc_ctor(1, 2, 0); -} else { - x_350 = x_244; - lean_ctor_set_tag(x_350, 1); -} -lean_ctor_set(x_350, 0, x_337); -lean_ctor_set(x_350, 1, x_349); -return x_350; -} -else -{ -lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; 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; -x_351 = lean_ctor_get(x_335, 2); +lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; 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; +x_351 = lean_ctor_get(x_350, 2); lean_inc(x_351); -x_352 = lean_ctor_get(x_334, 0); +x_352 = lean_ctor_get(x_349, 0); lean_inc(x_352); -lean_dec(x_334); -x_353 = lean_ctor_get(x_335, 0); +lean_dec(x_349); +x_353 = lean_ctor_get(x_350, 0); lean_inc(x_353); -x_354 = lean_ctor_get(x_335, 1); +x_354 = lean_ctor_get(x_350, 1); lean_inc(x_354); -x_355 = lean_ctor_get(x_335, 3); +x_355 = lean_ctor_get(x_350, 3); lean_inc(x_355); -x_356 = lean_ctor_get(x_335, 4); +x_356 = lean_ctor_get(x_350, 4); lean_inc(x_356); -x_357 = lean_ctor_get(x_335, 5); +x_357 = lean_ctor_get(x_350, 5); lean_inc(x_357); -if (lean_is_exclusive(x_335)) { - lean_ctor_release(x_335, 0); - lean_ctor_release(x_335, 1); - lean_ctor_release(x_335, 2); - lean_ctor_release(x_335, 3); - lean_ctor_release(x_335, 4); - lean_ctor_release(x_335, 5); - x_358 = x_335; +if (lean_is_exclusive(x_350)) { + lean_ctor_release(x_350, 0); + lean_ctor_release(x_350, 1); + lean_ctor_release(x_350, 2); + lean_ctor_release(x_350, 3); + lean_ctor_release(x_350, 4); + lean_ctor_release(x_350, 5); + x_358 = x_350; } else { - lean_dec_ref(x_335); + lean_dec_ref(x_350); x_358 = lean_box(0); } x_359 = lean_ctor_get(x_351, 0); @@ -20760,315 +21288,411 @@ x_360 = lean_ctor_get(x_351, 1); lean_inc(x_360); x_361 = lean_ctor_get(x_351, 3); lean_inc(x_361); +x_362 = lean_ctor_get(x_351, 4); +lean_inc(x_362); if (lean_is_exclusive(x_351)) { lean_ctor_release(x_351, 0); lean_ctor_release(x_351, 1); lean_ctor_release(x_351, 2); lean_ctor_release(x_351, 3); - x_362 = x_351; + lean_ctor_release(x_351, 4); + x_363 = x_351; } else { lean_dec_ref(x_351); - x_362 = lean_box(0); + x_363 = lean_box(0); } -if (lean_is_scalar(x_362)) { - x_363 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_363)) { + x_364 = lean_alloc_ctor(0, 5, 0); } else { - x_363 = x_362; + x_364 = x_363; } -lean_ctor_set(x_363, 0, x_359); -lean_ctor_set(x_363, 1, x_360); -lean_ctor_set(x_363, 2, x_332); -lean_ctor_set(x_363, 3, x_361); +lean_ctor_set(x_364, 0, x_359); +lean_ctor_set(x_364, 1, x_360); +lean_ctor_set(x_364, 2, x_346); +lean_ctor_set(x_364, 3, x_361); +lean_ctor_set(x_364, 4, x_362); if (lean_is_scalar(x_358)) { - x_364 = lean_alloc_ctor(0, 6, 0); + x_365 = lean_alloc_ctor(0, 6, 0); } else { - x_364 = x_358; + x_365 = x_358; } -lean_ctor_set(x_364, 0, x_353); -lean_ctor_set(x_364, 1, x_354); -lean_ctor_set(x_364, 2, x_363); -lean_ctor_set(x_364, 3, x_355); -lean_ctor_set(x_364, 4, x_356); -lean_ctor_set(x_364, 5, x_357); -if (lean_is_scalar(x_244)) { - x_365 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_365, 0, x_353); +lean_ctor_set(x_365, 1, x_354); +lean_ctor_set(x_365, 2, x_364); +lean_ctor_set(x_365, 3, x_355); +lean_ctor_set(x_365, 4, x_356); +lean_ctor_set(x_365, 5, x_357); +if (lean_is_scalar(x_254)) { + x_366 = lean_alloc_ctor(1, 2, 0); } else { - x_365 = x_244; + x_366 = x_254; + lean_ctor_set_tag(x_366, 1); } -lean_ctor_set(x_365, 0, x_352); -lean_ctor_set(x_365, 1, x_364); -return x_365; +lean_ctor_set(x_366, 0, x_352); +lean_ctor_set(x_366, 1, x_365); +return x_366; +} +else +{ +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; lean_object* x_374; lean_object* x_375; 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; +x_367 = lean_ctor_get(x_350, 2); +lean_inc(x_367); +x_368 = lean_ctor_get(x_349, 0); +lean_inc(x_368); +lean_dec(x_349); +x_369 = lean_ctor_get(x_350, 0); +lean_inc(x_369); +x_370 = lean_ctor_get(x_350, 1); +lean_inc(x_370); +x_371 = lean_ctor_get(x_350, 3); +lean_inc(x_371); +x_372 = lean_ctor_get(x_350, 4); +lean_inc(x_372); +x_373 = lean_ctor_get(x_350, 5); +lean_inc(x_373); +if (lean_is_exclusive(x_350)) { + lean_ctor_release(x_350, 0); + lean_ctor_release(x_350, 1); + lean_ctor_release(x_350, 2); + lean_ctor_release(x_350, 3); + lean_ctor_release(x_350, 4); + lean_ctor_release(x_350, 5); + x_374 = x_350; +} else { + lean_dec_ref(x_350); + x_374 = lean_box(0); +} +x_375 = lean_ctor_get(x_367, 0); +lean_inc(x_375); +x_376 = lean_ctor_get(x_367, 1); +lean_inc(x_376); +x_377 = lean_ctor_get(x_367, 3); +lean_inc(x_377); +x_378 = lean_ctor_get(x_367, 4); +lean_inc(x_378); +if (lean_is_exclusive(x_367)) { + lean_ctor_release(x_367, 0); + lean_ctor_release(x_367, 1); + lean_ctor_release(x_367, 2); + lean_ctor_release(x_367, 3); + lean_ctor_release(x_367, 4); + x_379 = x_367; +} else { + lean_dec_ref(x_367); + x_379 = lean_box(0); +} +if (lean_is_scalar(x_379)) { + x_380 = lean_alloc_ctor(0, 5, 0); +} else { + x_380 = x_379; +} +lean_ctor_set(x_380, 0, x_375); +lean_ctor_set(x_380, 1, x_376); +lean_ctor_set(x_380, 2, x_346); +lean_ctor_set(x_380, 3, x_377); +lean_ctor_set(x_380, 4, x_378); +if (lean_is_scalar(x_374)) { + x_381 = lean_alloc_ctor(0, 6, 0); +} else { + x_381 = x_374; +} +lean_ctor_set(x_381, 0, x_369); +lean_ctor_set(x_381, 1, x_370); +lean_ctor_set(x_381, 2, x_380); +lean_ctor_set(x_381, 3, x_371); +lean_ctor_set(x_381, 4, x_372); +lean_ctor_set(x_381, 5, x_373); +if (lean_is_scalar(x_254)) { + x_382 = lean_alloc_ctor(0, 2, 0); +} else { + x_382 = x_254; +} +lean_ctor_set(x_382, 0, x_368); +lean_ctor_set(x_382, 1, x_381); +return x_382; } } } } else { -lean_object* x_385; lean_object* x_386; lean_object* x_387; lean_object* x_388; lean_object* x_389; lean_object* x_390; lean_object* x_391; lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_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; -x_385 = lean_ctor_get(x_243, 2); -x_386 = lean_ctor_get(x_243, 0); -x_387 = lean_ctor_get(x_243, 1); -x_388 = lean_ctor_get(x_243, 3); -x_389 = lean_ctor_get(x_243, 4); -x_390 = lean_ctor_get(x_243, 5); -lean_inc(x_390); -lean_inc(x_389); -lean_inc(x_388); -lean_inc(x_385); -lean_inc(x_387); -lean_inc(x_386); -lean_dec(x_243); -x_391 = lean_ctor_get(x_385, 0); -lean_inc(x_391); -x_392 = lean_ctor_get(x_385, 1); -lean_inc(x_392); -x_393 = lean_ctor_get(x_385, 2); -lean_inc(x_393); -x_394 = lean_ctor_get(x_385, 3); -lean_inc(x_394); -if (lean_is_exclusive(x_385)) { - lean_ctor_release(x_385, 0); - lean_ctor_release(x_385, 1); - lean_ctor_release(x_385, 2); - lean_ctor_release(x_385, 3); - x_395 = x_385; +lean_object* x_402; lean_object* x_403; lean_object* x_404; lean_object* x_405; lean_object* x_406; lean_object* x_407; lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_object* x_412; lean_object* x_413; lean_object* x_414; lean_object* x_415; lean_object* x_449; lean_object* x_450; lean_object* x_451; lean_object* x_452; lean_object* x_453; lean_object* x_454; lean_object* x_455; lean_object* x_456; lean_object* x_457; lean_object* x_458; lean_object* x_459; lean_object* x_460; lean_object* x_461; +x_402 = lean_ctor_get(x_253, 2); +x_403 = lean_ctor_get(x_253, 0); +x_404 = lean_ctor_get(x_253, 1); +x_405 = lean_ctor_get(x_253, 3); +x_406 = lean_ctor_get(x_253, 4); +x_407 = lean_ctor_get(x_253, 5); +lean_inc(x_407); +lean_inc(x_406); +lean_inc(x_405); +lean_inc(x_402); +lean_inc(x_404); +lean_inc(x_403); +lean_dec(x_253); +x_408 = lean_ctor_get(x_402, 0); +lean_inc(x_408); +x_409 = lean_ctor_get(x_402, 1); +lean_inc(x_409); +x_410 = lean_ctor_get(x_402, 2); +lean_inc(x_410); +x_411 = lean_ctor_get(x_402, 3); +lean_inc(x_411); +x_412 = lean_ctor_get(x_402, 4); +lean_inc(x_412); +if (lean_is_exclusive(x_402)) { + lean_ctor_release(x_402, 0); + lean_ctor_release(x_402, 1); + lean_ctor_release(x_402, 2); + lean_ctor_release(x_402, 3); + lean_ctor_release(x_402, 4); + x_413 = x_402; } else { - lean_dec_ref(x_385); - x_395 = lean_box(0); + lean_dec_ref(x_402); + x_413 = lean_box(0); } -x_429 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_395)) { - x_430 = lean_alloc_ctor(0, 4, 0); +x_449 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_413)) { + x_450 = lean_alloc_ctor(0, 5, 0); } else { - x_430 = x_395; + x_450 = x_413; } -lean_ctor_set(x_430, 0, x_391); -lean_ctor_set(x_430, 1, x_392); -lean_ctor_set(x_430, 2, x_429); -lean_ctor_set(x_430, 3, x_394); -x_431 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_431, 0, x_386); -lean_ctor_set(x_431, 1, x_387); -lean_ctor_set(x_431, 2, x_430); -lean_ctor_set(x_431, 3, x_388); -lean_ctor_set(x_431, 4, x_389); -lean_ctor_set(x_431, 5, x_390); -x_432 = lean_ctor_get(x_12, 0); -lean_inc(x_432); -x_433 = lean_ctor_get(x_12, 1); -lean_inc(x_433); -x_434 = lean_ctor_get(x_12, 2); -lean_inc(x_434); -x_435 = lean_ctor_get(x_12, 3); -lean_inc(x_435); -x_436 = lean_ctor_get(x_12, 4); -lean_inc(x_436); +lean_ctor_set(x_450, 0, x_408); +lean_ctor_set(x_450, 1, x_409); +lean_ctor_set(x_450, 2, x_449); +lean_ctor_set(x_450, 3, x_411); +lean_ctor_set(x_450, 4, x_412); +x_451 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_451, 0, x_403); +lean_ctor_set(x_451, 1, x_404); +lean_ctor_set(x_451, 2, x_450); +lean_ctor_set(x_451, 3, x_405); +lean_ctor_set(x_451, 4, x_406); +lean_ctor_set(x_451, 5, x_407); +x_452 = lean_ctor_get(x_12, 0); +lean_inc(x_452); +x_453 = lean_ctor_get(x_12, 1); +lean_inc(x_453); +x_454 = lean_ctor_get(x_12, 2); +lean_inc(x_454); +x_455 = lean_ctor_get(x_12, 3); +lean_inc(x_455); +x_456 = lean_ctor_get(x_12, 4); +lean_inc(x_456); if (lean_is_exclusive(x_12)) { lean_ctor_release(x_12, 0); lean_ctor_release(x_12, 1); lean_ctor_release(x_12, 2); lean_ctor_release(x_12, 3); lean_ctor_release(x_12, 4); - x_437 = x_12; + x_457 = x_12; } else { lean_dec_ref(x_12); - x_437 = lean_box(0); + x_457 = lean_box(0); } -x_438 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_438, 0, x_245); -lean_ctor_set(x_438, 1, x_20); -x_439 = lean_array_push(x_434, x_438); -if (lean_is_scalar(x_437)) { - x_440 = lean_alloc_ctor(0, 5, 0); +x_458 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_458, 0, x_255); +lean_ctor_set(x_458, 1, x_20); +x_459 = lean_array_push(x_454, x_458); +if (lean_is_scalar(x_457)) { + x_460 = lean_alloc_ctor(0, 5, 0); } else { - x_440 = x_437; + x_460 = x_457; } -lean_ctor_set(x_440, 0, x_432); -lean_ctor_set(x_440, 1, x_433); -lean_ctor_set(x_440, 2, x_439); -lean_ctor_set(x_440, 3, x_435); -lean_ctor_set(x_440, 4, x_436); -x_441 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_247, x_440, x_431); -if (lean_obj_tag(x_441) == 0) +lean_ctor_set(x_460, 0, x_452); +lean_ctor_set(x_460, 1, x_453); +lean_ctor_set(x_460, 2, x_459); +lean_ctor_set(x_460, 3, x_455); +lean_ctor_set(x_460, 4, x_456); +x_461 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_257, x_460, x_451); +if (lean_obj_tag(x_461) == 0) { -lean_object* x_442; lean_object* x_443; lean_object* x_444; -x_442 = lean_ctor_get(x_441, 0); -lean_inc(x_442); -x_443 = lean_ctor_get(x_441, 1); -lean_inc(x_443); -lean_dec(x_441); -x_444 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_444, 0, x_442); -x_396 = x_444; -x_397 = x_443; -goto block_428; +lean_object* x_462; lean_object* x_463; lean_object* x_464; +x_462 = lean_ctor_get(x_461, 0); +lean_inc(x_462); +x_463 = lean_ctor_get(x_461, 1); +lean_inc(x_463); +lean_dec(x_461); +x_464 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_464, 0, x_462); +x_414 = x_464; +x_415 = x_463; +goto block_448; } else { -lean_object* x_445; lean_object* x_446; lean_object* x_447; -x_445 = lean_ctor_get(x_441, 0); -lean_inc(x_445); -x_446 = lean_ctor_get(x_441, 1); -lean_inc(x_446); -lean_dec(x_441); -x_447 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_447, 0, x_445); -x_396 = x_447; -x_397 = x_446; -goto block_428; +lean_object* x_465; lean_object* x_466; lean_object* x_467; +x_465 = lean_ctor_get(x_461, 0); +lean_inc(x_465); +x_466 = lean_ctor_get(x_461, 1); +lean_inc(x_466); +lean_dec(x_461); +x_467 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_467, 0, x_465); +x_414 = x_467; +x_415 = x_466; +goto block_448; } -block_428: +block_448: { -if (lean_obj_tag(x_396) == 0) +if (lean_obj_tag(x_414) == 0) { -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; lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_object* x_412; -x_398 = lean_ctor_get(x_397, 2); -lean_inc(x_398); -x_399 = lean_ctor_get(x_396, 0); -lean_inc(x_399); -lean_dec(x_396); -x_400 = lean_ctor_get(x_397, 0); -lean_inc(x_400); -x_401 = lean_ctor_get(x_397, 1); -lean_inc(x_401); -x_402 = lean_ctor_get(x_397, 3); -lean_inc(x_402); -x_403 = lean_ctor_get(x_397, 4); -lean_inc(x_403); -x_404 = lean_ctor_get(x_397, 5); -lean_inc(x_404); -if (lean_is_exclusive(x_397)) { - lean_ctor_release(x_397, 0); - lean_ctor_release(x_397, 1); - lean_ctor_release(x_397, 2); - lean_ctor_release(x_397, 3); - lean_ctor_release(x_397, 4); - lean_ctor_release(x_397, 5); - x_405 = x_397; -} else { - lean_dec_ref(x_397); - x_405 = lean_box(0); -} -x_406 = lean_ctor_get(x_398, 0); -lean_inc(x_406); -x_407 = lean_ctor_get(x_398, 1); -lean_inc(x_407); -x_408 = lean_ctor_get(x_398, 3); -lean_inc(x_408); -if (lean_is_exclusive(x_398)) { - lean_ctor_release(x_398, 0); - lean_ctor_release(x_398, 1); - lean_ctor_release(x_398, 2); - lean_ctor_release(x_398, 3); - x_409 = x_398; -} else { - lean_dec_ref(x_398); - x_409 = lean_box(0); -} -if (lean_is_scalar(x_409)) { - x_410 = lean_alloc_ctor(0, 4, 0); -} else { - x_410 = x_409; -} -lean_ctor_set(x_410, 0, x_406); -lean_ctor_set(x_410, 1, x_407); -lean_ctor_set(x_410, 2, x_393); -lean_ctor_set(x_410, 3, x_408); -if (lean_is_scalar(x_405)) { - x_411 = lean_alloc_ctor(0, 6, 0); -} else { - x_411 = x_405; -} -lean_ctor_set(x_411, 0, x_400); -lean_ctor_set(x_411, 1, x_401); -lean_ctor_set(x_411, 2, x_410); -lean_ctor_set(x_411, 3, x_402); -lean_ctor_set(x_411, 4, x_403); -lean_ctor_set(x_411, 5, x_404); -if (lean_is_scalar(x_244)) { - x_412 = lean_alloc_ctor(1, 2, 0); -} else { - x_412 = x_244; - lean_ctor_set_tag(x_412, 1); -} -lean_ctor_set(x_412, 0, x_399); -lean_ctor_set(x_412, 1, x_411); -return x_412; -} -else -{ -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; lean_object* x_426; lean_object* x_427; -x_413 = lean_ctor_get(x_397, 2); -lean_inc(x_413); -x_414 = lean_ctor_get(x_396, 0); -lean_inc(x_414); -lean_dec(x_396); -x_415 = lean_ctor_get(x_397, 0); -lean_inc(x_415); -x_416 = lean_ctor_get(x_397, 1); +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; lean_object* x_426; lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; +x_416 = lean_ctor_get(x_415, 2); lean_inc(x_416); -x_417 = lean_ctor_get(x_397, 3); +x_417 = lean_ctor_get(x_414, 0); lean_inc(x_417); -x_418 = lean_ctor_get(x_397, 4); +lean_dec(x_414); +x_418 = lean_ctor_get(x_415, 0); lean_inc(x_418); -x_419 = lean_ctor_get(x_397, 5); +x_419 = lean_ctor_get(x_415, 1); lean_inc(x_419); -if (lean_is_exclusive(x_397)) { - lean_ctor_release(x_397, 0); - lean_ctor_release(x_397, 1); - lean_ctor_release(x_397, 2); - lean_ctor_release(x_397, 3); - lean_ctor_release(x_397, 4); - lean_ctor_release(x_397, 5); - x_420 = x_397; -} else { - lean_dec_ref(x_397); - x_420 = lean_box(0); -} -x_421 = lean_ctor_get(x_413, 0); +x_420 = lean_ctor_get(x_415, 3); +lean_inc(x_420); +x_421 = lean_ctor_get(x_415, 4); lean_inc(x_421); -x_422 = lean_ctor_get(x_413, 1); +x_422 = lean_ctor_get(x_415, 5); lean_inc(x_422); -x_423 = lean_ctor_get(x_413, 3); -lean_inc(x_423); -if (lean_is_exclusive(x_413)) { - lean_ctor_release(x_413, 0); - lean_ctor_release(x_413, 1); - lean_ctor_release(x_413, 2); - lean_ctor_release(x_413, 3); - x_424 = x_413; +if (lean_is_exclusive(x_415)) { + lean_ctor_release(x_415, 0); + lean_ctor_release(x_415, 1); + lean_ctor_release(x_415, 2); + lean_ctor_release(x_415, 3); + lean_ctor_release(x_415, 4); + lean_ctor_release(x_415, 5); + x_423 = x_415; } else { - lean_dec_ref(x_413); - x_424 = lean_box(0); + lean_dec_ref(x_415); + x_423 = lean_box(0); } -if (lean_is_scalar(x_424)) { - x_425 = lean_alloc_ctor(0, 4, 0); +x_424 = lean_ctor_get(x_416, 0); +lean_inc(x_424); +x_425 = lean_ctor_get(x_416, 1); +lean_inc(x_425); +x_426 = lean_ctor_get(x_416, 3); +lean_inc(x_426); +x_427 = lean_ctor_get(x_416, 4); +lean_inc(x_427); +if (lean_is_exclusive(x_416)) { + lean_ctor_release(x_416, 0); + lean_ctor_release(x_416, 1); + lean_ctor_release(x_416, 2); + lean_ctor_release(x_416, 3); + lean_ctor_release(x_416, 4); + x_428 = x_416; } else { - x_425 = x_424; + lean_dec_ref(x_416); + x_428 = lean_box(0); } -lean_ctor_set(x_425, 0, x_421); -lean_ctor_set(x_425, 1, x_422); -lean_ctor_set(x_425, 2, x_393); -lean_ctor_set(x_425, 3, x_423); -if (lean_is_scalar(x_420)) { - x_426 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_428)) { + x_429 = lean_alloc_ctor(0, 5, 0); } else { - x_426 = x_420; + x_429 = x_428; } -lean_ctor_set(x_426, 0, x_415); -lean_ctor_set(x_426, 1, x_416); -lean_ctor_set(x_426, 2, x_425); -lean_ctor_set(x_426, 3, x_417); -lean_ctor_set(x_426, 4, x_418); -lean_ctor_set(x_426, 5, x_419); -if (lean_is_scalar(x_244)) { - x_427 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_429, 0, x_424); +lean_ctor_set(x_429, 1, x_425); +lean_ctor_set(x_429, 2, x_410); +lean_ctor_set(x_429, 3, x_426); +lean_ctor_set(x_429, 4, x_427); +if (lean_is_scalar(x_423)) { + x_430 = lean_alloc_ctor(0, 6, 0); } else { - x_427 = x_244; + x_430 = x_423; } -lean_ctor_set(x_427, 0, x_414); -lean_ctor_set(x_427, 1, x_426); -return x_427; +lean_ctor_set(x_430, 0, x_418); +lean_ctor_set(x_430, 1, x_419); +lean_ctor_set(x_430, 2, x_429); +lean_ctor_set(x_430, 3, x_420); +lean_ctor_set(x_430, 4, x_421); +lean_ctor_set(x_430, 5, x_422); +if (lean_is_scalar(x_254)) { + x_431 = lean_alloc_ctor(1, 2, 0); +} else { + x_431 = x_254; + lean_ctor_set_tag(x_431, 1); +} +lean_ctor_set(x_431, 0, x_417); +lean_ctor_set(x_431, 1, x_430); +return x_431; +} +else +{ +lean_object* x_432; lean_object* x_433; lean_object* x_434; lean_object* x_435; lean_object* x_436; lean_object* x_437; lean_object* x_438; lean_object* x_439; lean_object* x_440; lean_object* x_441; lean_object* x_442; lean_object* x_443; lean_object* x_444; lean_object* x_445; lean_object* x_446; lean_object* x_447; +x_432 = lean_ctor_get(x_415, 2); +lean_inc(x_432); +x_433 = lean_ctor_get(x_414, 0); +lean_inc(x_433); +lean_dec(x_414); +x_434 = lean_ctor_get(x_415, 0); +lean_inc(x_434); +x_435 = lean_ctor_get(x_415, 1); +lean_inc(x_435); +x_436 = lean_ctor_get(x_415, 3); +lean_inc(x_436); +x_437 = lean_ctor_get(x_415, 4); +lean_inc(x_437); +x_438 = lean_ctor_get(x_415, 5); +lean_inc(x_438); +if (lean_is_exclusive(x_415)) { + lean_ctor_release(x_415, 0); + lean_ctor_release(x_415, 1); + lean_ctor_release(x_415, 2); + lean_ctor_release(x_415, 3); + lean_ctor_release(x_415, 4); + lean_ctor_release(x_415, 5); + x_439 = x_415; +} else { + lean_dec_ref(x_415); + x_439 = lean_box(0); +} +x_440 = lean_ctor_get(x_432, 0); +lean_inc(x_440); +x_441 = lean_ctor_get(x_432, 1); +lean_inc(x_441); +x_442 = lean_ctor_get(x_432, 3); +lean_inc(x_442); +x_443 = lean_ctor_get(x_432, 4); +lean_inc(x_443); +if (lean_is_exclusive(x_432)) { + lean_ctor_release(x_432, 0); + lean_ctor_release(x_432, 1); + lean_ctor_release(x_432, 2); + lean_ctor_release(x_432, 3); + lean_ctor_release(x_432, 4); + x_444 = x_432; +} else { + lean_dec_ref(x_432); + x_444 = lean_box(0); +} +if (lean_is_scalar(x_444)) { + x_445 = lean_alloc_ctor(0, 5, 0); +} else { + x_445 = x_444; +} +lean_ctor_set(x_445, 0, x_440); +lean_ctor_set(x_445, 1, x_441); +lean_ctor_set(x_445, 2, x_410); +lean_ctor_set(x_445, 3, x_442); +lean_ctor_set(x_445, 4, x_443); +if (lean_is_scalar(x_439)) { + x_446 = lean_alloc_ctor(0, 6, 0); +} else { + x_446 = x_439; +} +lean_ctor_set(x_446, 0, x_434); +lean_ctor_set(x_446, 1, x_435); +lean_ctor_set(x_446, 2, x_445); +lean_ctor_set(x_446, 3, x_436); +lean_ctor_set(x_446, 4, x_437); +lean_ctor_set(x_446, 5, x_438); +if (lean_is_scalar(x_254)) { + x_447 = lean_alloc_ctor(0, 2, 0); +} else { + x_447 = x_254; +} +lean_ctor_set(x_447, 0, x_433); +lean_ctor_set(x_447, 1, x_446); +return x_447; } } } @@ -21076,7 +21700,7 @@ return x_427; } else { -uint8_t x_448; +uint8_t x_468; lean_dec(x_20); lean_dec(x_12); lean_dec(x_11); @@ -21086,23 +21710,23 @@ lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_448 = !lean_is_exclusive(x_237); -if (x_448 == 0) +x_468 = !lean_is_exclusive(x_247); +if (x_468 == 0) { -return x_237; +return x_247; } else { -lean_object* x_449; lean_object* x_450; lean_object* x_451; -x_449 = lean_ctor_get(x_237, 0); -x_450 = lean_ctor_get(x_237, 1); -lean_inc(x_450); -lean_inc(x_449); -lean_dec(x_237); -x_451 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_451, 0, x_449); -lean_ctor_set(x_451, 1, x_450); -return x_451; +lean_object* x_469; lean_object* x_470; lean_object* x_471; +x_469 = lean_ctor_get(x_247, 0); +x_470 = lean_ctor_get(x_247, 1); +lean_inc(x_470); +lean_inc(x_469); +lean_dec(x_247); +x_471 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_471, 0, x_469); +lean_ctor_set(x_471, 1, x_470); +return x_471; } } } @@ -21110,7 +21734,7 @@ return x_451; } else { -uint8_t x_452; +uint8_t x_472; lean_dec(x_24); lean_dec(x_20); lean_dec(x_12); @@ -21121,29 +21745,29 @@ lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_452 = !lean_is_exclusive(x_25); -if (x_452 == 0) +x_472 = !lean_is_exclusive(x_25); +if (x_472 == 0) { return x_25; } else { -lean_object* x_453; lean_object* x_454; lean_object* x_455; -x_453 = lean_ctor_get(x_25, 0); -x_454 = lean_ctor_get(x_25, 1); -lean_inc(x_454); -lean_inc(x_453); +lean_object* x_473; lean_object* x_474; lean_object* x_475; +x_473 = lean_ctor_get(x_25, 0); +x_474 = lean_ctor_get(x_25, 1); +lean_inc(x_474); +lean_inc(x_473); lean_dec(x_25); -x_455 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_455, 0, x_453); -lean_ctor_set(x_455, 1, x_454); -return x_455; +x_475 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_475, 0, x_473); +lean_ctor_set(x_475, 1, x_474); +return x_475; } } } else { -uint8_t x_456; +uint8_t x_476; lean_dec(x_20); lean_dec(x_12); lean_dec(x_11); @@ -21153,23 +21777,23 @@ lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_456 = !lean_is_exclusive(x_21); -if (x_456 == 0) +x_476 = !lean_is_exclusive(x_21); +if (x_476 == 0) { return x_21; } else { -lean_object* x_457; lean_object* x_458; lean_object* x_459; -x_457 = lean_ctor_get(x_21, 0); -x_458 = lean_ctor_get(x_21, 1); -lean_inc(x_458); -lean_inc(x_457); +lean_object* x_477; lean_object* x_478; lean_object* x_479; +x_477 = lean_ctor_get(x_21, 0); +x_478 = lean_ctor_get(x_21, 1); +lean_inc(x_478); +lean_inc(x_477); lean_dec(x_21); -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_479 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_479, 0, x_477); +lean_ctor_set(x_479, 1, x_478); +return x_479; } } } @@ -21269,105 +21893,105 @@ x_31 = lean_ctor_get(x_25, 2); x_32 = !lean_is_exclusive(x_31); if (x_32 == 0) { -lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_85; uint8_t x_86; +lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_89; uint8_t x_90; x_33 = lean_ctor_get(x_31, 2); -x_85 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_31, 2, x_85); -x_86 = !lean_is_exclusive(x_7); -if (x_86 == 0) +x_89 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_31, 2, x_89); +x_90 = !lean_is_exclusive(x_7); +if (x_90 == 0) { -lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; -x_87 = lean_ctor_get(x_7, 2); -x_88 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_88, 0, x_27); -lean_ctor_set(x_88, 1, x_14); -x_89 = lean_array_push(x_87, x_88); -lean_ctor_set(x_7, 2, x_89); -x_90 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_7, x_25); -if (lean_obj_tag(x_90) == 0) +lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; +x_91 = lean_ctor_get(x_7, 2); +x_92 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_92, 0, x_27); +lean_ctor_set(x_92, 1, x_14); +x_93 = lean_array_push(x_91, x_92); +lean_ctor_set(x_7, 2, x_93); +x_94 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_7, x_25); +if (lean_obj_tag(x_94) == 0) { -lean_object* x_91; lean_object* x_92; lean_object* x_93; -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_alloc_ctor(1, 1, 0); -lean_ctor_set(x_93, 0, x_91); -x_34 = x_93; -x_35 = x_92; -goto block_84; -} -else -{ -lean_object* x_94; lean_object* x_95; lean_object* x_96; -x_94 = lean_ctor_get(x_90, 0); -lean_inc(x_94); -x_95 = lean_ctor_get(x_90, 1); +lean_object* x_95; lean_object* x_96; lean_object* x_97; +x_95 = lean_ctor_get(x_94, 0); lean_inc(x_95); -lean_dec(x_90); -x_96 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_96, 0, x_94); -x_34 = x_96; -x_35 = x_95; -goto block_84; -} +x_96 = lean_ctor_get(x_94, 1); +lean_inc(x_96); +lean_dec(x_94); +x_97 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_97, 0, x_95); +x_34 = x_97; +x_35 = x_96; +goto block_88; } else { -lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; -x_97 = lean_ctor_get(x_7, 0); -x_98 = lean_ctor_get(x_7, 1); -x_99 = lean_ctor_get(x_7, 2); -x_100 = lean_ctor_get(x_7, 3); -x_101 = lean_ctor_get(x_7, 4); -lean_inc(x_101); -lean_inc(x_100); -lean_inc(x_99); +lean_object* x_98; lean_object* x_99; lean_object* x_100; +x_98 = lean_ctor_get(x_94, 0); lean_inc(x_98); -lean_inc(x_97); -lean_dec(x_7); -x_102 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_102, 0, x_27); -lean_ctor_set(x_102, 1, x_14); -x_103 = lean_array_push(x_99, x_102); -x_104 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_104, 0, x_97); -lean_ctor_set(x_104, 1, x_98); -lean_ctor_set(x_104, 2, x_103); -lean_ctor_set(x_104, 3, x_100); -lean_ctor_set(x_104, 4, x_101); -x_105 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_104, x_25); -if (lean_obj_tag(x_105) == 0) -{ -lean_object* x_106; lean_object* x_107; lean_object* x_108; -x_106 = lean_ctor_get(x_105, 0); -lean_inc(x_106); -x_107 = lean_ctor_get(x_105, 1); -lean_inc(x_107); -lean_dec(x_105); -x_108 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_108, 0, x_106); -x_34 = x_108; -x_35 = x_107; -goto block_84; +x_99 = lean_ctor_get(x_94, 1); +lean_inc(x_99); +lean_dec(x_94); +x_100 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_100, 0, x_98); +x_34 = x_100; +x_35 = x_99; +goto block_88; +} } else { -lean_object* x_109; lean_object* x_110; lean_object* x_111; -x_109 = lean_ctor_get(x_105, 0); -lean_inc(x_109); -x_110 = lean_ctor_get(x_105, 1); +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; +x_101 = lean_ctor_get(x_7, 0); +x_102 = lean_ctor_get(x_7, 1); +x_103 = lean_ctor_get(x_7, 2); +x_104 = lean_ctor_get(x_7, 3); +x_105 = lean_ctor_get(x_7, 4); +lean_inc(x_105); +lean_inc(x_104); +lean_inc(x_103); +lean_inc(x_102); +lean_inc(x_101); +lean_dec(x_7); +x_106 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_106, 0, x_27); +lean_ctor_set(x_106, 1, x_14); +x_107 = lean_array_push(x_103, x_106); +x_108 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_108, 0, x_101); +lean_ctor_set(x_108, 1, x_102); +lean_ctor_set(x_108, 2, x_107); +lean_ctor_set(x_108, 3, x_104); +lean_ctor_set(x_108, 4, x_105); +x_109 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_108, x_25); +if (lean_obj_tag(x_109) == 0) +{ +lean_object* x_110; lean_object* x_111; lean_object* x_112; +x_110 = lean_ctor_get(x_109, 0); lean_inc(x_110); -lean_dec(x_105); -x_111 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_111, 0, x_109); -x_34 = x_111; -x_35 = x_110; -goto block_84; +x_111 = lean_ctor_get(x_109, 1); +lean_inc(x_111); +lean_dec(x_109); +x_112 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_112, 0, x_110); +x_34 = x_112; +x_35 = x_111; +goto block_88; +} +else +{ +lean_object* x_113; lean_object* x_114; lean_object* x_115; +x_113 = lean_ctor_get(x_109, 0); +lean_inc(x_113); +x_114 = lean_ctor_get(x_109, 1); +lean_inc(x_114); +lean_dec(x_109); +x_115 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_115, 0, x_113); +x_34 = x_115; +x_35 = x_114; +goto block_88; } } -block_84: +block_88: { if (lean_obj_tag(x_34) == 0) { @@ -21402,1284 +22026,1262 @@ return x_42; } else { -lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; +lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; x_43 = lean_ctor_get(x_36, 0); x_44 = lean_ctor_get(x_36, 1); x_45 = lean_ctor_get(x_36, 3); +x_46 = lean_ctor_get(x_36, 4); +lean_inc(x_46); lean_inc(x_45); lean_inc(x_44); lean_inc(x_43); lean_dec(x_36); -x_46 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_46, 0, x_43); -lean_ctor_set(x_46, 1, x_44); -lean_ctor_set(x_46, 2, x_33); -lean_ctor_set(x_46, 3, x_45); -lean_ctor_set(x_35, 2, x_46); +x_47 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_47, 0, x_43); +lean_ctor_set(x_47, 1, x_44); +lean_ctor_set(x_47, 2, x_33); +lean_ctor_set(x_47, 3, x_45); +lean_ctor_set(x_47, 4, x_46); +lean_ctor_set(x_35, 2, x_47); if (lean_is_scalar(x_26)) { - x_47 = lean_alloc_ctor(1, 2, 0); + x_48 = lean_alloc_ctor(1, 2, 0); } else { - x_47 = x_26; - lean_ctor_set_tag(x_47, 1); + x_48 = x_26; + lean_ctor_set_tag(x_48, 1); } -lean_ctor_set(x_47, 0, x_37); -lean_ctor_set(x_47, 1, x_35); -return x_47; +lean_ctor_set(x_48, 0, x_37); +lean_ctor_set(x_48, 1, x_35); +return x_48; } } else { -lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; -x_48 = lean_ctor_get(x_35, 0); -x_49 = lean_ctor_get(x_35, 1); -x_50 = lean_ctor_get(x_35, 3); -x_51 = lean_ctor_get(x_35, 4); -x_52 = lean_ctor_get(x_35, 5); +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; +x_49 = lean_ctor_get(x_35, 0); +x_50 = lean_ctor_get(x_35, 1); +x_51 = lean_ctor_get(x_35, 3); +x_52 = lean_ctor_get(x_35, 4); +x_53 = lean_ctor_get(x_35, 5); +lean_inc(x_53); lean_inc(x_52); lean_inc(x_51); lean_inc(x_50); lean_inc(x_49); -lean_inc(x_48); lean_dec(x_35); -x_53 = lean_ctor_get(x_36, 0); -lean_inc(x_53); -x_54 = lean_ctor_get(x_36, 1); +x_54 = lean_ctor_get(x_36, 0); lean_inc(x_54); -x_55 = lean_ctor_get(x_36, 3); +x_55 = lean_ctor_get(x_36, 1); lean_inc(x_55); +x_56 = lean_ctor_get(x_36, 3); +lean_inc(x_56); +x_57 = lean_ctor_get(x_36, 4); +lean_inc(x_57); if (lean_is_exclusive(x_36)) { lean_ctor_release(x_36, 0); lean_ctor_release(x_36, 1); lean_ctor_release(x_36, 2); lean_ctor_release(x_36, 3); - x_56 = x_36; + lean_ctor_release(x_36, 4); + x_58 = x_36; } else { lean_dec_ref(x_36); - x_56 = lean_box(0); + x_58 = lean_box(0); } -if (lean_is_scalar(x_56)) { - x_57 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_58)) { + x_59 = lean_alloc_ctor(0, 5, 0); } else { - x_57 = x_56; + x_59 = x_58; } -lean_ctor_set(x_57, 0, x_53); -lean_ctor_set(x_57, 1, x_54); -lean_ctor_set(x_57, 2, x_33); -lean_ctor_set(x_57, 3, x_55); -x_58 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_58, 0, x_48); -lean_ctor_set(x_58, 1, x_49); -lean_ctor_set(x_58, 2, x_57); -lean_ctor_set(x_58, 3, x_50); -lean_ctor_set(x_58, 4, x_51); -lean_ctor_set(x_58, 5, x_52); +lean_ctor_set(x_59, 0, x_54); +lean_ctor_set(x_59, 1, x_55); +lean_ctor_set(x_59, 2, x_33); +lean_ctor_set(x_59, 3, x_56); +lean_ctor_set(x_59, 4, x_57); +x_60 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_60, 0, x_49); +lean_ctor_set(x_60, 1, x_50); +lean_ctor_set(x_60, 2, x_59); +lean_ctor_set(x_60, 3, x_51); +lean_ctor_set(x_60, 4, x_52); +lean_ctor_set(x_60, 5, x_53); if (lean_is_scalar(x_26)) { - x_59 = lean_alloc_ctor(1, 2, 0); + x_61 = lean_alloc_ctor(1, 2, 0); } else { - x_59 = x_26; - lean_ctor_set_tag(x_59, 1); + x_61 = x_26; + lean_ctor_set_tag(x_61, 1); } -lean_ctor_set(x_59, 0, x_37); -lean_ctor_set(x_59, 1, x_58); -return x_59; +lean_ctor_set(x_61, 0, x_37); +lean_ctor_set(x_61, 1, x_60); +return x_61; } } else { -lean_object* x_60; lean_object* x_61; uint8_t x_62; -x_60 = lean_ctor_get(x_35, 2); -lean_inc(x_60); -x_61 = lean_ctor_get(x_34, 0); -lean_inc(x_61); +lean_object* x_62; lean_object* x_63; uint8_t x_64; +x_62 = lean_ctor_get(x_35, 2); +lean_inc(x_62); +x_63 = lean_ctor_get(x_34, 0); +lean_inc(x_63); lean_dec(x_34); -x_62 = !lean_is_exclusive(x_35); -if (x_62 == 0) -{ -lean_object* x_63; uint8_t x_64; -x_63 = lean_ctor_get(x_35, 2); -lean_dec(x_63); -x_64 = !lean_is_exclusive(x_60); +x_64 = !lean_is_exclusive(x_35); if (x_64 == 0) { -lean_object* x_65; lean_object* x_66; -x_65 = lean_ctor_get(x_60, 2); +lean_object* x_65; uint8_t x_66; +x_65 = lean_ctor_get(x_35, 2); lean_dec(x_65); -lean_ctor_set(x_60, 2, x_33); +x_66 = !lean_is_exclusive(x_62); +if (x_66 == 0) +{ +lean_object* x_67; lean_object* x_68; +x_67 = lean_ctor_get(x_62, 2); +lean_dec(x_67); +lean_ctor_set(x_62, 2, x_33); if (lean_is_scalar(x_26)) { - x_66 = lean_alloc_ctor(0, 2, 0); + x_68 = lean_alloc_ctor(0, 2, 0); } else { - x_66 = x_26; + x_68 = x_26; } -lean_ctor_set(x_66, 0, x_61); -lean_ctor_set(x_66, 1, x_35); -return x_66; +lean_ctor_set(x_68, 0, x_63); +lean_ctor_set(x_68, 1, x_35); +return x_68; } else { -lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; -x_67 = lean_ctor_get(x_60, 0); -x_68 = lean_ctor_get(x_60, 1); -x_69 = lean_ctor_get(x_60, 3); +lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; +x_69 = lean_ctor_get(x_62, 0); +x_70 = lean_ctor_get(x_62, 1); +x_71 = lean_ctor_get(x_62, 3); +x_72 = lean_ctor_get(x_62, 4); +lean_inc(x_72); +lean_inc(x_71); +lean_inc(x_70); lean_inc(x_69); -lean_inc(x_68); -lean_inc(x_67); -lean_dec(x_60); -x_70 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_70, 0, x_67); -lean_ctor_set(x_70, 1, x_68); -lean_ctor_set(x_70, 2, x_33); -lean_ctor_set(x_70, 3, x_69); -lean_ctor_set(x_35, 2, x_70); +lean_dec(x_62); +x_73 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_73, 0, x_69); +lean_ctor_set(x_73, 1, x_70); +lean_ctor_set(x_73, 2, x_33); +lean_ctor_set(x_73, 3, x_71); +lean_ctor_set(x_73, 4, x_72); +lean_ctor_set(x_35, 2, x_73); if (lean_is_scalar(x_26)) { - x_71 = lean_alloc_ctor(0, 2, 0); + x_74 = lean_alloc_ctor(0, 2, 0); } else { - x_71 = x_26; + x_74 = x_26; } -lean_ctor_set(x_71, 0, x_61); -lean_ctor_set(x_71, 1, x_35); -return x_71; +lean_ctor_set(x_74, 0, x_63); +lean_ctor_set(x_74, 1, x_35); +return x_74; } } else { -lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; -x_72 = lean_ctor_get(x_35, 0); -x_73 = lean_ctor_get(x_35, 1); -x_74 = lean_ctor_get(x_35, 3); -x_75 = lean_ctor_get(x_35, 4); -x_76 = lean_ctor_get(x_35, 5); +lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; +x_75 = lean_ctor_get(x_35, 0); +x_76 = lean_ctor_get(x_35, 1); +x_77 = lean_ctor_get(x_35, 3); +x_78 = lean_ctor_get(x_35, 4); +x_79 = lean_ctor_get(x_35, 5); +lean_inc(x_79); +lean_inc(x_78); +lean_inc(x_77); lean_inc(x_76); lean_inc(x_75); -lean_inc(x_74); -lean_inc(x_73); -lean_inc(x_72); lean_dec(x_35); -x_77 = lean_ctor_get(x_60, 0); -lean_inc(x_77); -x_78 = lean_ctor_get(x_60, 1); -lean_inc(x_78); -x_79 = lean_ctor_get(x_60, 3); -lean_inc(x_79); -if (lean_is_exclusive(x_60)) { - lean_ctor_release(x_60, 0); - lean_ctor_release(x_60, 1); - lean_ctor_release(x_60, 2); - lean_ctor_release(x_60, 3); - x_80 = x_60; +x_80 = lean_ctor_get(x_62, 0); +lean_inc(x_80); +x_81 = lean_ctor_get(x_62, 1); +lean_inc(x_81); +x_82 = lean_ctor_get(x_62, 3); +lean_inc(x_82); +x_83 = lean_ctor_get(x_62, 4); +lean_inc(x_83); +if (lean_is_exclusive(x_62)) { + lean_ctor_release(x_62, 0); + lean_ctor_release(x_62, 1); + lean_ctor_release(x_62, 2); + lean_ctor_release(x_62, 3); + lean_ctor_release(x_62, 4); + x_84 = x_62; } else { - lean_dec_ref(x_60); - x_80 = lean_box(0); + lean_dec_ref(x_62); + x_84 = lean_box(0); } -if (lean_is_scalar(x_80)) { - x_81 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_84)) { + x_85 = lean_alloc_ctor(0, 5, 0); } else { - x_81 = x_80; + x_85 = x_84; } -lean_ctor_set(x_81, 0, x_77); -lean_ctor_set(x_81, 1, x_78); -lean_ctor_set(x_81, 2, x_33); -lean_ctor_set(x_81, 3, x_79); -x_82 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_82, 0, x_72); -lean_ctor_set(x_82, 1, x_73); -lean_ctor_set(x_82, 2, x_81); -lean_ctor_set(x_82, 3, x_74); -lean_ctor_set(x_82, 4, x_75); -lean_ctor_set(x_82, 5, x_76); +lean_ctor_set(x_85, 0, x_80); +lean_ctor_set(x_85, 1, x_81); +lean_ctor_set(x_85, 2, x_33); +lean_ctor_set(x_85, 3, x_82); +lean_ctor_set(x_85, 4, x_83); +x_86 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_86, 0, x_75); +lean_ctor_set(x_86, 1, x_76); +lean_ctor_set(x_86, 2, x_85); +lean_ctor_set(x_86, 3, x_77); +lean_ctor_set(x_86, 4, x_78); +lean_ctor_set(x_86, 5, x_79); if (lean_is_scalar(x_26)) { - x_83 = lean_alloc_ctor(0, 2, 0); + x_87 = lean_alloc_ctor(0, 2, 0); } else { - x_83 = x_26; + x_87 = x_26; } -lean_ctor_set(x_83, 0, x_61); -lean_ctor_set(x_83, 1, x_82); -return x_83; +lean_ctor_set(x_87, 0, x_63); +lean_ctor_set(x_87, 1, x_86); +return x_87; } } } } else { -lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_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; -x_112 = lean_ctor_get(x_31, 0); -x_113 = lean_ctor_get(x_31, 1); -x_114 = lean_ctor_get(x_31, 2); -x_115 = lean_ctor_get(x_31, 3); -lean_inc(x_115); -lean_inc(x_114); -lean_inc(x_113); -lean_inc(x_112); -lean_dec(x_31); -x_149 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_150 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_150, 0, x_112); -lean_ctor_set(x_150, 1, x_113); -lean_ctor_set(x_150, 2, x_149); -lean_ctor_set(x_150, 3, x_115); -lean_ctor_set(x_25, 2, x_150); -x_151 = lean_ctor_get(x_7, 0); -lean_inc(x_151); -x_152 = lean_ctor_get(x_7, 1); -lean_inc(x_152); -x_153 = lean_ctor_get(x_7, 2); -lean_inc(x_153); -x_154 = lean_ctor_get(x_7, 3); -lean_inc(x_154); -x_155 = lean_ctor_get(x_7, 4); -lean_inc(x_155); -if (lean_is_exclusive(x_7)) { - lean_ctor_release(x_7, 0); - lean_ctor_release(x_7, 1); - lean_ctor_release(x_7, 2); - lean_ctor_release(x_7, 3); - lean_ctor_release(x_7, 4); - x_156 = x_7; -} else { - lean_dec_ref(x_7); - x_156 = lean_box(0); -} -x_157 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_157, 0, x_27); -lean_ctor_set(x_157, 1, x_14); -x_158 = lean_array_push(x_153, x_157); -if (lean_is_scalar(x_156)) { - x_159 = lean_alloc_ctor(0, 5, 0); -} else { - x_159 = x_156; -} -lean_ctor_set(x_159, 0, x_151); -lean_ctor_set(x_159, 1, x_152); -lean_ctor_set(x_159, 2, x_158); -lean_ctor_set(x_159, 3, x_154); -lean_ctor_set(x_159, 4, x_155); -x_160 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_159, x_25); -if (lean_obj_tag(x_160) == 0) -{ -lean_object* x_161; lean_object* x_162; lean_object* x_163; -x_161 = lean_ctor_get(x_160, 0); -lean_inc(x_161); -x_162 = lean_ctor_get(x_160, 1); -lean_inc(x_162); -lean_dec(x_160); -x_163 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_163, 0, x_161); -x_116 = x_163; -x_117 = x_162; -goto block_148; -} -else -{ -lean_object* x_164; lean_object* x_165; lean_object* x_166; -x_164 = lean_ctor_get(x_160, 0); -lean_inc(x_164); -x_165 = lean_ctor_get(x_160, 1); -lean_inc(x_165); -lean_dec(x_160); -x_166 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_166, 0, x_164); -x_116 = x_166; -x_117 = x_165; -goto block_148; -} -block_148: -{ -if (lean_obj_tag(x_116) == 0) -{ -lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; -x_118 = lean_ctor_get(x_117, 2); -lean_inc(x_118); -x_119 = lean_ctor_get(x_116, 0); -lean_inc(x_119); -lean_dec(x_116); -x_120 = lean_ctor_get(x_117, 0); +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_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; +x_116 = lean_ctor_get(x_31, 0); +x_117 = lean_ctor_get(x_31, 1); +x_118 = lean_ctor_get(x_31, 2); +x_119 = lean_ctor_get(x_31, 3); +x_120 = lean_ctor_get(x_31, 4); lean_inc(x_120); -x_121 = lean_ctor_get(x_117, 1); -lean_inc(x_121); -x_122 = lean_ctor_get(x_117, 3); -lean_inc(x_122); -x_123 = lean_ctor_get(x_117, 4); -lean_inc(x_123); -x_124 = lean_ctor_get(x_117, 5); -lean_inc(x_124); -if (lean_is_exclusive(x_117)) { - lean_ctor_release(x_117, 0); - lean_ctor_release(x_117, 1); - lean_ctor_release(x_117, 2); - lean_ctor_release(x_117, 3); - lean_ctor_release(x_117, 4); - lean_ctor_release(x_117, 5); - x_125 = x_117; -} else { - lean_dec_ref(x_117); - x_125 = lean_box(0); -} -x_126 = lean_ctor_get(x_118, 0); -lean_inc(x_126); -x_127 = lean_ctor_get(x_118, 1); -lean_inc(x_127); -x_128 = lean_ctor_get(x_118, 3); -lean_inc(x_128); -if (lean_is_exclusive(x_118)) { - lean_ctor_release(x_118, 0); - lean_ctor_release(x_118, 1); - lean_ctor_release(x_118, 2); - lean_ctor_release(x_118, 3); - x_129 = x_118; -} else { - lean_dec_ref(x_118); - x_129 = lean_box(0); -} -if (lean_is_scalar(x_129)) { - x_130 = lean_alloc_ctor(0, 4, 0); -} else { - x_130 = x_129; -} -lean_ctor_set(x_130, 0, x_126); -lean_ctor_set(x_130, 1, x_127); -lean_ctor_set(x_130, 2, x_114); -lean_ctor_set(x_130, 3, x_128); -if (lean_is_scalar(x_125)) { - x_131 = lean_alloc_ctor(0, 6, 0); -} else { - x_131 = x_125; -} -lean_ctor_set(x_131, 0, x_120); -lean_ctor_set(x_131, 1, x_121); -lean_ctor_set(x_131, 2, x_130); -lean_ctor_set(x_131, 3, x_122); -lean_ctor_set(x_131, 4, x_123); -lean_ctor_set(x_131, 5, x_124); -if (lean_is_scalar(x_26)) { - x_132 = lean_alloc_ctor(1, 2, 0); -} else { - x_132 = x_26; - lean_ctor_set_tag(x_132, 1); -} -lean_ctor_set(x_132, 0, x_119); -lean_ctor_set(x_132, 1, x_131); -return x_132; -} -else -{ -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; -x_133 = lean_ctor_get(x_117, 2); -lean_inc(x_133); -x_134 = lean_ctor_get(x_116, 0); -lean_inc(x_134); -lean_dec(x_116); -x_135 = lean_ctor_get(x_117, 0); -lean_inc(x_135); -x_136 = lean_ctor_get(x_117, 1); -lean_inc(x_136); -x_137 = lean_ctor_get(x_117, 3); -lean_inc(x_137); -x_138 = lean_ctor_get(x_117, 4); -lean_inc(x_138); -x_139 = lean_ctor_get(x_117, 5); -lean_inc(x_139); -if (lean_is_exclusive(x_117)) { - lean_ctor_release(x_117, 0); - lean_ctor_release(x_117, 1); - lean_ctor_release(x_117, 2); - lean_ctor_release(x_117, 3); - lean_ctor_release(x_117, 4); - lean_ctor_release(x_117, 5); - x_140 = x_117; -} else { - lean_dec_ref(x_117); - x_140 = lean_box(0); -} -x_141 = lean_ctor_get(x_133, 0); -lean_inc(x_141); -x_142 = lean_ctor_get(x_133, 1); -lean_inc(x_142); -x_143 = lean_ctor_get(x_133, 3); -lean_inc(x_143); -if (lean_is_exclusive(x_133)) { - lean_ctor_release(x_133, 0); - lean_ctor_release(x_133, 1); - lean_ctor_release(x_133, 2); - lean_ctor_release(x_133, 3); - x_144 = x_133; -} else { - lean_dec_ref(x_133); - x_144 = lean_box(0); -} -if (lean_is_scalar(x_144)) { - x_145 = lean_alloc_ctor(0, 4, 0); -} else { - x_145 = x_144; -} -lean_ctor_set(x_145, 0, x_141); -lean_ctor_set(x_145, 1, x_142); -lean_ctor_set(x_145, 2, x_114); -lean_ctor_set(x_145, 3, x_143); -if (lean_is_scalar(x_140)) { - x_146 = lean_alloc_ctor(0, 6, 0); -} else { - x_146 = x_140; -} -lean_ctor_set(x_146, 0, x_135); -lean_ctor_set(x_146, 1, x_136); -lean_ctor_set(x_146, 2, x_145); -lean_ctor_set(x_146, 3, x_137); -lean_ctor_set(x_146, 4, x_138); -lean_ctor_set(x_146, 5, x_139); -if (lean_is_scalar(x_26)) { - x_147 = lean_alloc_ctor(0, 2, 0); -} else { - x_147 = x_26; -} -lean_ctor_set(x_147, 0, x_134); -lean_ctor_set(x_147, 1, x_146); -return x_147; -} -} -} -} -else -{ -lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; 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; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; -x_167 = lean_ctor_get(x_25, 2); -x_168 = lean_ctor_get(x_25, 0); -x_169 = lean_ctor_get(x_25, 1); -x_170 = lean_ctor_get(x_25, 3); -x_171 = lean_ctor_get(x_25, 4); -x_172 = lean_ctor_get(x_25, 5); -lean_inc(x_172); -lean_inc(x_171); -lean_inc(x_170); -lean_inc(x_167); -lean_inc(x_169); -lean_inc(x_168); -lean_dec(x_25); -x_173 = lean_ctor_get(x_167, 0); -lean_inc(x_173); -x_174 = lean_ctor_get(x_167, 1); -lean_inc(x_174); -x_175 = lean_ctor_get(x_167, 2); -lean_inc(x_175); -x_176 = lean_ctor_get(x_167, 3); -lean_inc(x_176); -if (lean_is_exclusive(x_167)) { - lean_ctor_release(x_167, 0); - lean_ctor_release(x_167, 1); - lean_ctor_release(x_167, 2); - lean_ctor_release(x_167, 3); - x_177 = x_167; -} else { - lean_dec_ref(x_167); - x_177 = lean_box(0); -} -x_211 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_177)) { - x_212 = lean_alloc_ctor(0, 4, 0); -} else { - x_212 = x_177; -} -lean_ctor_set(x_212, 0, x_173); -lean_ctor_set(x_212, 1, x_174); -lean_ctor_set(x_212, 2, x_211); -lean_ctor_set(x_212, 3, x_176); -x_213 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_213, 0, x_168); -lean_ctor_set(x_213, 1, x_169); -lean_ctor_set(x_213, 2, x_212); -lean_ctor_set(x_213, 3, x_170); -lean_ctor_set(x_213, 4, x_171); -lean_ctor_set(x_213, 5, x_172); -x_214 = lean_ctor_get(x_7, 0); -lean_inc(x_214); -x_215 = lean_ctor_get(x_7, 1); -lean_inc(x_215); -x_216 = lean_ctor_get(x_7, 2); -lean_inc(x_216); -x_217 = lean_ctor_get(x_7, 3); -lean_inc(x_217); -x_218 = lean_ctor_get(x_7, 4); -lean_inc(x_218); +lean_inc(x_119); +lean_inc(x_118); +lean_inc(x_117); +lean_inc(x_116); +lean_dec(x_31); +x_156 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_157 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_157, 0, x_116); +lean_ctor_set(x_157, 1, x_117); +lean_ctor_set(x_157, 2, x_156); +lean_ctor_set(x_157, 3, x_119); +lean_ctor_set(x_157, 4, x_120); +lean_ctor_set(x_25, 2, x_157); +x_158 = lean_ctor_get(x_7, 0); +lean_inc(x_158); +x_159 = lean_ctor_get(x_7, 1); +lean_inc(x_159); +x_160 = lean_ctor_get(x_7, 2); +lean_inc(x_160); +x_161 = lean_ctor_get(x_7, 3); +lean_inc(x_161); +x_162 = lean_ctor_get(x_7, 4); +lean_inc(x_162); if (lean_is_exclusive(x_7)) { lean_ctor_release(x_7, 0); lean_ctor_release(x_7, 1); lean_ctor_release(x_7, 2); lean_ctor_release(x_7, 3); lean_ctor_release(x_7, 4); - x_219 = x_7; + x_163 = x_7; } else { lean_dec_ref(x_7); - x_219 = lean_box(0); + x_163 = lean_box(0); } -x_220 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_220, 0, x_27); -lean_ctor_set(x_220, 1, x_14); -x_221 = lean_array_push(x_216, x_220); -if (lean_is_scalar(x_219)) { +x_164 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_164, 0, x_27); +lean_ctor_set(x_164, 1, x_14); +x_165 = lean_array_push(x_160, x_164); +if (lean_is_scalar(x_163)) { + x_166 = lean_alloc_ctor(0, 5, 0); +} else { + x_166 = x_163; +} +lean_ctor_set(x_166, 0, x_158); +lean_ctor_set(x_166, 1, x_159); +lean_ctor_set(x_166, 2, x_165); +lean_ctor_set(x_166, 3, x_161); +lean_ctor_set(x_166, 4, x_162); +x_167 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_166, x_25); +if (lean_obj_tag(x_167) == 0) +{ +lean_object* x_168; lean_object* x_169; lean_object* x_170; +x_168 = lean_ctor_get(x_167, 0); +lean_inc(x_168); +x_169 = lean_ctor_get(x_167, 1); +lean_inc(x_169); +lean_dec(x_167); +x_170 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_170, 0, x_168); +x_121 = x_170; +x_122 = x_169; +goto block_155; +} +else +{ +lean_object* x_171; lean_object* x_172; lean_object* x_173; +x_171 = lean_ctor_get(x_167, 0); +lean_inc(x_171); +x_172 = lean_ctor_get(x_167, 1); +lean_inc(x_172); +lean_dec(x_167); +x_173 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_173, 0, x_171); +x_121 = x_173; +x_122 = x_172; +goto block_155; +} +block_155: +{ +if (lean_obj_tag(x_121) == 0) +{ +lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; +x_123 = lean_ctor_get(x_122, 2); +lean_inc(x_123); +x_124 = lean_ctor_get(x_121, 0); +lean_inc(x_124); +lean_dec(x_121); +x_125 = lean_ctor_get(x_122, 0); +lean_inc(x_125); +x_126 = lean_ctor_get(x_122, 1); +lean_inc(x_126); +x_127 = lean_ctor_get(x_122, 3); +lean_inc(x_127); +x_128 = lean_ctor_get(x_122, 4); +lean_inc(x_128); +x_129 = lean_ctor_get(x_122, 5); +lean_inc(x_129); +if (lean_is_exclusive(x_122)) { + lean_ctor_release(x_122, 0); + lean_ctor_release(x_122, 1); + lean_ctor_release(x_122, 2); + lean_ctor_release(x_122, 3); + lean_ctor_release(x_122, 4); + lean_ctor_release(x_122, 5); + x_130 = x_122; +} else { + lean_dec_ref(x_122); + x_130 = lean_box(0); +} +x_131 = lean_ctor_get(x_123, 0); +lean_inc(x_131); +x_132 = lean_ctor_get(x_123, 1); +lean_inc(x_132); +x_133 = lean_ctor_get(x_123, 3); +lean_inc(x_133); +x_134 = lean_ctor_get(x_123, 4); +lean_inc(x_134); +if (lean_is_exclusive(x_123)) { + lean_ctor_release(x_123, 0); + lean_ctor_release(x_123, 1); + lean_ctor_release(x_123, 2); + lean_ctor_release(x_123, 3); + lean_ctor_release(x_123, 4); + x_135 = x_123; +} else { + lean_dec_ref(x_123); + x_135 = lean_box(0); +} +if (lean_is_scalar(x_135)) { + x_136 = lean_alloc_ctor(0, 5, 0); +} else { + x_136 = x_135; +} +lean_ctor_set(x_136, 0, x_131); +lean_ctor_set(x_136, 1, x_132); +lean_ctor_set(x_136, 2, x_118); +lean_ctor_set(x_136, 3, x_133); +lean_ctor_set(x_136, 4, x_134); +if (lean_is_scalar(x_130)) { + x_137 = lean_alloc_ctor(0, 6, 0); +} else { + x_137 = x_130; +} +lean_ctor_set(x_137, 0, x_125); +lean_ctor_set(x_137, 1, x_126); +lean_ctor_set(x_137, 2, x_136); +lean_ctor_set(x_137, 3, x_127); +lean_ctor_set(x_137, 4, x_128); +lean_ctor_set(x_137, 5, x_129); +if (lean_is_scalar(x_26)) { + x_138 = lean_alloc_ctor(1, 2, 0); +} else { + x_138 = x_26; + lean_ctor_set_tag(x_138, 1); +} +lean_ctor_set(x_138, 0, x_124); +lean_ctor_set(x_138, 1, x_137); +return x_138; +} +else +{ +lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_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; +x_139 = lean_ctor_get(x_122, 2); +lean_inc(x_139); +x_140 = lean_ctor_get(x_121, 0); +lean_inc(x_140); +lean_dec(x_121); +x_141 = lean_ctor_get(x_122, 0); +lean_inc(x_141); +x_142 = lean_ctor_get(x_122, 1); +lean_inc(x_142); +x_143 = lean_ctor_get(x_122, 3); +lean_inc(x_143); +x_144 = lean_ctor_get(x_122, 4); +lean_inc(x_144); +x_145 = lean_ctor_get(x_122, 5); +lean_inc(x_145); +if (lean_is_exclusive(x_122)) { + lean_ctor_release(x_122, 0); + lean_ctor_release(x_122, 1); + lean_ctor_release(x_122, 2); + lean_ctor_release(x_122, 3); + lean_ctor_release(x_122, 4); + lean_ctor_release(x_122, 5); + x_146 = x_122; +} else { + lean_dec_ref(x_122); + x_146 = lean_box(0); +} +x_147 = lean_ctor_get(x_139, 0); +lean_inc(x_147); +x_148 = lean_ctor_get(x_139, 1); +lean_inc(x_148); +x_149 = lean_ctor_get(x_139, 3); +lean_inc(x_149); +x_150 = lean_ctor_get(x_139, 4); +lean_inc(x_150); +if (lean_is_exclusive(x_139)) { + lean_ctor_release(x_139, 0); + lean_ctor_release(x_139, 1); + lean_ctor_release(x_139, 2); + lean_ctor_release(x_139, 3); + lean_ctor_release(x_139, 4); + x_151 = x_139; +} else { + lean_dec_ref(x_139); + x_151 = lean_box(0); +} +if (lean_is_scalar(x_151)) { + x_152 = lean_alloc_ctor(0, 5, 0); +} else { + x_152 = x_151; +} +lean_ctor_set(x_152, 0, x_147); +lean_ctor_set(x_152, 1, x_148); +lean_ctor_set(x_152, 2, x_118); +lean_ctor_set(x_152, 3, x_149); +lean_ctor_set(x_152, 4, x_150); +if (lean_is_scalar(x_146)) { + x_153 = lean_alloc_ctor(0, 6, 0); +} else { + x_153 = x_146; +} +lean_ctor_set(x_153, 0, x_141); +lean_ctor_set(x_153, 1, x_142); +lean_ctor_set(x_153, 2, x_152); +lean_ctor_set(x_153, 3, x_143); +lean_ctor_set(x_153, 4, x_144); +lean_ctor_set(x_153, 5, x_145); +if (lean_is_scalar(x_26)) { + x_154 = lean_alloc_ctor(0, 2, 0); +} else { + x_154 = x_26; +} +lean_ctor_set(x_154, 0, x_140); +lean_ctor_set(x_154, 1, x_153); +return x_154; +} +} +} +} +else +{ +lean_object* x_174; lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_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; lean_object* x_231; lean_object* x_232; lean_object* x_233; +x_174 = lean_ctor_get(x_25, 2); +x_175 = lean_ctor_get(x_25, 0); +x_176 = lean_ctor_get(x_25, 1); +x_177 = lean_ctor_get(x_25, 3); +x_178 = lean_ctor_get(x_25, 4); +x_179 = lean_ctor_get(x_25, 5); +lean_inc(x_179); +lean_inc(x_178); +lean_inc(x_177); +lean_inc(x_174); +lean_inc(x_176); +lean_inc(x_175); +lean_dec(x_25); +x_180 = lean_ctor_get(x_174, 0); +lean_inc(x_180); +x_181 = lean_ctor_get(x_174, 1); +lean_inc(x_181); +x_182 = lean_ctor_get(x_174, 2); +lean_inc(x_182); +x_183 = lean_ctor_get(x_174, 3); +lean_inc(x_183); +x_184 = lean_ctor_get(x_174, 4); +lean_inc(x_184); +if (lean_is_exclusive(x_174)) { + lean_ctor_release(x_174, 0); + lean_ctor_release(x_174, 1); + lean_ctor_release(x_174, 2); + lean_ctor_release(x_174, 3); + lean_ctor_release(x_174, 4); + x_185 = x_174; +} else { + lean_dec_ref(x_174); + x_185 = lean_box(0); +} +x_221 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_185)) { x_222 = lean_alloc_ctor(0, 5, 0); } else { - x_222 = x_219; + x_222 = x_185; } -lean_ctor_set(x_222, 0, x_214); -lean_ctor_set(x_222, 1, x_215); +lean_ctor_set(x_222, 0, x_180); +lean_ctor_set(x_222, 1, x_181); lean_ctor_set(x_222, 2, x_221); -lean_ctor_set(x_222, 3, x_217); -lean_ctor_set(x_222, 4, x_218); -x_223 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_222, x_213); -if (lean_obj_tag(x_223) == 0) -{ -lean_object* x_224; lean_object* x_225; lean_object* x_226; -x_224 = lean_ctor_get(x_223, 0); +lean_ctor_set(x_222, 3, x_183); +lean_ctor_set(x_222, 4, x_184); +x_223 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_223, 0, x_175); +lean_ctor_set(x_223, 1, x_176); +lean_ctor_set(x_223, 2, x_222); +lean_ctor_set(x_223, 3, x_177); +lean_ctor_set(x_223, 4, x_178); +lean_ctor_set(x_223, 5, x_179); +x_224 = lean_ctor_get(x_7, 0); lean_inc(x_224); -x_225 = lean_ctor_get(x_223, 1); +x_225 = lean_ctor_get(x_7, 1); lean_inc(x_225); -lean_dec(x_223); -x_226 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_226, 0, x_224); -x_178 = x_226; -x_179 = x_225; -goto block_210; -} -else -{ -lean_object* x_227; lean_object* x_228; lean_object* x_229; -x_227 = lean_ctor_get(x_223, 0); +x_226 = lean_ctor_get(x_7, 2); +lean_inc(x_226); +x_227 = lean_ctor_get(x_7, 3); lean_inc(x_227); -x_228 = lean_ctor_get(x_223, 1); +x_228 = lean_ctor_get(x_7, 4); lean_inc(x_228); -lean_dec(x_223); -x_229 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_229, 0, x_227); -x_178 = x_229; -x_179 = x_228; -goto block_210; +if (lean_is_exclusive(x_7)) { + lean_ctor_release(x_7, 0); + lean_ctor_release(x_7, 1); + lean_ctor_release(x_7, 2); + lean_ctor_release(x_7, 3); + lean_ctor_release(x_7, 4); + x_229 = x_7; +} else { + lean_dec_ref(x_7); + x_229 = lean_box(0); } -block_210: +x_230 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_230, 0, x_27); +lean_ctor_set(x_230, 1, x_14); +x_231 = lean_array_push(x_226, x_230); +if (lean_is_scalar(x_229)) { + x_232 = lean_alloc_ctor(0, 5, 0); +} else { + x_232 = x_229; +} +lean_ctor_set(x_232, 0, x_224); +lean_ctor_set(x_232, 1, x_225); +lean_ctor_set(x_232, 2, x_231); +lean_ctor_set(x_232, 3, x_227); +lean_ctor_set(x_232, 4, x_228); +x_233 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_232, x_223); +if (lean_obj_tag(x_233) == 0) { -if (lean_obj_tag(x_178) == 0) -{ -lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; -x_180 = lean_ctor_get(x_179, 2); -lean_inc(x_180); -x_181 = lean_ctor_get(x_178, 0); -lean_inc(x_181); -lean_dec(x_178); -x_182 = lean_ctor_get(x_179, 0); -lean_inc(x_182); -x_183 = lean_ctor_get(x_179, 1); -lean_inc(x_183); -x_184 = lean_ctor_get(x_179, 3); -lean_inc(x_184); -x_185 = lean_ctor_get(x_179, 4); -lean_inc(x_185); -x_186 = lean_ctor_get(x_179, 5); -lean_inc(x_186); -if (lean_is_exclusive(x_179)) { - lean_ctor_release(x_179, 0); - lean_ctor_release(x_179, 1); - lean_ctor_release(x_179, 2); - lean_ctor_release(x_179, 3); - lean_ctor_release(x_179, 4); - lean_ctor_release(x_179, 5); - x_187 = x_179; -} else { - lean_dec_ref(x_179); - x_187 = lean_box(0); -} -x_188 = lean_ctor_get(x_180, 0); -lean_inc(x_188); -x_189 = lean_ctor_get(x_180, 1); -lean_inc(x_189); -x_190 = lean_ctor_get(x_180, 3); -lean_inc(x_190); -if (lean_is_exclusive(x_180)) { - lean_ctor_release(x_180, 0); - lean_ctor_release(x_180, 1); - lean_ctor_release(x_180, 2); - lean_ctor_release(x_180, 3); - x_191 = x_180; -} else { - lean_dec_ref(x_180); - x_191 = lean_box(0); -} -if (lean_is_scalar(x_191)) { - x_192 = lean_alloc_ctor(0, 4, 0); -} else { - x_192 = x_191; -} -lean_ctor_set(x_192, 0, x_188); -lean_ctor_set(x_192, 1, x_189); -lean_ctor_set(x_192, 2, x_175); -lean_ctor_set(x_192, 3, x_190); -if (lean_is_scalar(x_187)) { - x_193 = lean_alloc_ctor(0, 6, 0); -} else { - x_193 = x_187; -} -lean_ctor_set(x_193, 0, x_182); -lean_ctor_set(x_193, 1, x_183); -lean_ctor_set(x_193, 2, x_192); -lean_ctor_set(x_193, 3, x_184); -lean_ctor_set(x_193, 4, x_185); -lean_ctor_set(x_193, 5, x_186); -if (lean_is_scalar(x_26)) { - x_194 = lean_alloc_ctor(1, 2, 0); -} else { - x_194 = x_26; - lean_ctor_set_tag(x_194, 1); -} -lean_ctor_set(x_194, 0, x_181); -lean_ctor_set(x_194, 1, x_193); -return x_194; +lean_object* x_234; lean_object* x_235; lean_object* x_236; +x_234 = lean_ctor_get(x_233, 0); +lean_inc(x_234); +x_235 = lean_ctor_get(x_233, 1); +lean_inc(x_235); +lean_dec(x_233); +x_236 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_236, 0, x_234); +x_186 = x_236; +x_187 = x_235; +goto block_220; } else { -lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; -x_195 = lean_ctor_get(x_179, 2); -lean_inc(x_195); -x_196 = lean_ctor_get(x_178, 0); +lean_object* x_237; lean_object* x_238; lean_object* x_239; +x_237 = lean_ctor_get(x_233, 0); +lean_inc(x_237); +x_238 = lean_ctor_get(x_233, 1); +lean_inc(x_238); +lean_dec(x_233); +x_239 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_239, 0, x_237); +x_186 = x_239; +x_187 = x_238; +goto block_220; +} +block_220: +{ +if (lean_obj_tag(x_186) == 0) +{ +lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; +x_188 = lean_ctor_get(x_187, 2); +lean_inc(x_188); +x_189 = lean_ctor_get(x_186, 0); +lean_inc(x_189); +lean_dec(x_186); +x_190 = lean_ctor_get(x_187, 0); +lean_inc(x_190); +x_191 = lean_ctor_get(x_187, 1); +lean_inc(x_191); +x_192 = lean_ctor_get(x_187, 3); +lean_inc(x_192); +x_193 = lean_ctor_get(x_187, 4); +lean_inc(x_193); +x_194 = lean_ctor_get(x_187, 5); +lean_inc(x_194); +if (lean_is_exclusive(x_187)) { + lean_ctor_release(x_187, 0); + lean_ctor_release(x_187, 1); + lean_ctor_release(x_187, 2); + lean_ctor_release(x_187, 3); + lean_ctor_release(x_187, 4); + lean_ctor_release(x_187, 5); + x_195 = x_187; +} else { + lean_dec_ref(x_187); + x_195 = lean_box(0); +} +x_196 = lean_ctor_get(x_188, 0); lean_inc(x_196); -lean_dec(x_178); -x_197 = lean_ctor_get(x_179, 0); +x_197 = lean_ctor_get(x_188, 1); lean_inc(x_197); -x_198 = lean_ctor_get(x_179, 1); +x_198 = lean_ctor_get(x_188, 3); lean_inc(x_198); -x_199 = lean_ctor_get(x_179, 3); +x_199 = lean_ctor_get(x_188, 4); lean_inc(x_199); -x_200 = lean_ctor_get(x_179, 4); -lean_inc(x_200); -x_201 = lean_ctor_get(x_179, 5); -lean_inc(x_201); -if (lean_is_exclusive(x_179)) { - lean_ctor_release(x_179, 0); - lean_ctor_release(x_179, 1); - lean_ctor_release(x_179, 2); - lean_ctor_release(x_179, 3); - lean_ctor_release(x_179, 4); - lean_ctor_release(x_179, 5); - x_202 = x_179; +if (lean_is_exclusive(x_188)) { + lean_ctor_release(x_188, 0); + lean_ctor_release(x_188, 1); + lean_ctor_release(x_188, 2); + lean_ctor_release(x_188, 3); + lean_ctor_release(x_188, 4); + x_200 = x_188; } else { - lean_dec_ref(x_179); - x_202 = lean_box(0); + lean_dec_ref(x_188); + x_200 = lean_box(0); } -x_203 = lean_ctor_get(x_195, 0); -lean_inc(x_203); -x_204 = lean_ctor_get(x_195, 1); -lean_inc(x_204); -x_205 = lean_ctor_get(x_195, 3); -lean_inc(x_205); -if (lean_is_exclusive(x_195)) { - lean_ctor_release(x_195, 0); - lean_ctor_release(x_195, 1); - lean_ctor_release(x_195, 2); - lean_ctor_release(x_195, 3); - x_206 = x_195; +if (lean_is_scalar(x_200)) { + x_201 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_195); - x_206 = lean_box(0); + x_201 = x_200; } -if (lean_is_scalar(x_206)) { - x_207 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_201, 0, x_196); +lean_ctor_set(x_201, 1, x_197); +lean_ctor_set(x_201, 2, x_182); +lean_ctor_set(x_201, 3, x_198); +lean_ctor_set(x_201, 4, x_199); +if (lean_is_scalar(x_195)) { + x_202 = lean_alloc_ctor(0, 6, 0); } else { - x_207 = x_206; + x_202 = x_195; } -lean_ctor_set(x_207, 0, x_203); -lean_ctor_set(x_207, 1, x_204); -lean_ctor_set(x_207, 2, x_175); -lean_ctor_set(x_207, 3, x_205); -if (lean_is_scalar(x_202)) { - x_208 = lean_alloc_ctor(0, 6, 0); -} else { - x_208 = x_202; -} -lean_ctor_set(x_208, 0, x_197); -lean_ctor_set(x_208, 1, x_198); -lean_ctor_set(x_208, 2, x_207); -lean_ctor_set(x_208, 3, x_199); -lean_ctor_set(x_208, 4, x_200); -lean_ctor_set(x_208, 5, x_201); +lean_ctor_set(x_202, 0, x_190); +lean_ctor_set(x_202, 1, x_191); +lean_ctor_set(x_202, 2, x_201); +lean_ctor_set(x_202, 3, x_192); +lean_ctor_set(x_202, 4, x_193); +lean_ctor_set(x_202, 5, x_194); if (lean_is_scalar(x_26)) { - x_209 = lean_alloc_ctor(0, 2, 0); + x_203 = lean_alloc_ctor(1, 2, 0); } else { - x_209 = x_26; + x_203 = x_26; + lean_ctor_set_tag(x_203, 1); } -lean_ctor_set(x_209, 0, x_196); -lean_ctor_set(x_209, 1, x_208); -return x_209; +lean_ctor_set(x_203, 0, x_189); +lean_ctor_set(x_203, 1, x_202); +return x_203; +} +else +{ +lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; +x_204 = lean_ctor_get(x_187, 2); +lean_inc(x_204); +x_205 = lean_ctor_get(x_186, 0); +lean_inc(x_205); +lean_dec(x_186); +x_206 = lean_ctor_get(x_187, 0); +lean_inc(x_206); +x_207 = lean_ctor_get(x_187, 1); +lean_inc(x_207); +x_208 = lean_ctor_get(x_187, 3); +lean_inc(x_208); +x_209 = lean_ctor_get(x_187, 4); +lean_inc(x_209); +x_210 = lean_ctor_get(x_187, 5); +lean_inc(x_210); +if (lean_is_exclusive(x_187)) { + lean_ctor_release(x_187, 0); + lean_ctor_release(x_187, 1); + lean_ctor_release(x_187, 2); + lean_ctor_release(x_187, 3); + lean_ctor_release(x_187, 4); + lean_ctor_release(x_187, 5); + x_211 = x_187; +} else { + lean_dec_ref(x_187); + x_211 = lean_box(0); +} +x_212 = lean_ctor_get(x_204, 0); +lean_inc(x_212); +x_213 = lean_ctor_get(x_204, 1); +lean_inc(x_213); +x_214 = lean_ctor_get(x_204, 3); +lean_inc(x_214); +x_215 = lean_ctor_get(x_204, 4); +lean_inc(x_215); +if (lean_is_exclusive(x_204)) { + lean_ctor_release(x_204, 0); + lean_ctor_release(x_204, 1); + lean_ctor_release(x_204, 2); + lean_ctor_release(x_204, 3); + lean_ctor_release(x_204, 4); + x_216 = x_204; +} else { + lean_dec_ref(x_204); + x_216 = lean_box(0); +} +if (lean_is_scalar(x_216)) { + x_217 = lean_alloc_ctor(0, 5, 0); +} else { + x_217 = x_216; +} +lean_ctor_set(x_217, 0, x_212); +lean_ctor_set(x_217, 1, x_213); +lean_ctor_set(x_217, 2, x_182); +lean_ctor_set(x_217, 3, x_214); +lean_ctor_set(x_217, 4, x_215); +if (lean_is_scalar(x_211)) { + x_218 = lean_alloc_ctor(0, 6, 0); +} else { + x_218 = x_211; +} +lean_ctor_set(x_218, 0, x_206); +lean_ctor_set(x_218, 1, x_207); +lean_ctor_set(x_218, 2, x_217); +lean_ctor_set(x_218, 3, x_208); +lean_ctor_set(x_218, 4, x_209); +lean_ctor_set(x_218, 5, x_210); +if (lean_is_scalar(x_26)) { + x_219 = lean_alloc_ctor(0, 2, 0); +} else { + x_219 = x_26; +} +lean_ctor_set(x_219, 0, x_205); +lean_ctor_set(x_219, 1, x_218); +return x_219; } } } } default: { -lean_object* x_230; lean_object* x_231; -x_230 = lean_ctor_get(x_19, 1); -lean_inc(x_230); +lean_object* x_240; lean_object* x_241; +x_240 = lean_ctor_get(x_19, 1); +lean_inc(x_240); lean_dec(x_19); lean_inc(x_7); -x_231 = l_Lean_Meta_isClassExpensive___main(x_18, x_7, x_230); -if (lean_obj_tag(x_231) == 0) +x_241 = l_Lean_Meta_isClassExpensive___main(x_18, x_7, x_240); +if (lean_obj_tag(x_241) == 0) { -lean_object* x_232; -x_232 = lean_ctor_get(x_231, 0); -lean_inc(x_232); -if (lean_obj_tag(x_232) == 0) +lean_object* x_242; +x_242 = lean_ctor_get(x_241, 0); +lean_inc(x_242); +if (lean_obj_tag(x_242) == 0) { -lean_object* x_233; lean_object* x_234; lean_object* x_235; +lean_object* x_243; lean_object* x_244; lean_object* x_245; lean_dec(x_14); -x_233 = lean_ctor_get(x_231, 1); -lean_inc(x_233); -lean_dec(x_231); -x_234 = lean_unsigned_to_nat(1u); -x_235 = lean_nat_add(x_6, x_234); +x_243 = lean_ctor_get(x_241, 1); +lean_inc(x_243); +lean_dec(x_241); +x_244 = lean_unsigned_to_nat(1u); +x_245 = lean_nat_add(x_6, x_244); lean_dec(x_6); -x_6 = x_235; -x_8 = x_233; +x_6 = x_245; +x_8 = x_243; goto _start; } else { -lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; uint8_t x_242; -x_237 = lean_ctor_get(x_231, 1); -lean_inc(x_237); -if (lean_is_exclusive(x_231)) { - lean_ctor_release(x_231, 0); - lean_ctor_release(x_231, 1); - x_238 = x_231; +lean_object* x_247; lean_object* x_248; lean_object* x_249; lean_object* x_250; lean_object* x_251; uint8_t x_252; +x_247 = lean_ctor_get(x_241, 1); +lean_inc(x_247); +if (lean_is_exclusive(x_241)) { + lean_ctor_release(x_241, 0); + lean_ctor_release(x_241, 1); + x_248 = x_241; } else { - lean_dec_ref(x_231); - x_238 = lean_box(0); + lean_dec_ref(x_241); + x_248 = lean_box(0); } -x_239 = lean_ctor_get(x_232, 0); -lean_inc(x_239); -lean_dec(x_232); -x_240 = lean_unsigned_to_nat(1u); -x_241 = lean_nat_add(x_6, x_240); -lean_dec(x_6); -x_242 = !lean_is_exclusive(x_237); -if (x_242 == 0) -{ -lean_object* x_243; uint8_t x_244; -x_243 = lean_ctor_get(x_237, 2); -x_244 = !lean_is_exclusive(x_243); -if (x_244 == 0) -{ -lean_object* x_245; lean_object* x_246; lean_object* x_247; lean_object* x_297; uint8_t x_298; -x_245 = lean_ctor_get(x_243, 2); -x_297 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_243, 2, x_297); -x_298 = !lean_is_exclusive(x_7); -if (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_7, 2); -x_300 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_300, 0, x_239); -lean_ctor_set(x_300, 1, x_14); -x_301 = lean_array_push(x_299, x_300); -lean_ctor_set(x_7, 2, x_301); -x_302 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_241, x_7, x_237); -if (lean_obj_tag(x_302) == 0) -{ -lean_object* x_303; lean_object* x_304; lean_object* x_305; -x_303 = lean_ctor_get(x_302, 0); -lean_inc(x_303); -x_304 = lean_ctor_get(x_302, 1); -lean_inc(x_304); -lean_dec(x_302); -x_305 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_305, 0, x_303); -x_246 = x_305; -x_247 = x_304; -goto block_296; -} -else -{ -lean_object* x_306; lean_object* x_307; lean_object* x_308; -x_306 = lean_ctor_get(x_302, 0); -lean_inc(x_306); -x_307 = lean_ctor_get(x_302, 1); -lean_inc(x_307); -lean_dec(x_302); -x_308 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_308, 0, x_306); -x_246 = x_308; -x_247 = x_307; -goto block_296; -} -} -else -{ -lean_object* x_309; lean_object* x_310; lean_object* x_311; lean_object* x_312; lean_object* x_313; lean_object* x_314; lean_object* x_315; lean_object* x_316; lean_object* x_317; -x_309 = lean_ctor_get(x_7, 0); -x_310 = lean_ctor_get(x_7, 1); -x_311 = lean_ctor_get(x_7, 2); -x_312 = lean_ctor_get(x_7, 3); -x_313 = lean_ctor_get(x_7, 4); -lean_inc(x_313); -lean_inc(x_312); -lean_inc(x_311); -lean_inc(x_310); -lean_inc(x_309); -lean_dec(x_7); -x_314 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_314, 0, x_239); -lean_ctor_set(x_314, 1, x_14); -x_315 = lean_array_push(x_311, x_314); -x_316 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_316, 0, x_309); -lean_ctor_set(x_316, 1, x_310); -lean_ctor_set(x_316, 2, x_315); -lean_ctor_set(x_316, 3, x_312); -lean_ctor_set(x_316, 4, x_313); -x_317 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_241, x_316, x_237); -if (lean_obj_tag(x_317) == 0) -{ -lean_object* x_318; lean_object* x_319; lean_object* x_320; -x_318 = lean_ctor_get(x_317, 0); -lean_inc(x_318); -x_319 = lean_ctor_get(x_317, 1); -lean_inc(x_319); -lean_dec(x_317); -x_320 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_320, 0, x_318); -x_246 = x_320; -x_247 = x_319; -goto block_296; -} -else -{ -lean_object* x_321; lean_object* x_322; lean_object* x_323; -x_321 = lean_ctor_get(x_317, 0); -lean_inc(x_321); -x_322 = lean_ctor_get(x_317, 1); -lean_inc(x_322); -lean_dec(x_317); -x_323 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_323, 0, x_321); -x_246 = x_323; -x_247 = x_322; -goto block_296; -} -} -block_296: -{ -if (lean_obj_tag(x_246) == 0) -{ -lean_object* x_248; lean_object* x_249; uint8_t x_250; -x_248 = lean_ctor_get(x_247, 2); -lean_inc(x_248); -x_249 = lean_ctor_get(x_246, 0); +x_249 = lean_ctor_get(x_242, 0); lean_inc(x_249); -lean_dec(x_246); -x_250 = !lean_is_exclusive(x_247); -if (x_250 == 0) -{ -lean_object* x_251; uint8_t x_252; -x_251 = lean_ctor_get(x_247, 2); -lean_dec(x_251); -x_252 = !lean_is_exclusive(x_248); +lean_dec(x_242); +x_250 = lean_unsigned_to_nat(1u); +x_251 = lean_nat_add(x_6, x_250); +lean_dec(x_6); +x_252 = !lean_is_exclusive(x_247); if (x_252 == 0) { -lean_object* x_253; lean_object* x_254; -x_253 = lean_ctor_get(x_248, 2); -lean_dec(x_253); -lean_ctor_set(x_248, 2, x_245); -if (lean_is_scalar(x_238)) { - x_254 = lean_alloc_ctor(1, 2, 0); -} else { - x_254 = x_238; - lean_ctor_set_tag(x_254, 1); -} -lean_ctor_set(x_254, 0, x_249); -lean_ctor_set(x_254, 1, x_247); -return x_254; +lean_object* x_253; uint8_t x_254; +x_253 = lean_ctor_get(x_247, 2); +x_254 = !lean_is_exclusive(x_253); +if (x_254 == 0) +{ +lean_object* x_255; lean_object* x_256; lean_object* x_257; lean_object* x_311; uint8_t x_312; +x_255 = lean_ctor_get(x_253, 2); +x_311 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_253, 2, x_311); +x_312 = !lean_is_exclusive(x_7); +if (x_312 == 0) +{ +lean_object* x_313; lean_object* x_314; lean_object* x_315; lean_object* x_316; +x_313 = lean_ctor_get(x_7, 2); +x_314 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_314, 0, x_249); +lean_ctor_set(x_314, 1, x_14); +x_315 = lean_array_push(x_313, x_314); +lean_ctor_set(x_7, 2, x_315); +x_316 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_251, x_7, x_247); +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); +x_319 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_319, 0, x_317); +x_256 = x_319; +x_257 = x_318; +goto block_310; } else { -lean_object* x_255; lean_object* x_256; lean_object* x_257; lean_object* x_258; lean_object* x_259; -x_255 = lean_ctor_get(x_248, 0); -x_256 = lean_ctor_get(x_248, 1); -x_257 = lean_ctor_get(x_248, 3); -lean_inc(x_257); -lean_inc(x_256); -lean_inc(x_255); -lean_dec(x_248); -x_258 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_258, 0, x_255); -lean_ctor_set(x_258, 1, x_256); -lean_ctor_set(x_258, 2, x_245); -lean_ctor_set(x_258, 3, x_257); -lean_ctor_set(x_247, 2, x_258); -if (lean_is_scalar(x_238)) { - x_259 = lean_alloc_ctor(1, 2, 0); -} else { - x_259 = x_238; - lean_ctor_set_tag(x_259, 1); -} -lean_ctor_set(x_259, 0, x_249); -lean_ctor_set(x_259, 1, x_247); -return x_259; +lean_object* x_320; lean_object* x_321; lean_object* x_322; +x_320 = lean_ctor_get(x_316, 0); +lean_inc(x_320); +x_321 = lean_ctor_get(x_316, 1); +lean_inc(x_321); +lean_dec(x_316); +x_322 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_322, 0, x_320); +x_256 = x_322; +x_257 = x_321; +goto block_310; } } else { -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_260 = lean_ctor_get(x_247, 0); -x_261 = lean_ctor_get(x_247, 1); -x_262 = lean_ctor_get(x_247, 3); -x_263 = lean_ctor_get(x_247, 4); -x_264 = lean_ctor_get(x_247, 5); -lean_inc(x_264); -lean_inc(x_263); -lean_inc(x_262); -lean_inc(x_261); -lean_inc(x_260); -lean_dec(x_247); -x_265 = lean_ctor_get(x_248, 0); -lean_inc(x_265); -x_266 = lean_ctor_get(x_248, 1); -lean_inc(x_266); -x_267 = lean_ctor_get(x_248, 3); +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; +x_323 = lean_ctor_get(x_7, 0); +x_324 = lean_ctor_get(x_7, 1); +x_325 = lean_ctor_get(x_7, 2); +x_326 = lean_ctor_get(x_7, 3); +x_327 = lean_ctor_get(x_7, 4); +lean_inc(x_327); +lean_inc(x_326); +lean_inc(x_325); +lean_inc(x_324); +lean_inc(x_323); +lean_dec(x_7); +x_328 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_328, 0, x_249); +lean_ctor_set(x_328, 1, x_14); +x_329 = lean_array_push(x_325, x_328); +x_330 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_330, 0, x_323); +lean_ctor_set(x_330, 1, x_324); +lean_ctor_set(x_330, 2, x_329); +lean_ctor_set(x_330, 3, x_326); +lean_ctor_set(x_330, 4, x_327); +x_331 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_251, x_330, x_247); +if (lean_obj_tag(x_331) == 0) +{ +lean_object* x_332; lean_object* x_333; lean_object* x_334; +x_332 = lean_ctor_get(x_331, 0); +lean_inc(x_332); +x_333 = lean_ctor_get(x_331, 1); +lean_inc(x_333); +lean_dec(x_331); +x_334 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_334, 0, x_332); +x_256 = x_334; +x_257 = x_333; +goto block_310; +} +else +{ +lean_object* x_335; lean_object* x_336; lean_object* x_337; +x_335 = lean_ctor_get(x_331, 0); +lean_inc(x_335); +x_336 = lean_ctor_get(x_331, 1); +lean_inc(x_336); +lean_dec(x_331); +x_337 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_337, 0, x_335); +x_256 = x_337; +x_257 = x_336; +goto block_310; +} +} +block_310: +{ +if (lean_obj_tag(x_256) == 0) +{ +lean_object* x_258; lean_object* x_259; uint8_t x_260; +x_258 = lean_ctor_get(x_257, 2); +lean_inc(x_258); +x_259 = lean_ctor_get(x_256, 0); +lean_inc(x_259); +lean_dec(x_256); +x_260 = !lean_is_exclusive(x_257); +if (x_260 == 0) +{ +lean_object* x_261; uint8_t x_262; +x_261 = lean_ctor_get(x_257, 2); +lean_dec(x_261); +x_262 = !lean_is_exclusive(x_258); +if (x_262 == 0) +{ +lean_object* x_263; lean_object* x_264; +x_263 = lean_ctor_get(x_258, 2); +lean_dec(x_263); +lean_ctor_set(x_258, 2, x_255); +if (lean_is_scalar(x_248)) { + x_264 = lean_alloc_ctor(1, 2, 0); +} else { + x_264 = x_248; + lean_ctor_set_tag(x_264, 1); +} +lean_ctor_set(x_264, 0, x_259); +lean_ctor_set(x_264, 1, x_257); +return x_264; +} +else +{ +lean_object* x_265; lean_object* x_266; lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_object* x_270; +x_265 = lean_ctor_get(x_258, 0); +x_266 = lean_ctor_get(x_258, 1); +x_267 = lean_ctor_get(x_258, 3); +x_268 = lean_ctor_get(x_258, 4); +lean_inc(x_268); lean_inc(x_267); -if (lean_is_exclusive(x_248)) { - lean_ctor_release(x_248, 0); - lean_ctor_release(x_248, 1); - lean_ctor_release(x_248, 2); - lean_ctor_release(x_248, 3); - x_268 = x_248; -} else { - lean_dec_ref(x_248); - x_268 = lean_box(0); -} -if (lean_is_scalar(x_268)) { - x_269 = lean_alloc_ctor(0, 4, 0); -} else { - x_269 = x_268; -} +lean_inc(x_266); +lean_inc(x_265); +lean_dec(x_258); +x_269 = lean_alloc_ctor(0, 5, 0); lean_ctor_set(x_269, 0, x_265); lean_ctor_set(x_269, 1, x_266); -lean_ctor_set(x_269, 2, x_245); +lean_ctor_set(x_269, 2, x_255); lean_ctor_set(x_269, 3, x_267); -x_270 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_270, 0, x_260); -lean_ctor_set(x_270, 1, x_261); -lean_ctor_set(x_270, 2, x_269); -lean_ctor_set(x_270, 3, x_262); -lean_ctor_set(x_270, 4, x_263); -lean_ctor_set(x_270, 5, x_264); -if (lean_is_scalar(x_238)) { - x_271 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_269, 4, x_268); +lean_ctor_set(x_257, 2, x_269); +if (lean_is_scalar(x_248)) { + x_270 = lean_alloc_ctor(1, 2, 0); } else { - x_271 = x_238; - lean_ctor_set_tag(x_271, 1); + x_270 = x_248; + lean_ctor_set_tag(x_270, 1); } -lean_ctor_set(x_271, 0, x_249); -lean_ctor_set(x_271, 1, x_270); -return x_271; +lean_ctor_set(x_270, 0, x_259); +lean_ctor_set(x_270, 1, x_257); +return x_270; } } else { -lean_object* x_272; lean_object* x_273; uint8_t x_274; -x_272 = lean_ctor_get(x_247, 2); -lean_inc(x_272); -x_273 = lean_ctor_get(x_246, 0); +lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_object* x_276; lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; lean_object* x_281; lean_object* x_282; lean_object* x_283; +x_271 = lean_ctor_get(x_257, 0); +x_272 = lean_ctor_get(x_257, 1); +x_273 = lean_ctor_get(x_257, 3); +x_274 = lean_ctor_get(x_257, 4); +x_275 = lean_ctor_get(x_257, 5); +lean_inc(x_275); +lean_inc(x_274); lean_inc(x_273); -lean_dec(x_246); -x_274 = !lean_is_exclusive(x_247); -if (x_274 == 0) -{ -lean_object* x_275; uint8_t x_276; -x_275 = lean_ctor_get(x_247, 2); -lean_dec(x_275); -x_276 = !lean_is_exclusive(x_272); -if (x_276 == 0) -{ -lean_object* x_277; lean_object* x_278; -x_277 = lean_ctor_get(x_272, 2); -lean_dec(x_277); -lean_ctor_set(x_272, 2, x_245); -if (lean_is_scalar(x_238)) { - x_278 = lean_alloc_ctor(0, 2, 0); -} else { - x_278 = x_238; -} -lean_ctor_set(x_278, 0, x_273); -lean_ctor_set(x_278, 1, x_247); -return x_278; -} -else -{ -lean_object* x_279; lean_object* x_280; lean_object* x_281; lean_object* x_282; lean_object* x_283; -x_279 = lean_ctor_get(x_272, 0); -x_280 = lean_ctor_get(x_272, 1); -x_281 = lean_ctor_get(x_272, 3); -lean_inc(x_281); -lean_inc(x_280); +lean_inc(x_272); +lean_inc(x_271); +lean_dec(x_257); +x_276 = lean_ctor_get(x_258, 0); +lean_inc(x_276); +x_277 = lean_ctor_get(x_258, 1); +lean_inc(x_277); +x_278 = lean_ctor_get(x_258, 3); +lean_inc(x_278); +x_279 = lean_ctor_get(x_258, 4); lean_inc(x_279); -lean_dec(x_272); -x_282 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_282, 0, x_279); -lean_ctor_set(x_282, 1, x_280); -lean_ctor_set(x_282, 2, x_245); -lean_ctor_set(x_282, 3, x_281); -lean_ctor_set(x_247, 2, x_282); -if (lean_is_scalar(x_238)) { - x_283 = lean_alloc_ctor(0, 2, 0); +if (lean_is_exclusive(x_258)) { + lean_ctor_release(x_258, 0); + lean_ctor_release(x_258, 1); + lean_ctor_release(x_258, 2); + lean_ctor_release(x_258, 3); + lean_ctor_release(x_258, 4); + x_280 = x_258; } else { - x_283 = x_238; + lean_dec_ref(x_258); + x_280 = lean_box(0); } -lean_ctor_set(x_283, 0, x_273); -lean_ctor_set(x_283, 1, x_247); +if (lean_is_scalar(x_280)) { + x_281 = lean_alloc_ctor(0, 5, 0); +} else { + x_281 = x_280; +} +lean_ctor_set(x_281, 0, x_276); +lean_ctor_set(x_281, 1, x_277); +lean_ctor_set(x_281, 2, x_255); +lean_ctor_set(x_281, 3, x_278); +lean_ctor_set(x_281, 4, x_279); +x_282 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_282, 0, x_271); +lean_ctor_set(x_282, 1, x_272); +lean_ctor_set(x_282, 2, x_281); +lean_ctor_set(x_282, 3, x_273); +lean_ctor_set(x_282, 4, x_274); +lean_ctor_set(x_282, 5, x_275); +if (lean_is_scalar(x_248)) { + x_283 = lean_alloc_ctor(1, 2, 0); +} else { + x_283 = x_248; + lean_ctor_set_tag(x_283, 1); +} +lean_ctor_set(x_283, 0, x_259); +lean_ctor_set(x_283, 1, x_282); return x_283; } } else { -lean_object* x_284; lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; lean_object* x_289; lean_object* x_290; lean_object* x_291; lean_object* x_292; lean_object* x_293; lean_object* x_294; lean_object* x_295; -x_284 = lean_ctor_get(x_247, 0); -x_285 = lean_ctor_get(x_247, 1); -x_286 = lean_ctor_get(x_247, 3); -x_287 = lean_ctor_get(x_247, 4); -x_288 = lean_ctor_get(x_247, 5); -lean_inc(x_288); -lean_inc(x_287); -lean_inc(x_286); -lean_inc(x_285); +lean_object* x_284; lean_object* x_285; uint8_t x_286; +x_284 = lean_ctor_get(x_257, 2); lean_inc(x_284); -lean_dec(x_247); -x_289 = lean_ctor_get(x_272, 0); -lean_inc(x_289); -x_290 = lean_ctor_get(x_272, 1); -lean_inc(x_290); -x_291 = lean_ctor_get(x_272, 3); +x_285 = lean_ctor_get(x_256, 0); +lean_inc(x_285); +lean_dec(x_256); +x_286 = !lean_is_exclusive(x_257); +if (x_286 == 0) +{ +lean_object* x_287; uint8_t x_288; +x_287 = lean_ctor_get(x_257, 2); +lean_dec(x_287); +x_288 = !lean_is_exclusive(x_284); +if (x_288 == 0) +{ +lean_object* x_289; lean_object* x_290; +x_289 = lean_ctor_get(x_284, 2); +lean_dec(x_289); +lean_ctor_set(x_284, 2, x_255); +if (lean_is_scalar(x_248)) { + x_290 = lean_alloc_ctor(0, 2, 0); +} else { + x_290 = x_248; +} +lean_ctor_set(x_290, 0, x_285); +lean_ctor_set(x_290, 1, x_257); +return x_290; +} +else +{ +lean_object* x_291; lean_object* x_292; lean_object* x_293; lean_object* x_294; lean_object* x_295; lean_object* x_296; +x_291 = lean_ctor_get(x_284, 0); +x_292 = lean_ctor_get(x_284, 1); +x_293 = lean_ctor_get(x_284, 3); +x_294 = lean_ctor_get(x_284, 4); +lean_inc(x_294); +lean_inc(x_293); +lean_inc(x_292); lean_inc(x_291); -if (lean_is_exclusive(x_272)) { - lean_ctor_release(x_272, 0); - lean_ctor_release(x_272, 1); - lean_ctor_release(x_272, 2); - lean_ctor_release(x_272, 3); - x_292 = x_272; +lean_dec(x_284); +x_295 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_295, 0, x_291); +lean_ctor_set(x_295, 1, x_292); +lean_ctor_set(x_295, 2, x_255); +lean_ctor_set(x_295, 3, x_293); +lean_ctor_set(x_295, 4, x_294); +lean_ctor_set(x_257, 2, x_295); +if (lean_is_scalar(x_248)) { + x_296 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_272); - x_292 = lean_box(0); + x_296 = x_248; } -if (lean_is_scalar(x_292)) { - x_293 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_296, 0, x_285); +lean_ctor_set(x_296, 1, x_257); +return x_296; +} +} +else +{ +lean_object* x_297; lean_object* x_298; lean_object* x_299; lean_object* x_300; lean_object* x_301; lean_object* x_302; lean_object* x_303; lean_object* x_304; lean_object* x_305; lean_object* x_306; lean_object* x_307; lean_object* x_308; lean_object* x_309; +x_297 = lean_ctor_get(x_257, 0); +x_298 = lean_ctor_get(x_257, 1); +x_299 = lean_ctor_get(x_257, 3); +x_300 = lean_ctor_get(x_257, 4); +x_301 = lean_ctor_get(x_257, 5); +lean_inc(x_301); +lean_inc(x_300); +lean_inc(x_299); +lean_inc(x_298); +lean_inc(x_297); +lean_dec(x_257); +x_302 = lean_ctor_get(x_284, 0); +lean_inc(x_302); +x_303 = lean_ctor_get(x_284, 1); +lean_inc(x_303); +x_304 = lean_ctor_get(x_284, 3); +lean_inc(x_304); +x_305 = lean_ctor_get(x_284, 4); +lean_inc(x_305); +if (lean_is_exclusive(x_284)) { + lean_ctor_release(x_284, 0); + lean_ctor_release(x_284, 1); + lean_ctor_release(x_284, 2); + lean_ctor_release(x_284, 3); + lean_ctor_release(x_284, 4); + x_306 = x_284; } else { - x_293 = x_292; + lean_dec_ref(x_284); + x_306 = lean_box(0); } -lean_ctor_set(x_293, 0, x_289); -lean_ctor_set(x_293, 1, x_290); -lean_ctor_set(x_293, 2, x_245); -lean_ctor_set(x_293, 3, x_291); -x_294 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_294, 0, x_284); -lean_ctor_set(x_294, 1, x_285); -lean_ctor_set(x_294, 2, x_293); -lean_ctor_set(x_294, 3, x_286); -lean_ctor_set(x_294, 4, x_287); -lean_ctor_set(x_294, 5, x_288); -if (lean_is_scalar(x_238)) { - x_295 = lean_alloc_ctor(0, 2, 0); +if (lean_is_scalar(x_306)) { + x_307 = lean_alloc_ctor(0, 5, 0); } else { - x_295 = x_238; + x_307 = x_306; } -lean_ctor_set(x_295, 0, x_273); -lean_ctor_set(x_295, 1, x_294); -return x_295; +lean_ctor_set(x_307, 0, x_302); +lean_ctor_set(x_307, 1, x_303); +lean_ctor_set(x_307, 2, x_255); +lean_ctor_set(x_307, 3, x_304); +lean_ctor_set(x_307, 4, x_305); +x_308 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_308, 0, x_297); +lean_ctor_set(x_308, 1, x_298); +lean_ctor_set(x_308, 2, x_307); +lean_ctor_set(x_308, 3, x_299); +lean_ctor_set(x_308, 4, x_300); +lean_ctor_set(x_308, 5, x_301); +if (lean_is_scalar(x_248)) { + x_309 = lean_alloc_ctor(0, 2, 0); +} else { + x_309 = x_248; +} +lean_ctor_set(x_309, 0, x_285); +lean_ctor_set(x_309, 1, x_308); +return x_309; } } } } else { -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_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; -x_324 = lean_ctor_get(x_243, 0); -x_325 = lean_ctor_get(x_243, 1); -x_326 = lean_ctor_get(x_243, 2); -x_327 = lean_ctor_get(x_243, 3); -lean_inc(x_327); -lean_inc(x_326); -lean_inc(x_325); -lean_inc(x_324); -lean_dec(x_243); -x_361 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_362 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_362, 0, x_324); -lean_ctor_set(x_362, 1, x_325); -lean_ctor_set(x_362, 2, x_361); -lean_ctor_set(x_362, 3, x_327); -lean_ctor_set(x_237, 2, x_362); -x_363 = lean_ctor_get(x_7, 0); -lean_inc(x_363); -x_364 = lean_ctor_get(x_7, 1); -lean_inc(x_364); -x_365 = lean_ctor_get(x_7, 2); -lean_inc(x_365); -x_366 = lean_ctor_get(x_7, 3); -lean_inc(x_366); -x_367 = lean_ctor_get(x_7, 4); -lean_inc(x_367); +lean_object* x_338; lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; lean_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; +x_338 = lean_ctor_get(x_253, 0); +x_339 = lean_ctor_get(x_253, 1); +x_340 = lean_ctor_get(x_253, 2); +x_341 = lean_ctor_get(x_253, 3); +x_342 = lean_ctor_get(x_253, 4); +lean_inc(x_342); +lean_inc(x_341); +lean_inc(x_340); +lean_inc(x_339); +lean_inc(x_338); +lean_dec(x_253); +x_378 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_379 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_379, 0, x_338); +lean_ctor_set(x_379, 1, x_339); +lean_ctor_set(x_379, 2, x_378); +lean_ctor_set(x_379, 3, x_341); +lean_ctor_set(x_379, 4, x_342); +lean_ctor_set(x_247, 2, x_379); +x_380 = lean_ctor_get(x_7, 0); +lean_inc(x_380); +x_381 = lean_ctor_get(x_7, 1); +lean_inc(x_381); +x_382 = lean_ctor_get(x_7, 2); +lean_inc(x_382); +x_383 = lean_ctor_get(x_7, 3); +lean_inc(x_383); +x_384 = lean_ctor_get(x_7, 4); +lean_inc(x_384); if (lean_is_exclusive(x_7)) { lean_ctor_release(x_7, 0); lean_ctor_release(x_7, 1); lean_ctor_release(x_7, 2); lean_ctor_release(x_7, 3); lean_ctor_release(x_7, 4); - x_368 = x_7; + x_385 = x_7; } else { lean_dec_ref(x_7); - x_368 = lean_box(0); + x_385 = lean_box(0); } -x_369 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_369, 0, x_239); -lean_ctor_set(x_369, 1, x_14); -x_370 = lean_array_push(x_365, x_369); -if (lean_is_scalar(x_368)) { - x_371 = lean_alloc_ctor(0, 5, 0); +x_386 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_386, 0, x_249); +lean_ctor_set(x_386, 1, x_14); +x_387 = lean_array_push(x_382, x_386); +if (lean_is_scalar(x_385)) { + x_388 = lean_alloc_ctor(0, 5, 0); } else { - x_371 = x_368; + x_388 = x_385; } -lean_ctor_set(x_371, 0, x_363); -lean_ctor_set(x_371, 1, x_364); -lean_ctor_set(x_371, 2, x_370); -lean_ctor_set(x_371, 3, x_366); -lean_ctor_set(x_371, 4, x_367); -x_372 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_241, x_371, x_237); -if (lean_obj_tag(x_372) == 0) +lean_ctor_set(x_388, 0, x_380); +lean_ctor_set(x_388, 1, x_381); +lean_ctor_set(x_388, 2, x_387); +lean_ctor_set(x_388, 3, x_383); +lean_ctor_set(x_388, 4, x_384); +x_389 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_251, x_388, x_247); +if (lean_obj_tag(x_389) == 0) { -lean_object* x_373; lean_object* x_374; lean_object* x_375; -x_373 = lean_ctor_get(x_372, 0); -lean_inc(x_373); -x_374 = lean_ctor_get(x_372, 1); -lean_inc(x_374); -lean_dec(x_372); -x_375 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_375, 0, x_373); -x_328 = x_375; -x_329 = x_374; -goto block_360; +lean_object* x_390; lean_object* x_391; lean_object* x_392; +x_390 = lean_ctor_get(x_389, 0); +lean_inc(x_390); +x_391 = lean_ctor_get(x_389, 1); +lean_inc(x_391); +lean_dec(x_389); +x_392 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_392, 0, x_390); +x_343 = x_392; +x_344 = x_391; +goto block_377; } else { -lean_object* x_376; lean_object* x_377; lean_object* x_378; -x_376 = lean_ctor_get(x_372, 0); -lean_inc(x_376); -x_377 = lean_ctor_get(x_372, 1); -lean_inc(x_377); -lean_dec(x_372); -x_378 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_378, 0, x_376); -x_328 = x_378; -x_329 = x_377; -goto block_360; +lean_object* x_393; lean_object* x_394; lean_object* x_395; +x_393 = lean_ctor_get(x_389, 0); +lean_inc(x_393); +x_394 = lean_ctor_get(x_389, 1); +lean_inc(x_394); +lean_dec(x_389); +x_395 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_395, 0, x_393); +x_343 = x_395; +x_344 = x_394; +goto block_377; } -block_360: +block_377: { -if (lean_obj_tag(x_328) == 0) +if (lean_obj_tag(x_343) == 0) { -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; lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; -x_330 = lean_ctor_get(x_329, 2); -lean_inc(x_330); -x_331 = lean_ctor_get(x_328, 0); -lean_inc(x_331); -lean_dec(x_328); -x_332 = lean_ctor_get(x_329, 0); -lean_inc(x_332); -x_333 = lean_ctor_get(x_329, 1); -lean_inc(x_333); -x_334 = lean_ctor_get(x_329, 3); -lean_inc(x_334); -x_335 = lean_ctor_get(x_329, 4); -lean_inc(x_335); -x_336 = lean_ctor_get(x_329, 5); -lean_inc(x_336); -if (lean_is_exclusive(x_329)) { - lean_ctor_release(x_329, 0); - lean_ctor_release(x_329, 1); - lean_ctor_release(x_329, 2); - lean_ctor_release(x_329, 3); - lean_ctor_release(x_329, 4); - lean_ctor_release(x_329, 5); - x_337 = x_329; -} else { - lean_dec_ref(x_329); - x_337 = lean_box(0); -} -x_338 = lean_ctor_get(x_330, 0); -lean_inc(x_338); -x_339 = lean_ctor_get(x_330, 1); -lean_inc(x_339); -x_340 = lean_ctor_get(x_330, 3); -lean_inc(x_340); -if (lean_is_exclusive(x_330)) { - lean_ctor_release(x_330, 0); - lean_ctor_release(x_330, 1); - lean_ctor_release(x_330, 2); - lean_ctor_release(x_330, 3); - x_341 = x_330; -} else { - lean_dec_ref(x_330); - x_341 = lean_box(0); -} -if (lean_is_scalar(x_341)) { - x_342 = lean_alloc_ctor(0, 4, 0); -} else { - x_342 = x_341; -} -lean_ctor_set(x_342, 0, x_338); -lean_ctor_set(x_342, 1, x_339); -lean_ctor_set(x_342, 2, x_326); -lean_ctor_set(x_342, 3, x_340); -if (lean_is_scalar(x_337)) { - x_343 = lean_alloc_ctor(0, 6, 0); -} else { - x_343 = x_337; -} -lean_ctor_set(x_343, 0, x_332); -lean_ctor_set(x_343, 1, x_333); -lean_ctor_set(x_343, 2, x_342); -lean_ctor_set(x_343, 3, x_334); -lean_ctor_set(x_343, 4, x_335); -lean_ctor_set(x_343, 5, x_336); -if (lean_is_scalar(x_238)) { - x_344 = lean_alloc_ctor(1, 2, 0); -} else { - x_344 = x_238; - lean_ctor_set_tag(x_344, 1); -} -lean_ctor_set(x_344, 0, x_331); -lean_ctor_set(x_344, 1, x_343); -return x_344; -} -else -{ -lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; lean_object* x_350; lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; lean_object* x_358; lean_object* x_359; -x_345 = lean_ctor_get(x_329, 2); +lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; lean_object* x_350; lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; lean_object* x_358; lean_object* x_359; lean_object* x_360; +x_345 = lean_ctor_get(x_344, 2); lean_inc(x_345); -x_346 = lean_ctor_get(x_328, 0); +x_346 = lean_ctor_get(x_343, 0); lean_inc(x_346); -lean_dec(x_328); -x_347 = lean_ctor_get(x_329, 0); +lean_dec(x_343); +x_347 = lean_ctor_get(x_344, 0); lean_inc(x_347); -x_348 = lean_ctor_get(x_329, 1); +x_348 = lean_ctor_get(x_344, 1); lean_inc(x_348); -x_349 = lean_ctor_get(x_329, 3); +x_349 = lean_ctor_get(x_344, 3); lean_inc(x_349); -x_350 = lean_ctor_get(x_329, 4); +x_350 = lean_ctor_get(x_344, 4); lean_inc(x_350); -x_351 = lean_ctor_get(x_329, 5); +x_351 = lean_ctor_get(x_344, 5); lean_inc(x_351); -if (lean_is_exclusive(x_329)) { - lean_ctor_release(x_329, 0); - lean_ctor_release(x_329, 1); - lean_ctor_release(x_329, 2); - lean_ctor_release(x_329, 3); - lean_ctor_release(x_329, 4); - lean_ctor_release(x_329, 5); - x_352 = x_329; +if (lean_is_exclusive(x_344)) { + lean_ctor_release(x_344, 0); + lean_ctor_release(x_344, 1); + lean_ctor_release(x_344, 2); + lean_ctor_release(x_344, 3); + lean_ctor_release(x_344, 4); + lean_ctor_release(x_344, 5); + x_352 = x_344; } else { - lean_dec_ref(x_329); + lean_dec_ref(x_344); x_352 = lean_box(0); } x_353 = lean_ctor_get(x_345, 0); @@ -22688,315 +23290,411 @@ x_354 = lean_ctor_get(x_345, 1); lean_inc(x_354); x_355 = lean_ctor_get(x_345, 3); lean_inc(x_355); +x_356 = lean_ctor_get(x_345, 4); +lean_inc(x_356); if (lean_is_exclusive(x_345)) { lean_ctor_release(x_345, 0); lean_ctor_release(x_345, 1); lean_ctor_release(x_345, 2); lean_ctor_release(x_345, 3); - x_356 = x_345; + lean_ctor_release(x_345, 4); + x_357 = x_345; } else { lean_dec_ref(x_345); - x_356 = lean_box(0); + x_357 = lean_box(0); } -if (lean_is_scalar(x_356)) { - x_357 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_357)) { + x_358 = lean_alloc_ctor(0, 5, 0); } else { - x_357 = x_356; + x_358 = x_357; } -lean_ctor_set(x_357, 0, x_353); -lean_ctor_set(x_357, 1, x_354); -lean_ctor_set(x_357, 2, x_326); -lean_ctor_set(x_357, 3, x_355); +lean_ctor_set(x_358, 0, x_353); +lean_ctor_set(x_358, 1, x_354); +lean_ctor_set(x_358, 2, x_340); +lean_ctor_set(x_358, 3, x_355); +lean_ctor_set(x_358, 4, x_356); if (lean_is_scalar(x_352)) { - x_358 = lean_alloc_ctor(0, 6, 0); + x_359 = lean_alloc_ctor(0, 6, 0); } else { - x_358 = x_352; + x_359 = x_352; } -lean_ctor_set(x_358, 0, x_347); -lean_ctor_set(x_358, 1, x_348); -lean_ctor_set(x_358, 2, x_357); -lean_ctor_set(x_358, 3, x_349); -lean_ctor_set(x_358, 4, x_350); -lean_ctor_set(x_358, 5, x_351); -if (lean_is_scalar(x_238)) { - x_359 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_359, 0, x_347); +lean_ctor_set(x_359, 1, x_348); +lean_ctor_set(x_359, 2, x_358); +lean_ctor_set(x_359, 3, x_349); +lean_ctor_set(x_359, 4, x_350); +lean_ctor_set(x_359, 5, x_351); +if (lean_is_scalar(x_248)) { + x_360 = lean_alloc_ctor(1, 2, 0); } else { - x_359 = x_238; + x_360 = x_248; + lean_ctor_set_tag(x_360, 1); } -lean_ctor_set(x_359, 0, x_346); -lean_ctor_set(x_359, 1, x_358); -return x_359; +lean_ctor_set(x_360, 0, x_346); +lean_ctor_set(x_360, 1, x_359); +return x_360; +} +else +{ +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; lean_object* x_374; lean_object* x_375; lean_object* x_376; +x_361 = lean_ctor_get(x_344, 2); +lean_inc(x_361); +x_362 = lean_ctor_get(x_343, 0); +lean_inc(x_362); +lean_dec(x_343); +x_363 = lean_ctor_get(x_344, 0); +lean_inc(x_363); +x_364 = lean_ctor_get(x_344, 1); +lean_inc(x_364); +x_365 = lean_ctor_get(x_344, 3); +lean_inc(x_365); +x_366 = lean_ctor_get(x_344, 4); +lean_inc(x_366); +x_367 = lean_ctor_get(x_344, 5); +lean_inc(x_367); +if (lean_is_exclusive(x_344)) { + lean_ctor_release(x_344, 0); + lean_ctor_release(x_344, 1); + lean_ctor_release(x_344, 2); + lean_ctor_release(x_344, 3); + lean_ctor_release(x_344, 4); + lean_ctor_release(x_344, 5); + x_368 = x_344; +} else { + lean_dec_ref(x_344); + x_368 = lean_box(0); +} +x_369 = lean_ctor_get(x_361, 0); +lean_inc(x_369); +x_370 = lean_ctor_get(x_361, 1); +lean_inc(x_370); +x_371 = lean_ctor_get(x_361, 3); +lean_inc(x_371); +x_372 = lean_ctor_get(x_361, 4); +lean_inc(x_372); +if (lean_is_exclusive(x_361)) { + lean_ctor_release(x_361, 0); + lean_ctor_release(x_361, 1); + lean_ctor_release(x_361, 2); + lean_ctor_release(x_361, 3); + lean_ctor_release(x_361, 4); + x_373 = x_361; +} else { + lean_dec_ref(x_361); + x_373 = lean_box(0); +} +if (lean_is_scalar(x_373)) { + x_374 = lean_alloc_ctor(0, 5, 0); +} else { + x_374 = x_373; +} +lean_ctor_set(x_374, 0, x_369); +lean_ctor_set(x_374, 1, x_370); +lean_ctor_set(x_374, 2, x_340); +lean_ctor_set(x_374, 3, x_371); +lean_ctor_set(x_374, 4, x_372); +if (lean_is_scalar(x_368)) { + x_375 = lean_alloc_ctor(0, 6, 0); +} else { + x_375 = x_368; +} +lean_ctor_set(x_375, 0, x_363); +lean_ctor_set(x_375, 1, x_364); +lean_ctor_set(x_375, 2, x_374); +lean_ctor_set(x_375, 3, x_365); +lean_ctor_set(x_375, 4, x_366); +lean_ctor_set(x_375, 5, x_367); +if (lean_is_scalar(x_248)) { + x_376 = lean_alloc_ctor(0, 2, 0); +} else { + x_376 = x_248; +} +lean_ctor_set(x_376, 0, x_362); +lean_ctor_set(x_376, 1, x_375); +return x_376; } } } } else { -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; lean_object* x_391; lean_object* x_423; lean_object* x_424; lean_object* x_425; lean_object* x_426; lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; lean_object* x_432; lean_object* x_433; lean_object* x_434; lean_object* x_435; -x_379 = lean_ctor_get(x_237, 2); -x_380 = lean_ctor_get(x_237, 0); -x_381 = lean_ctor_get(x_237, 1); -x_382 = lean_ctor_get(x_237, 3); -x_383 = lean_ctor_get(x_237, 4); -x_384 = lean_ctor_get(x_237, 5); -lean_inc(x_384); -lean_inc(x_383); -lean_inc(x_382); -lean_inc(x_379); -lean_inc(x_381); -lean_inc(x_380); -lean_dec(x_237); -x_385 = lean_ctor_get(x_379, 0); -lean_inc(x_385); -x_386 = lean_ctor_get(x_379, 1); -lean_inc(x_386); -x_387 = lean_ctor_get(x_379, 2); -lean_inc(x_387); -x_388 = lean_ctor_get(x_379, 3); -lean_inc(x_388); -if (lean_is_exclusive(x_379)) { - lean_ctor_release(x_379, 0); - lean_ctor_release(x_379, 1); - lean_ctor_release(x_379, 2); - lean_ctor_release(x_379, 3); - x_389 = x_379; +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; lean_object* x_408; lean_object* x_409; lean_object* x_443; lean_object* x_444; lean_object* x_445; lean_object* x_446; lean_object* x_447; lean_object* x_448; lean_object* x_449; lean_object* x_450; lean_object* x_451; lean_object* x_452; lean_object* x_453; lean_object* x_454; lean_object* x_455; +x_396 = lean_ctor_get(x_247, 2); +x_397 = lean_ctor_get(x_247, 0); +x_398 = lean_ctor_get(x_247, 1); +x_399 = lean_ctor_get(x_247, 3); +x_400 = lean_ctor_get(x_247, 4); +x_401 = lean_ctor_get(x_247, 5); +lean_inc(x_401); +lean_inc(x_400); +lean_inc(x_399); +lean_inc(x_396); +lean_inc(x_398); +lean_inc(x_397); +lean_dec(x_247); +x_402 = lean_ctor_get(x_396, 0); +lean_inc(x_402); +x_403 = lean_ctor_get(x_396, 1); +lean_inc(x_403); +x_404 = lean_ctor_get(x_396, 2); +lean_inc(x_404); +x_405 = lean_ctor_get(x_396, 3); +lean_inc(x_405); +x_406 = lean_ctor_get(x_396, 4); +lean_inc(x_406); +if (lean_is_exclusive(x_396)) { + lean_ctor_release(x_396, 0); + lean_ctor_release(x_396, 1); + lean_ctor_release(x_396, 2); + lean_ctor_release(x_396, 3); + lean_ctor_release(x_396, 4); + x_407 = x_396; } else { - lean_dec_ref(x_379); - x_389 = lean_box(0); + lean_dec_ref(x_396); + x_407 = lean_box(0); } -x_423 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_389)) { - x_424 = lean_alloc_ctor(0, 4, 0); +x_443 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_407)) { + x_444 = lean_alloc_ctor(0, 5, 0); } else { - x_424 = x_389; + x_444 = x_407; } -lean_ctor_set(x_424, 0, x_385); -lean_ctor_set(x_424, 1, x_386); -lean_ctor_set(x_424, 2, x_423); -lean_ctor_set(x_424, 3, x_388); -x_425 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_425, 0, x_380); -lean_ctor_set(x_425, 1, x_381); -lean_ctor_set(x_425, 2, x_424); -lean_ctor_set(x_425, 3, x_382); -lean_ctor_set(x_425, 4, x_383); -lean_ctor_set(x_425, 5, x_384); -x_426 = lean_ctor_get(x_7, 0); -lean_inc(x_426); -x_427 = lean_ctor_get(x_7, 1); -lean_inc(x_427); -x_428 = lean_ctor_get(x_7, 2); -lean_inc(x_428); -x_429 = lean_ctor_get(x_7, 3); -lean_inc(x_429); -x_430 = lean_ctor_get(x_7, 4); -lean_inc(x_430); +lean_ctor_set(x_444, 0, x_402); +lean_ctor_set(x_444, 1, x_403); +lean_ctor_set(x_444, 2, x_443); +lean_ctor_set(x_444, 3, x_405); +lean_ctor_set(x_444, 4, x_406); +x_445 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_445, 0, x_397); +lean_ctor_set(x_445, 1, x_398); +lean_ctor_set(x_445, 2, x_444); +lean_ctor_set(x_445, 3, x_399); +lean_ctor_set(x_445, 4, x_400); +lean_ctor_set(x_445, 5, x_401); +x_446 = lean_ctor_get(x_7, 0); +lean_inc(x_446); +x_447 = lean_ctor_get(x_7, 1); +lean_inc(x_447); +x_448 = lean_ctor_get(x_7, 2); +lean_inc(x_448); +x_449 = lean_ctor_get(x_7, 3); +lean_inc(x_449); +x_450 = lean_ctor_get(x_7, 4); +lean_inc(x_450); if (lean_is_exclusive(x_7)) { lean_ctor_release(x_7, 0); lean_ctor_release(x_7, 1); lean_ctor_release(x_7, 2); lean_ctor_release(x_7, 3); lean_ctor_release(x_7, 4); - x_431 = x_7; + x_451 = x_7; } else { lean_dec_ref(x_7); - x_431 = lean_box(0); + x_451 = lean_box(0); } -x_432 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_432, 0, x_239); -lean_ctor_set(x_432, 1, x_14); -x_433 = lean_array_push(x_428, x_432); -if (lean_is_scalar(x_431)) { - x_434 = lean_alloc_ctor(0, 5, 0); +x_452 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_452, 0, x_249); +lean_ctor_set(x_452, 1, x_14); +x_453 = lean_array_push(x_448, x_452); +if (lean_is_scalar(x_451)) { + x_454 = lean_alloc_ctor(0, 5, 0); } else { - x_434 = x_431; + x_454 = x_451; } -lean_ctor_set(x_434, 0, x_426); -lean_ctor_set(x_434, 1, x_427); -lean_ctor_set(x_434, 2, x_433); -lean_ctor_set(x_434, 3, x_429); -lean_ctor_set(x_434, 4, x_430); -x_435 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_241, x_434, x_425); -if (lean_obj_tag(x_435) == 0) +lean_ctor_set(x_454, 0, x_446); +lean_ctor_set(x_454, 1, x_447); +lean_ctor_set(x_454, 2, x_453); +lean_ctor_set(x_454, 3, x_449); +lean_ctor_set(x_454, 4, x_450); +x_455 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_251, x_454, x_445); +if (lean_obj_tag(x_455) == 0) { -lean_object* x_436; lean_object* x_437; lean_object* x_438; -x_436 = lean_ctor_get(x_435, 0); -lean_inc(x_436); -x_437 = lean_ctor_get(x_435, 1); -lean_inc(x_437); -lean_dec(x_435); -x_438 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_438, 0, x_436); -x_390 = x_438; -x_391 = x_437; -goto block_422; +lean_object* x_456; lean_object* x_457; lean_object* x_458; +x_456 = lean_ctor_get(x_455, 0); +lean_inc(x_456); +x_457 = lean_ctor_get(x_455, 1); +lean_inc(x_457); +lean_dec(x_455); +x_458 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_458, 0, x_456); +x_408 = x_458; +x_409 = x_457; +goto block_442; } else { -lean_object* x_439; lean_object* x_440; lean_object* x_441; -x_439 = lean_ctor_get(x_435, 0); -lean_inc(x_439); -x_440 = lean_ctor_get(x_435, 1); -lean_inc(x_440); -lean_dec(x_435); -x_441 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_441, 0, x_439); -x_390 = x_441; -x_391 = x_440; -goto block_422; +lean_object* x_459; lean_object* x_460; lean_object* x_461; +x_459 = lean_ctor_get(x_455, 0); +lean_inc(x_459); +x_460 = lean_ctor_get(x_455, 1); +lean_inc(x_460); +lean_dec(x_455); +x_461 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_461, 0, x_459); +x_408 = x_461; +x_409 = x_460; +goto block_442; } -block_422: +block_442: { -if (lean_obj_tag(x_390) == 0) +if (lean_obj_tag(x_408) == 0) { -lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; lean_object* x_400; lean_object* x_401; lean_object* x_402; lean_object* x_403; lean_object* x_404; lean_object* x_405; lean_object* x_406; -x_392 = lean_ctor_get(x_391, 2); -lean_inc(x_392); -x_393 = lean_ctor_get(x_390, 0); -lean_inc(x_393); -lean_dec(x_390); -x_394 = lean_ctor_get(x_391, 0); -lean_inc(x_394); -x_395 = lean_ctor_get(x_391, 1); -lean_inc(x_395); -x_396 = lean_ctor_get(x_391, 3); -lean_inc(x_396); -x_397 = lean_ctor_get(x_391, 4); -lean_inc(x_397); -x_398 = lean_ctor_get(x_391, 5); -lean_inc(x_398); -if (lean_is_exclusive(x_391)) { - lean_ctor_release(x_391, 0); - lean_ctor_release(x_391, 1); - lean_ctor_release(x_391, 2); - lean_ctor_release(x_391, 3); - lean_ctor_release(x_391, 4); - lean_ctor_release(x_391, 5); - x_399 = x_391; -} else { - lean_dec_ref(x_391); - x_399 = lean_box(0); -} -x_400 = lean_ctor_get(x_392, 0); -lean_inc(x_400); -x_401 = lean_ctor_get(x_392, 1); -lean_inc(x_401); -x_402 = lean_ctor_get(x_392, 3); -lean_inc(x_402); -if (lean_is_exclusive(x_392)) { - lean_ctor_release(x_392, 0); - lean_ctor_release(x_392, 1); - lean_ctor_release(x_392, 2); - lean_ctor_release(x_392, 3); - x_403 = x_392; -} else { - lean_dec_ref(x_392); - x_403 = lean_box(0); -} -if (lean_is_scalar(x_403)) { - x_404 = lean_alloc_ctor(0, 4, 0); -} else { - x_404 = x_403; -} -lean_ctor_set(x_404, 0, x_400); -lean_ctor_set(x_404, 1, x_401); -lean_ctor_set(x_404, 2, x_387); -lean_ctor_set(x_404, 3, x_402); -if (lean_is_scalar(x_399)) { - x_405 = lean_alloc_ctor(0, 6, 0); -} else { - x_405 = x_399; -} -lean_ctor_set(x_405, 0, x_394); -lean_ctor_set(x_405, 1, x_395); -lean_ctor_set(x_405, 2, x_404); -lean_ctor_set(x_405, 3, x_396); -lean_ctor_set(x_405, 4, x_397); -lean_ctor_set(x_405, 5, x_398); -if (lean_is_scalar(x_238)) { - x_406 = lean_alloc_ctor(1, 2, 0); -} else { - x_406 = x_238; - lean_ctor_set_tag(x_406, 1); -} -lean_ctor_set(x_406, 0, x_393); -lean_ctor_set(x_406, 1, x_405); -return x_406; -} -else -{ -lean_object* x_407; lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_object* x_412; lean_object* x_413; lean_object* x_414; lean_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; -x_407 = lean_ctor_get(x_391, 2); -lean_inc(x_407); -x_408 = lean_ctor_get(x_390, 0); -lean_inc(x_408); -lean_dec(x_390); -x_409 = lean_ctor_get(x_391, 0); -lean_inc(x_409); -x_410 = lean_ctor_get(x_391, 1); +lean_object* x_410; 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_410 = lean_ctor_get(x_409, 2); lean_inc(x_410); -x_411 = lean_ctor_get(x_391, 3); +x_411 = lean_ctor_get(x_408, 0); lean_inc(x_411); -x_412 = lean_ctor_get(x_391, 4); +lean_dec(x_408); +x_412 = lean_ctor_get(x_409, 0); lean_inc(x_412); -x_413 = lean_ctor_get(x_391, 5); +x_413 = lean_ctor_get(x_409, 1); lean_inc(x_413); -if (lean_is_exclusive(x_391)) { - lean_ctor_release(x_391, 0); - lean_ctor_release(x_391, 1); - lean_ctor_release(x_391, 2); - lean_ctor_release(x_391, 3); - lean_ctor_release(x_391, 4); - lean_ctor_release(x_391, 5); - x_414 = x_391; -} else { - lean_dec_ref(x_391); - x_414 = lean_box(0); -} -x_415 = lean_ctor_get(x_407, 0); +x_414 = lean_ctor_get(x_409, 3); +lean_inc(x_414); +x_415 = lean_ctor_get(x_409, 4); lean_inc(x_415); -x_416 = lean_ctor_get(x_407, 1); +x_416 = lean_ctor_get(x_409, 5); lean_inc(x_416); -x_417 = lean_ctor_get(x_407, 3); -lean_inc(x_417); -if (lean_is_exclusive(x_407)) { - lean_ctor_release(x_407, 0); - lean_ctor_release(x_407, 1); - lean_ctor_release(x_407, 2); - lean_ctor_release(x_407, 3); - x_418 = x_407; +if (lean_is_exclusive(x_409)) { + lean_ctor_release(x_409, 0); + lean_ctor_release(x_409, 1); + lean_ctor_release(x_409, 2); + lean_ctor_release(x_409, 3); + lean_ctor_release(x_409, 4); + lean_ctor_release(x_409, 5); + x_417 = x_409; } else { - lean_dec_ref(x_407); - x_418 = lean_box(0); + lean_dec_ref(x_409); + x_417 = lean_box(0); } -if (lean_is_scalar(x_418)) { - x_419 = lean_alloc_ctor(0, 4, 0); +x_418 = lean_ctor_get(x_410, 0); +lean_inc(x_418); +x_419 = lean_ctor_get(x_410, 1); +lean_inc(x_419); +x_420 = lean_ctor_get(x_410, 3); +lean_inc(x_420); +x_421 = lean_ctor_get(x_410, 4); +lean_inc(x_421); +if (lean_is_exclusive(x_410)) { + lean_ctor_release(x_410, 0); + lean_ctor_release(x_410, 1); + lean_ctor_release(x_410, 2); + lean_ctor_release(x_410, 3); + lean_ctor_release(x_410, 4); + x_422 = x_410; } else { - x_419 = x_418; + lean_dec_ref(x_410); + x_422 = lean_box(0); } -lean_ctor_set(x_419, 0, x_415); -lean_ctor_set(x_419, 1, x_416); -lean_ctor_set(x_419, 2, x_387); -lean_ctor_set(x_419, 3, x_417); -if (lean_is_scalar(x_414)) { - x_420 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_422)) { + x_423 = lean_alloc_ctor(0, 5, 0); } else { - x_420 = x_414; + x_423 = x_422; } -lean_ctor_set(x_420, 0, x_409); -lean_ctor_set(x_420, 1, x_410); -lean_ctor_set(x_420, 2, x_419); -lean_ctor_set(x_420, 3, x_411); -lean_ctor_set(x_420, 4, x_412); -lean_ctor_set(x_420, 5, x_413); -if (lean_is_scalar(x_238)) { - x_421 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_423, 0, x_418); +lean_ctor_set(x_423, 1, x_419); +lean_ctor_set(x_423, 2, x_404); +lean_ctor_set(x_423, 3, x_420); +lean_ctor_set(x_423, 4, x_421); +if (lean_is_scalar(x_417)) { + x_424 = lean_alloc_ctor(0, 6, 0); } else { - x_421 = x_238; + x_424 = x_417; } -lean_ctor_set(x_421, 0, x_408); -lean_ctor_set(x_421, 1, x_420); -return x_421; +lean_ctor_set(x_424, 0, x_412); +lean_ctor_set(x_424, 1, x_413); +lean_ctor_set(x_424, 2, x_423); +lean_ctor_set(x_424, 3, x_414); +lean_ctor_set(x_424, 4, x_415); +lean_ctor_set(x_424, 5, x_416); +if (lean_is_scalar(x_248)) { + x_425 = lean_alloc_ctor(1, 2, 0); +} else { + x_425 = x_248; + lean_ctor_set_tag(x_425, 1); +} +lean_ctor_set(x_425, 0, x_411); +lean_ctor_set(x_425, 1, x_424); +return x_425; +} +else +{ +lean_object* x_426; lean_object* x_427; 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; +x_426 = lean_ctor_get(x_409, 2); +lean_inc(x_426); +x_427 = lean_ctor_get(x_408, 0); +lean_inc(x_427); +lean_dec(x_408); +x_428 = lean_ctor_get(x_409, 0); +lean_inc(x_428); +x_429 = lean_ctor_get(x_409, 1); +lean_inc(x_429); +x_430 = lean_ctor_get(x_409, 3); +lean_inc(x_430); +x_431 = lean_ctor_get(x_409, 4); +lean_inc(x_431); +x_432 = lean_ctor_get(x_409, 5); +lean_inc(x_432); +if (lean_is_exclusive(x_409)) { + lean_ctor_release(x_409, 0); + lean_ctor_release(x_409, 1); + lean_ctor_release(x_409, 2); + lean_ctor_release(x_409, 3); + lean_ctor_release(x_409, 4); + lean_ctor_release(x_409, 5); + x_433 = x_409; +} else { + lean_dec_ref(x_409); + x_433 = lean_box(0); +} +x_434 = lean_ctor_get(x_426, 0); +lean_inc(x_434); +x_435 = lean_ctor_get(x_426, 1); +lean_inc(x_435); +x_436 = lean_ctor_get(x_426, 3); +lean_inc(x_436); +x_437 = lean_ctor_get(x_426, 4); +lean_inc(x_437); +if (lean_is_exclusive(x_426)) { + lean_ctor_release(x_426, 0); + lean_ctor_release(x_426, 1); + lean_ctor_release(x_426, 2); + lean_ctor_release(x_426, 3); + lean_ctor_release(x_426, 4); + x_438 = x_426; +} else { + lean_dec_ref(x_426); + x_438 = lean_box(0); +} +if (lean_is_scalar(x_438)) { + x_439 = lean_alloc_ctor(0, 5, 0); +} else { + x_439 = x_438; +} +lean_ctor_set(x_439, 0, x_434); +lean_ctor_set(x_439, 1, x_435); +lean_ctor_set(x_439, 2, x_404); +lean_ctor_set(x_439, 3, x_436); +lean_ctor_set(x_439, 4, x_437); +if (lean_is_scalar(x_433)) { + x_440 = lean_alloc_ctor(0, 6, 0); +} else { + x_440 = x_433; +} +lean_ctor_set(x_440, 0, x_428); +lean_ctor_set(x_440, 1, x_429); +lean_ctor_set(x_440, 2, x_439); +lean_ctor_set(x_440, 3, x_430); +lean_ctor_set(x_440, 4, x_431); +lean_ctor_set(x_440, 5, x_432); +if (lean_is_scalar(x_248)) { + x_441 = lean_alloc_ctor(0, 2, 0); +} else { + x_441 = x_248; +} +lean_ctor_set(x_441, 0, x_427); +lean_ctor_set(x_441, 1, x_440); +return x_441; } } } @@ -23004,29 +23702,29 @@ return x_421; } else { -uint8_t x_442; +uint8_t x_462; lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_442 = !lean_is_exclusive(x_231); -if (x_442 == 0) +x_462 = !lean_is_exclusive(x_241); +if (x_462 == 0) { -return x_231; +return x_241; } else { -lean_object* x_443; lean_object* x_444; lean_object* x_445; -x_443 = lean_ctor_get(x_231, 0); -x_444 = lean_ctor_get(x_231, 1); -lean_inc(x_444); -lean_inc(x_443); -lean_dec(x_231); -x_445 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_445, 0, x_443); -lean_ctor_set(x_445, 1, x_444); -return x_445; +lean_object* x_463; lean_object* x_464; lean_object* x_465; +x_463 = lean_ctor_get(x_241, 0); +x_464 = lean_ctor_get(x_241, 1); +lean_inc(x_464); +lean_inc(x_463); +lean_dec(x_241); +x_465 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_465, 0, x_463); +lean_ctor_set(x_465, 1, x_464); +return x_465; } } } @@ -23034,58 +23732,58 @@ return x_445; } else { -uint8_t x_446; +uint8_t x_466; lean_dec(x_18); lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_446 = !lean_is_exclusive(x_19); -if (x_446 == 0) +x_466 = !lean_is_exclusive(x_19); +if (x_466 == 0) { return x_19; } else { -lean_object* x_447; lean_object* x_448; lean_object* x_449; -x_447 = lean_ctor_get(x_19, 0); -x_448 = lean_ctor_get(x_19, 1); -lean_inc(x_448); -lean_inc(x_447); +lean_object* x_467; lean_object* x_468; lean_object* x_469; +x_467 = lean_ctor_get(x_19, 0); +x_468 = lean_ctor_get(x_19, 1); +lean_inc(x_468); +lean_inc(x_467); lean_dec(x_19); -x_449 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_449, 0, x_447); -lean_ctor_set(x_449, 1, x_448); -return x_449; +x_469 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_469, 0, x_467); +lean_ctor_set(x_469, 1, x_468); +return x_469; } } } else { -uint8_t x_450; +uint8_t x_470; lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_450 = !lean_is_exclusive(x_15); -if (x_450 == 0) +x_470 = !lean_is_exclusive(x_15); +if (x_470 == 0) { return x_15; } else { -lean_object* x_451; lean_object* x_452; lean_object* x_453; -x_451 = lean_ctor_get(x_15, 0); -x_452 = lean_ctor_get(x_15, 1); -lean_inc(x_452); -lean_inc(x_451); +lean_object* x_471; lean_object* x_472; lean_object* x_473; +x_471 = lean_ctor_get(x_15, 0); +x_472 = lean_ctor_get(x_15, 1); +lean_inc(x_472); +lean_inc(x_471); lean_dec(x_15); -x_453 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_453, 0, x_451); -lean_ctor_set(x_453, 1, x_452); -return x_453; +x_473 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_473, 0, x_471); +lean_ctor_set(x_473, 1, x_472); +return x_473; } } } @@ -23496,105 +24194,105 @@ x_31 = lean_ctor_get(x_25, 2); x_32 = !lean_is_exclusive(x_31); if (x_32 == 0) { -lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_85; uint8_t x_86; +lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_89; uint8_t x_90; x_33 = lean_ctor_get(x_31, 2); -x_85 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_31, 2, x_85); -x_86 = !lean_is_exclusive(x_7); -if (x_86 == 0) +x_89 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_31, 2, x_89); +x_90 = !lean_is_exclusive(x_7); +if (x_90 == 0) { -lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; -x_87 = lean_ctor_get(x_7, 2); -x_88 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_88, 0, x_27); -lean_ctor_set(x_88, 1, x_14); -x_89 = lean_array_push(x_87, x_88); -lean_ctor_set(x_7, 2, x_89); -x_90 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_7, x_25); -if (lean_obj_tag(x_90) == 0) +lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; +x_91 = lean_ctor_get(x_7, 2); +x_92 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_92, 0, x_27); +lean_ctor_set(x_92, 1, x_14); +x_93 = lean_array_push(x_91, x_92); +lean_ctor_set(x_7, 2, x_93); +x_94 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_7, x_25); +if (lean_obj_tag(x_94) == 0) { -lean_object* x_91; lean_object* x_92; lean_object* x_93; -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_alloc_ctor(1, 1, 0); -lean_ctor_set(x_93, 0, x_91); -x_34 = x_93; -x_35 = x_92; -goto block_84; -} -else -{ -lean_object* x_94; lean_object* x_95; lean_object* x_96; -x_94 = lean_ctor_get(x_90, 0); -lean_inc(x_94); -x_95 = lean_ctor_get(x_90, 1); +lean_object* x_95; lean_object* x_96; lean_object* x_97; +x_95 = lean_ctor_get(x_94, 0); lean_inc(x_95); -lean_dec(x_90); -x_96 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_96, 0, x_94); -x_34 = x_96; -x_35 = x_95; -goto block_84; -} +x_96 = lean_ctor_get(x_94, 1); +lean_inc(x_96); +lean_dec(x_94); +x_97 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_97, 0, x_95); +x_34 = x_97; +x_35 = x_96; +goto block_88; } else { -lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; -x_97 = lean_ctor_get(x_7, 0); -x_98 = lean_ctor_get(x_7, 1); -x_99 = lean_ctor_get(x_7, 2); -x_100 = lean_ctor_get(x_7, 3); -x_101 = lean_ctor_get(x_7, 4); -lean_inc(x_101); -lean_inc(x_100); -lean_inc(x_99); +lean_object* x_98; lean_object* x_99; lean_object* x_100; +x_98 = lean_ctor_get(x_94, 0); lean_inc(x_98); -lean_inc(x_97); -lean_dec(x_7); -x_102 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_102, 0, x_27); -lean_ctor_set(x_102, 1, x_14); -x_103 = lean_array_push(x_99, x_102); -x_104 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_104, 0, x_97); -lean_ctor_set(x_104, 1, x_98); -lean_ctor_set(x_104, 2, x_103); -lean_ctor_set(x_104, 3, x_100); -lean_ctor_set(x_104, 4, x_101); -x_105 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_104, x_25); -if (lean_obj_tag(x_105) == 0) -{ -lean_object* x_106; lean_object* x_107; lean_object* x_108; -x_106 = lean_ctor_get(x_105, 0); -lean_inc(x_106); -x_107 = lean_ctor_get(x_105, 1); -lean_inc(x_107); -lean_dec(x_105); -x_108 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_108, 0, x_106); -x_34 = x_108; -x_35 = x_107; -goto block_84; +x_99 = lean_ctor_get(x_94, 1); +lean_inc(x_99); +lean_dec(x_94); +x_100 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_100, 0, x_98); +x_34 = x_100; +x_35 = x_99; +goto block_88; +} } else { -lean_object* x_109; lean_object* x_110; lean_object* x_111; -x_109 = lean_ctor_get(x_105, 0); -lean_inc(x_109); -x_110 = lean_ctor_get(x_105, 1); +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; +x_101 = lean_ctor_get(x_7, 0); +x_102 = lean_ctor_get(x_7, 1); +x_103 = lean_ctor_get(x_7, 2); +x_104 = lean_ctor_get(x_7, 3); +x_105 = lean_ctor_get(x_7, 4); +lean_inc(x_105); +lean_inc(x_104); +lean_inc(x_103); +lean_inc(x_102); +lean_inc(x_101); +lean_dec(x_7); +x_106 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_106, 0, x_27); +lean_ctor_set(x_106, 1, x_14); +x_107 = lean_array_push(x_103, x_106); +x_108 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_108, 0, x_101); +lean_ctor_set(x_108, 1, x_102); +lean_ctor_set(x_108, 2, x_107); +lean_ctor_set(x_108, 3, x_104); +lean_ctor_set(x_108, 4, x_105); +x_109 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_108, x_25); +if (lean_obj_tag(x_109) == 0) +{ +lean_object* x_110; lean_object* x_111; lean_object* x_112; +x_110 = lean_ctor_get(x_109, 0); lean_inc(x_110); -lean_dec(x_105); -x_111 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_111, 0, x_109); -x_34 = x_111; -x_35 = x_110; -goto block_84; +x_111 = lean_ctor_get(x_109, 1); +lean_inc(x_111); +lean_dec(x_109); +x_112 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_112, 0, x_110); +x_34 = x_112; +x_35 = x_111; +goto block_88; +} +else +{ +lean_object* x_113; lean_object* x_114; lean_object* x_115; +x_113 = lean_ctor_get(x_109, 0); +lean_inc(x_113); +x_114 = lean_ctor_get(x_109, 1); +lean_inc(x_114); +lean_dec(x_109); +x_115 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_115, 0, x_113); +x_34 = x_115; +x_35 = x_114; +goto block_88; } } -block_84: +block_88: { if (lean_obj_tag(x_34) == 0) { @@ -23629,1284 +24327,1262 @@ return x_42; } else { -lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; +lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; x_43 = lean_ctor_get(x_36, 0); x_44 = lean_ctor_get(x_36, 1); x_45 = lean_ctor_get(x_36, 3); +x_46 = lean_ctor_get(x_36, 4); +lean_inc(x_46); lean_inc(x_45); lean_inc(x_44); lean_inc(x_43); lean_dec(x_36); -x_46 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_46, 0, x_43); -lean_ctor_set(x_46, 1, x_44); -lean_ctor_set(x_46, 2, x_33); -lean_ctor_set(x_46, 3, x_45); -lean_ctor_set(x_35, 2, x_46); +x_47 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_47, 0, x_43); +lean_ctor_set(x_47, 1, x_44); +lean_ctor_set(x_47, 2, x_33); +lean_ctor_set(x_47, 3, x_45); +lean_ctor_set(x_47, 4, x_46); +lean_ctor_set(x_35, 2, x_47); if (lean_is_scalar(x_26)) { - x_47 = lean_alloc_ctor(1, 2, 0); + x_48 = lean_alloc_ctor(1, 2, 0); } else { - x_47 = x_26; - lean_ctor_set_tag(x_47, 1); + x_48 = x_26; + lean_ctor_set_tag(x_48, 1); } -lean_ctor_set(x_47, 0, x_37); -lean_ctor_set(x_47, 1, x_35); -return x_47; +lean_ctor_set(x_48, 0, x_37); +lean_ctor_set(x_48, 1, x_35); +return x_48; } } else { -lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; -x_48 = lean_ctor_get(x_35, 0); -x_49 = lean_ctor_get(x_35, 1); -x_50 = lean_ctor_get(x_35, 3); -x_51 = lean_ctor_get(x_35, 4); -x_52 = lean_ctor_get(x_35, 5); +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; +x_49 = lean_ctor_get(x_35, 0); +x_50 = lean_ctor_get(x_35, 1); +x_51 = lean_ctor_get(x_35, 3); +x_52 = lean_ctor_get(x_35, 4); +x_53 = lean_ctor_get(x_35, 5); +lean_inc(x_53); lean_inc(x_52); lean_inc(x_51); lean_inc(x_50); lean_inc(x_49); -lean_inc(x_48); lean_dec(x_35); -x_53 = lean_ctor_get(x_36, 0); -lean_inc(x_53); -x_54 = lean_ctor_get(x_36, 1); +x_54 = lean_ctor_get(x_36, 0); lean_inc(x_54); -x_55 = lean_ctor_get(x_36, 3); +x_55 = lean_ctor_get(x_36, 1); lean_inc(x_55); +x_56 = lean_ctor_get(x_36, 3); +lean_inc(x_56); +x_57 = lean_ctor_get(x_36, 4); +lean_inc(x_57); if (lean_is_exclusive(x_36)) { lean_ctor_release(x_36, 0); lean_ctor_release(x_36, 1); lean_ctor_release(x_36, 2); lean_ctor_release(x_36, 3); - x_56 = x_36; + lean_ctor_release(x_36, 4); + x_58 = x_36; } else { lean_dec_ref(x_36); - x_56 = lean_box(0); + x_58 = lean_box(0); } -if (lean_is_scalar(x_56)) { - x_57 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_58)) { + x_59 = lean_alloc_ctor(0, 5, 0); } else { - x_57 = x_56; + x_59 = x_58; } -lean_ctor_set(x_57, 0, x_53); -lean_ctor_set(x_57, 1, x_54); -lean_ctor_set(x_57, 2, x_33); -lean_ctor_set(x_57, 3, x_55); -x_58 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_58, 0, x_48); -lean_ctor_set(x_58, 1, x_49); -lean_ctor_set(x_58, 2, x_57); -lean_ctor_set(x_58, 3, x_50); -lean_ctor_set(x_58, 4, x_51); -lean_ctor_set(x_58, 5, x_52); +lean_ctor_set(x_59, 0, x_54); +lean_ctor_set(x_59, 1, x_55); +lean_ctor_set(x_59, 2, x_33); +lean_ctor_set(x_59, 3, x_56); +lean_ctor_set(x_59, 4, x_57); +x_60 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_60, 0, x_49); +lean_ctor_set(x_60, 1, x_50); +lean_ctor_set(x_60, 2, x_59); +lean_ctor_set(x_60, 3, x_51); +lean_ctor_set(x_60, 4, x_52); +lean_ctor_set(x_60, 5, x_53); if (lean_is_scalar(x_26)) { - x_59 = lean_alloc_ctor(1, 2, 0); + x_61 = lean_alloc_ctor(1, 2, 0); } else { - x_59 = x_26; - lean_ctor_set_tag(x_59, 1); + x_61 = x_26; + lean_ctor_set_tag(x_61, 1); } -lean_ctor_set(x_59, 0, x_37); -lean_ctor_set(x_59, 1, x_58); -return x_59; +lean_ctor_set(x_61, 0, x_37); +lean_ctor_set(x_61, 1, x_60); +return x_61; } } else { -lean_object* x_60; lean_object* x_61; uint8_t x_62; -x_60 = lean_ctor_get(x_35, 2); -lean_inc(x_60); -x_61 = lean_ctor_get(x_34, 0); -lean_inc(x_61); +lean_object* x_62; lean_object* x_63; uint8_t x_64; +x_62 = lean_ctor_get(x_35, 2); +lean_inc(x_62); +x_63 = lean_ctor_get(x_34, 0); +lean_inc(x_63); lean_dec(x_34); -x_62 = !lean_is_exclusive(x_35); -if (x_62 == 0) -{ -lean_object* x_63; uint8_t x_64; -x_63 = lean_ctor_get(x_35, 2); -lean_dec(x_63); -x_64 = !lean_is_exclusive(x_60); +x_64 = !lean_is_exclusive(x_35); if (x_64 == 0) { -lean_object* x_65; lean_object* x_66; -x_65 = lean_ctor_get(x_60, 2); +lean_object* x_65; uint8_t x_66; +x_65 = lean_ctor_get(x_35, 2); lean_dec(x_65); -lean_ctor_set(x_60, 2, x_33); +x_66 = !lean_is_exclusive(x_62); +if (x_66 == 0) +{ +lean_object* x_67; lean_object* x_68; +x_67 = lean_ctor_get(x_62, 2); +lean_dec(x_67); +lean_ctor_set(x_62, 2, x_33); if (lean_is_scalar(x_26)) { - x_66 = lean_alloc_ctor(0, 2, 0); + x_68 = lean_alloc_ctor(0, 2, 0); } else { - x_66 = x_26; + x_68 = x_26; } -lean_ctor_set(x_66, 0, x_61); -lean_ctor_set(x_66, 1, x_35); -return x_66; +lean_ctor_set(x_68, 0, x_63); +lean_ctor_set(x_68, 1, x_35); +return x_68; } else { -lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; -x_67 = lean_ctor_get(x_60, 0); -x_68 = lean_ctor_get(x_60, 1); -x_69 = lean_ctor_get(x_60, 3); +lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; +x_69 = lean_ctor_get(x_62, 0); +x_70 = lean_ctor_get(x_62, 1); +x_71 = lean_ctor_get(x_62, 3); +x_72 = lean_ctor_get(x_62, 4); +lean_inc(x_72); +lean_inc(x_71); +lean_inc(x_70); lean_inc(x_69); -lean_inc(x_68); -lean_inc(x_67); -lean_dec(x_60); -x_70 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_70, 0, x_67); -lean_ctor_set(x_70, 1, x_68); -lean_ctor_set(x_70, 2, x_33); -lean_ctor_set(x_70, 3, x_69); -lean_ctor_set(x_35, 2, x_70); +lean_dec(x_62); +x_73 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_73, 0, x_69); +lean_ctor_set(x_73, 1, x_70); +lean_ctor_set(x_73, 2, x_33); +lean_ctor_set(x_73, 3, x_71); +lean_ctor_set(x_73, 4, x_72); +lean_ctor_set(x_35, 2, x_73); if (lean_is_scalar(x_26)) { - x_71 = lean_alloc_ctor(0, 2, 0); + x_74 = lean_alloc_ctor(0, 2, 0); } else { - x_71 = x_26; + x_74 = x_26; } -lean_ctor_set(x_71, 0, x_61); -lean_ctor_set(x_71, 1, x_35); -return x_71; +lean_ctor_set(x_74, 0, x_63); +lean_ctor_set(x_74, 1, x_35); +return x_74; } } else { -lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; -x_72 = lean_ctor_get(x_35, 0); -x_73 = lean_ctor_get(x_35, 1); -x_74 = lean_ctor_get(x_35, 3); -x_75 = lean_ctor_get(x_35, 4); -x_76 = lean_ctor_get(x_35, 5); +lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; +x_75 = lean_ctor_get(x_35, 0); +x_76 = lean_ctor_get(x_35, 1); +x_77 = lean_ctor_get(x_35, 3); +x_78 = lean_ctor_get(x_35, 4); +x_79 = lean_ctor_get(x_35, 5); +lean_inc(x_79); +lean_inc(x_78); +lean_inc(x_77); lean_inc(x_76); lean_inc(x_75); -lean_inc(x_74); -lean_inc(x_73); -lean_inc(x_72); lean_dec(x_35); -x_77 = lean_ctor_get(x_60, 0); -lean_inc(x_77); -x_78 = lean_ctor_get(x_60, 1); -lean_inc(x_78); -x_79 = lean_ctor_get(x_60, 3); -lean_inc(x_79); -if (lean_is_exclusive(x_60)) { - lean_ctor_release(x_60, 0); - lean_ctor_release(x_60, 1); - lean_ctor_release(x_60, 2); - lean_ctor_release(x_60, 3); - x_80 = x_60; +x_80 = lean_ctor_get(x_62, 0); +lean_inc(x_80); +x_81 = lean_ctor_get(x_62, 1); +lean_inc(x_81); +x_82 = lean_ctor_get(x_62, 3); +lean_inc(x_82); +x_83 = lean_ctor_get(x_62, 4); +lean_inc(x_83); +if (lean_is_exclusive(x_62)) { + lean_ctor_release(x_62, 0); + lean_ctor_release(x_62, 1); + lean_ctor_release(x_62, 2); + lean_ctor_release(x_62, 3); + lean_ctor_release(x_62, 4); + x_84 = x_62; } else { - lean_dec_ref(x_60); - x_80 = lean_box(0); + lean_dec_ref(x_62); + x_84 = lean_box(0); } -if (lean_is_scalar(x_80)) { - x_81 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_84)) { + x_85 = lean_alloc_ctor(0, 5, 0); } else { - x_81 = x_80; + x_85 = x_84; } -lean_ctor_set(x_81, 0, x_77); -lean_ctor_set(x_81, 1, x_78); -lean_ctor_set(x_81, 2, x_33); -lean_ctor_set(x_81, 3, x_79); -x_82 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_82, 0, x_72); -lean_ctor_set(x_82, 1, x_73); -lean_ctor_set(x_82, 2, x_81); -lean_ctor_set(x_82, 3, x_74); -lean_ctor_set(x_82, 4, x_75); -lean_ctor_set(x_82, 5, x_76); +lean_ctor_set(x_85, 0, x_80); +lean_ctor_set(x_85, 1, x_81); +lean_ctor_set(x_85, 2, x_33); +lean_ctor_set(x_85, 3, x_82); +lean_ctor_set(x_85, 4, x_83); +x_86 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_86, 0, x_75); +lean_ctor_set(x_86, 1, x_76); +lean_ctor_set(x_86, 2, x_85); +lean_ctor_set(x_86, 3, x_77); +lean_ctor_set(x_86, 4, x_78); +lean_ctor_set(x_86, 5, x_79); if (lean_is_scalar(x_26)) { - x_83 = lean_alloc_ctor(0, 2, 0); + x_87 = lean_alloc_ctor(0, 2, 0); } else { - x_83 = x_26; + x_87 = x_26; } -lean_ctor_set(x_83, 0, x_61); -lean_ctor_set(x_83, 1, x_82); -return x_83; +lean_ctor_set(x_87, 0, x_63); +lean_ctor_set(x_87, 1, x_86); +return x_87; } } } } else { -lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_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; -x_112 = lean_ctor_get(x_31, 0); -x_113 = lean_ctor_get(x_31, 1); -x_114 = lean_ctor_get(x_31, 2); -x_115 = lean_ctor_get(x_31, 3); -lean_inc(x_115); -lean_inc(x_114); -lean_inc(x_113); -lean_inc(x_112); -lean_dec(x_31); -x_149 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_150 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_150, 0, x_112); -lean_ctor_set(x_150, 1, x_113); -lean_ctor_set(x_150, 2, x_149); -lean_ctor_set(x_150, 3, x_115); -lean_ctor_set(x_25, 2, x_150); -x_151 = lean_ctor_get(x_7, 0); -lean_inc(x_151); -x_152 = lean_ctor_get(x_7, 1); -lean_inc(x_152); -x_153 = lean_ctor_get(x_7, 2); -lean_inc(x_153); -x_154 = lean_ctor_get(x_7, 3); -lean_inc(x_154); -x_155 = lean_ctor_get(x_7, 4); -lean_inc(x_155); -if (lean_is_exclusive(x_7)) { - lean_ctor_release(x_7, 0); - lean_ctor_release(x_7, 1); - lean_ctor_release(x_7, 2); - lean_ctor_release(x_7, 3); - lean_ctor_release(x_7, 4); - x_156 = x_7; -} else { - lean_dec_ref(x_7); - x_156 = lean_box(0); -} -x_157 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_157, 0, x_27); -lean_ctor_set(x_157, 1, x_14); -x_158 = lean_array_push(x_153, x_157); -if (lean_is_scalar(x_156)) { - x_159 = lean_alloc_ctor(0, 5, 0); -} else { - x_159 = x_156; -} -lean_ctor_set(x_159, 0, x_151); -lean_ctor_set(x_159, 1, x_152); -lean_ctor_set(x_159, 2, x_158); -lean_ctor_set(x_159, 3, x_154); -lean_ctor_set(x_159, 4, x_155); -x_160 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_159, x_25); -if (lean_obj_tag(x_160) == 0) -{ -lean_object* x_161; lean_object* x_162; lean_object* x_163; -x_161 = lean_ctor_get(x_160, 0); -lean_inc(x_161); -x_162 = lean_ctor_get(x_160, 1); -lean_inc(x_162); -lean_dec(x_160); -x_163 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_163, 0, x_161); -x_116 = x_163; -x_117 = x_162; -goto block_148; -} -else -{ -lean_object* x_164; lean_object* x_165; lean_object* x_166; -x_164 = lean_ctor_get(x_160, 0); -lean_inc(x_164); -x_165 = lean_ctor_get(x_160, 1); -lean_inc(x_165); -lean_dec(x_160); -x_166 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_166, 0, x_164); -x_116 = x_166; -x_117 = x_165; -goto block_148; -} -block_148: -{ -if (lean_obj_tag(x_116) == 0) -{ -lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; -x_118 = lean_ctor_get(x_117, 2); -lean_inc(x_118); -x_119 = lean_ctor_get(x_116, 0); -lean_inc(x_119); -lean_dec(x_116); -x_120 = lean_ctor_get(x_117, 0); +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_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; +x_116 = lean_ctor_get(x_31, 0); +x_117 = lean_ctor_get(x_31, 1); +x_118 = lean_ctor_get(x_31, 2); +x_119 = lean_ctor_get(x_31, 3); +x_120 = lean_ctor_get(x_31, 4); lean_inc(x_120); -x_121 = lean_ctor_get(x_117, 1); -lean_inc(x_121); -x_122 = lean_ctor_get(x_117, 3); -lean_inc(x_122); -x_123 = lean_ctor_get(x_117, 4); -lean_inc(x_123); -x_124 = lean_ctor_get(x_117, 5); -lean_inc(x_124); -if (lean_is_exclusive(x_117)) { - lean_ctor_release(x_117, 0); - lean_ctor_release(x_117, 1); - lean_ctor_release(x_117, 2); - lean_ctor_release(x_117, 3); - lean_ctor_release(x_117, 4); - lean_ctor_release(x_117, 5); - x_125 = x_117; -} else { - lean_dec_ref(x_117); - x_125 = lean_box(0); -} -x_126 = lean_ctor_get(x_118, 0); -lean_inc(x_126); -x_127 = lean_ctor_get(x_118, 1); -lean_inc(x_127); -x_128 = lean_ctor_get(x_118, 3); -lean_inc(x_128); -if (lean_is_exclusive(x_118)) { - lean_ctor_release(x_118, 0); - lean_ctor_release(x_118, 1); - lean_ctor_release(x_118, 2); - lean_ctor_release(x_118, 3); - x_129 = x_118; -} else { - lean_dec_ref(x_118); - x_129 = lean_box(0); -} -if (lean_is_scalar(x_129)) { - x_130 = lean_alloc_ctor(0, 4, 0); -} else { - x_130 = x_129; -} -lean_ctor_set(x_130, 0, x_126); -lean_ctor_set(x_130, 1, x_127); -lean_ctor_set(x_130, 2, x_114); -lean_ctor_set(x_130, 3, x_128); -if (lean_is_scalar(x_125)) { - x_131 = lean_alloc_ctor(0, 6, 0); -} else { - x_131 = x_125; -} -lean_ctor_set(x_131, 0, x_120); -lean_ctor_set(x_131, 1, x_121); -lean_ctor_set(x_131, 2, x_130); -lean_ctor_set(x_131, 3, x_122); -lean_ctor_set(x_131, 4, x_123); -lean_ctor_set(x_131, 5, x_124); -if (lean_is_scalar(x_26)) { - x_132 = lean_alloc_ctor(1, 2, 0); -} else { - x_132 = x_26; - lean_ctor_set_tag(x_132, 1); -} -lean_ctor_set(x_132, 0, x_119); -lean_ctor_set(x_132, 1, x_131); -return x_132; -} -else -{ -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; -x_133 = lean_ctor_get(x_117, 2); -lean_inc(x_133); -x_134 = lean_ctor_get(x_116, 0); -lean_inc(x_134); -lean_dec(x_116); -x_135 = lean_ctor_get(x_117, 0); -lean_inc(x_135); -x_136 = lean_ctor_get(x_117, 1); -lean_inc(x_136); -x_137 = lean_ctor_get(x_117, 3); -lean_inc(x_137); -x_138 = lean_ctor_get(x_117, 4); -lean_inc(x_138); -x_139 = lean_ctor_get(x_117, 5); -lean_inc(x_139); -if (lean_is_exclusive(x_117)) { - lean_ctor_release(x_117, 0); - lean_ctor_release(x_117, 1); - lean_ctor_release(x_117, 2); - lean_ctor_release(x_117, 3); - lean_ctor_release(x_117, 4); - lean_ctor_release(x_117, 5); - x_140 = x_117; -} else { - lean_dec_ref(x_117); - x_140 = lean_box(0); -} -x_141 = lean_ctor_get(x_133, 0); -lean_inc(x_141); -x_142 = lean_ctor_get(x_133, 1); -lean_inc(x_142); -x_143 = lean_ctor_get(x_133, 3); -lean_inc(x_143); -if (lean_is_exclusive(x_133)) { - lean_ctor_release(x_133, 0); - lean_ctor_release(x_133, 1); - lean_ctor_release(x_133, 2); - lean_ctor_release(x_133, 3); - x_144 = x_133; -} else { - lean_dec_ref(x_133); - x_144 = lean_box(0); -} -if (lean_is_scalar(x_144)) { - x_145 = lean_alloc_ctor(0, 4, 0); -} else { - x_145 = x_144; -} -lean_ctor_set(x_145, 0, x_141); -lean_ctor_set(x_145, 1, x_142); -lean_ctor_set(x_145, 2, x_114); -lean_ctor_set(x_145, 3, x_143); -if (lean_is_scalar(x_140)) { - x_146 = lean_alloc_ctor(0, 6, 0); -} else { - x_146 = x_140; -} -lean_ctor_set(x_146, 0, x_135); -lean_ctor_set(x_146, 1, x_136); -lean_ctor_set(x_146, 2, x_145); -lean_ctor_set(x_146, 3, x_137); -lean_ctor_set(x_146, 4, x_138); -lean_ctor_set(x_146, 5, x_139); -if (lean_is_scalar(x_26)) { - x_147 = lean_alloc_ctor(0, 2, 0); -} else { - x_147 = x_26; -} -lean_ctor_set(x_147, 0, x_134); -lean_ctor_set(x_147, 1, x_146); -return x_147; -} -} -} -} -else -{ -lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; 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; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; -x_167 = lean_ctor_get(x_25, 2); -x_168 = lean_ctor_get(x_25, 0); -x_169 = lean_ctor_get(x_25, 1); -x_170 = lean_ctor_get(x_25, 3); -x_171 = lean_ctor_get(x_25, 4); -x_172 = lean_ctor_get(x_25, 5); -lean_inc(x_172); -lean_inc(x_171); -lean_inc(x_170); -lean_inc(x_167); -lean_inc(x_169); -lean_inc(x_168); -lean_dec(x_25); -x_173 = lean_ctor_get(x_167, 0); -lean_inc(x_173); -x_174 = lean_ctor_get(x_167, 1); -lean_inc(x_174); -x_175 = lean_ctor_get(x_167, 2); -lean_inc(x_175); -x_176 = lean_ctor_get(x_167, 3); -lean_inc(x_176); -if (lean_is_exclusive(x_167)) { - lean_ctor_release(x_167, 0); - lean_ctor_release(x_167, 1); - lean_ctor_release(x_167, 2); - lean_ctor_release(x_167, 3); - x_177 = x_167; -} else { - lean_dec_ref(x_167); - x_177 = lean_box(0); -} -x_211 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_177)) { - x_212 = lean_alloc_ctor(0, 4, 0); -} else { - x_212 = x_177; -} -lean_ctor_set(x_212, 0, x_173); -lean_ctor_set(x_212, 1, x_174); -lean_ctor_set(x_212, 2, x_211); -lean_ctor_set(x_212, 3, x_176); -x_213 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_213, 0, x_168); -lean_ctor_set(x_213, 1, x_169); -lean_ctor_set(x_213, 2, x_212); -lean_ctor_set(x_213, 3, x_170); -lean_ctor_set(x_213, 4, x_171); -lean_ctor_set(x_213, 5, x_172); -x_214 = lean_ctor_get(x_7, 0); -lean_inc(x_214); -x_215 = lean_ctor_get(x_7, 1); -lean_inc(x_215); -x_216 = lean_ctor_get(x_7, 2); -lean_inc(x_216); -x_217 = lean_ctor_get(x_7, 3); -lean_inc(x_217); -x_218 = lean_ctor_get(x_7, 4); -lean_inc(x_218); +lean_inc(x_119); +lean_inc(x_118); +lean_inc(x_117); +lean_inc(x_116); +lean_dec(x_31); +x_156 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_157 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_157, 0, x_116); +lean_ctor_set(x_157, 1, x_117); +lean_ctor_set(x_157, 2, x_156); +lean_ctor_set(x_157, 3, x_119); +lean_ctor_set(x_157, 4, x_120); +lean_ctor_set(x_25, 2, x_157); +x_158 = lean_ctor_get(x_7, 0); +lean_inc(x_158); +x_159 = lean_ctor_get(x_7, 1); +lean_inc(x_159); +x_160 = lean_ctor_get(x_7, 2); +lean_inc(x_160); +x_161 = lean_ctor_get(x_7, 3); +lean_inc(x_161); +x_162 = lean_ctor_get(x_7, 4); +lean_inc(x_162); if (lean_is_exclusive(x_7)) { lean_ctor_release(x_7, 0); lean_ctor_release(x_7, 1); lean_ctor_release(x_7, 2); lean_ctor_release(x_7, 3); lean_ctor_release(x_7, 4); - x_219 = x_7; + x_163 = x_7; } else { lean_dec_ref(x_7); - x_219 = lean_box(0); + x_163 = lean_box(0); } -x_220 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_220, 0, x_27); -lean_ctor_set(x_220, 1, x_14); -x_221 = lean_array_push(x_216, x_220); -if (lean_is_scalar(x_219)) { +x_164 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_164, 0, x_27); +lean_ctor_set(x_164, 1, x_14); +x_165 = lean_array_push(x_160, x_164); +if (lean_is_scalar(x_163)) { + x_166 = lean_alloc_ctor(0, 5, 0); +} else { + x_166 = x_163; +} +lean_ctor_set(x_166, 0, x_158); +lean_ctor_set(x_166, 1, x_159); +lean_ctor_set(x_166, 2, x_165); +lean_ctor_set(x_166, 3, x_161); +lean_ctor_set(x_166, 4, x_162); +x_167 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_166, x_25); +if (lean_obj_tag(x_167) == 0) +{ +lean_object* x_168; lean_object* x_169; lean_object* x_170; +x_168 = lean_ctor_get(x_167, 0); +lean_inc(x_168); +x_169 = lean_ctor_get(x_167, 1); +lean_inc(x_169); +lean_dec(x_167); +x_170 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_170, 0, x_168); +x_121 = x_170; +x_122 = x_169; +goto block_155; +} +else +{ +lean_object* x_171; lean_object* x_172; lean_object* x_173; +x_171 = lean_ctor_get(x_167, 0); +lean_inc(x_171); +x_172 = lean_ctor_get(x_167, 1); +lean_inc(x_172); +lean_dec(x_167); +x_173 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_173, 0, x_171); +x_121 = x_173; +x_122 = x_172; +goto block_155; +} +block_155: +{ +if (lean_obj_tag(x_121) == 0) +{ +lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; +x_123 = lean_ctor_get(x_122, 2); +lean_inc(x_123); +x_124 = lean_ctor_get(x_121, 0); +lean_inc(x_124); +lean_dec(x_121); +x_125 = lean_ctor_get(x_122, 0); +lean_inc(x_125); +x_126 = lean_ctor_get(x_122, 1); +lean_inc(x_126); +x_127 = lean_ctor_get(x_122, 3); +lean_inc(x_127); +x_128 = lean_ctor_get(x_122, 4); +lean_inc(x_128); +x_129 = lean_ctor_get(x_122, 5); +lean_inc(x_129); +if (lean_is_exclusive(x_122)) { + lean_ctor_release(x_122, 0); + lean_ctor_release(x_122, 1); + lean_ctor_release(x_122, 2); + lean_ctor_release(x_122, 3); + lean_ctor_release(x_122, 4); + lean_ctor_release(x_122, 5); + x_130 = x_122; +} else { + lean_dec_ref(x_122); + x_130 = lean_box(0); +} +x_131 = lean_ctor_get(x_123, 0); +lean_inc(x_131); +x_132 = lean_ctor_get(x_123, 1); +lean_inc(x_132); +x_133 = lean_ctor_get(x_123, 3); +lean_inc(x_133); +x_134 = lean_ctor_get(x_123, 4); +lean_inc(x_134); +if (lean_is_exclusive(x_123)) { + lean_ctor_release(x_123, 0); + lean_ctor_release(x_123, 1); + lean_ctor_release(x_123, 2); + lean_ctor_release(x_123, 3); + lean_ctor_release(x_123, 4); + x_135 = x_123; +} else { + lean_dec_ref(x_123); + x_135 = lean_box(0); +} +if (lean_is_scalar(x_135)) { + x_136 = lean_alloc_ctor(0, 5, 0); +} else { + x_136 = x_135; +} +lean_ctor_set(x_136, 0, x_131); +lean_ctor_set(x_136, 1, x_132); +lean_ctor_set(x_136, 2, x_118); +lean_ctor_set(x_136, 3, x_133); +lean_ctor_set(x_136, 4, x_134); +if (lean_is_scalar(x_130)) { + x_137 = lean_alloc_ctor(0, 6, 0); +} else { + x_137 = x_130; +} +lean_ctor_set(x_137, 0, x_125); +lean_ctor_set(x_137, 1, x_126); +lean_ctor_set(x_137, 2, x_136); +lean_ctor_set(x_137, 3, x_127); +lean_ctor_set(x_137, 4, x_128); +lean_ctor_set(x_137, 5, x_129); +if (lean_is_scalar(x_26)) { + x_138 = lean_alloc_ctor(1, 2, 0); +} else { + x_138 = x_26; + lean_ctor_set_tag(x_138, 1); +} +lean_ctor_set(x_138, 0, x_124); +lean_ctor_set(x_138, 1, x_137); +return x_138; +} +else +{ +lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_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; +x_139 = lean_ctor_get(x_122, 2); +lean_inc(x_139); +x_140 = lean_ctor_get(x_121, 0); +lean_inc(x_140); +lean_dec(x_121); +x_141 = lean_ctor_get(x_122, 0); +lean_inc(x_141); +x_142 = lean_ctor_get(x_122, 1); +lean_inc(x_142); +x_143 = lean_ctor_get(x_122, 3); +lean_inc(x_143); +x_144 = lean_ctor_get(x_122, 4); +lean_inc(x_144); +x_145 = lean_ctor_get(x_122, 5); +lean_inc(x_145); +if (lean_is_exclusive(x_122)) { + lean_ctor_release(x_122, 0); + lean_ctor_release(x_122, 1); + lean_ctor_release(x_122, 2); + lean_ctor_release(x_122, 3); + lean_ctor_release(x_122, 4); + lean_ctor_release(x_122, 5); + x_146 = x_122; +} else { + lean_dec_ref(x_122); + x_146 = lean_box(0); +} +x_147 = lean_ctor_get(x_139, 0); +lean_inc(x_147); +x_148 = lean_ctor_get(x_139, 1); +lean_inc(x_148); +x_149 = lean_ctor_get(x_139, 3); +lean_inc(x_149); +x_150 = lean_ctor_get(x_139, 4); +lean_inc(x_150); +if (lean_is_exclusive(x_139)) { + lean_ctor_release(x_139, 0); + lean_ctor_release(x_139, 1); + lean_ctor_release(x_139, 2); + lean_ctor_release(x_139, 3); + lean_ctor_release(x_139, 4); + x_151 = x_139; +} else { + lean_dec_ref(x_139); + x_151 = lean_box(0); +} +if (lean_is_scalar(x_151)) { + x_152 = lean_alloc_ctor(0, 5, 0); +} else { + x_152 = x_151; +} +lean_ctor_set(x_152, 0, x_147); +lean_ctor_set(x_152, 1, x_148); +lean_ctor_set(x_152, 2, x_118); +lean_ctor_set(x_152, 3, x_149); +lean_ctor_set(x_152, 4, x_150); +if (lean_is_scalar(x_146)) { + x_153 = lean_alloc_ctor(0, 6, 0); +} else { + x_153 = x_146; +} +lean_ctor_set(x_153, 0, x_141); +lean_ctor_set(x_153, 1, x_142); +lean_ctor_set(x_153, 2, x_152); +lean_ctor_set(x_153, 3, x_143); +lean_ctor_set(x_153, 4, x_144); +lean_ctor_set(x_153, 5, x_145); +if (lean_is_scalar(x_26)) { + x_154 = lean_alloc_ctor(0, 2, 0); +} else { + x_154 = x_26; +} +lean_ctor_set(x_154, 0, x_140); +lean_ctor_set(x_154, 1, x_153); +return x_154; +} +} +} +} +else +{ +lean_object* x_174; lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_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; lean_object* x_231; lean_object* x_232; lean_object* x_233; +x_174 = lean_ctor_get(x_25, 2); +x_175 = lean_ctor_get(x_25, 0); +x_176 = lean_ctor_get(x_25, 1); +x_177 = lean_ctor_get(x_25, 3); +x_178 = lean_ctor_get(x_25, 4); +x_179 = lean_ctor_get(x_25, 5); +lean_inc(x_179); +lean_inc(x_178); +lean_inc(x_177); +lean_inc(x_174); +lean_inc(x_176); +lean_inc(x_175); +lean_dec(x_25); +x_180 = lean_ctor_get(x_174, 0); +lean_inc(x_180); +x_181 = lean_ctor_get(x_174, 1); +lean_inc(x_181); +x_182 = lean_ctor_get(x_174, 2); +lean_inc(x_182); +x_183 = lean_ctor_get(x_174, 3); +lean_inc(x_183); +x_184 = lean_ctor_get(x_174, 4); +lean_inc(x_184); +if (lean_is_exclusive(x_174)) { + lean_ctor_release(x_174, 0); + lean_ctor_release(x_174, 1); + lean_ctor_release(x_174, 2); + lean_ctor_release(x_174, 3); + lean_ctor_release(x_174, 4); + x_185 = x_174; +} else { + lean_dec_ref(x_174); + x_185 = lean_box(0); +} +x_221 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_185)) { x_222 = lean_alloc_ctor(0, 5, 0); } else { - x_222 = x_219; + x_222 = x_185; } -lean_ctor_set(x_222, 0, x_214); -lean_ctor_set(x_222, 1, x_215); +lean_ctor_set(x_222, 0, x_180); +lean_ctor_set(x_222, 1, x_181); lean_ctor_set(x_222, 2, x_221); -lean_ctor_set(x_222, 3, x_217); -lean_ctor_set(x_222, 4, x_218); -x_223 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_222, x_213); -if (lean_obj_tag(x_223) == 0) -{ -lean_object* x_224; lean_object* x_225; lean_object* x_226; -x_224 = lean_ctor_get(x_223, 0); +lean_ctor_set(x_222, 3, x_183); +lean_ctor_set(x_222, 4, x_184); +x_223 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_223, 0, x_175); +lean_ctor_set(x_223, 1, x_176); +lean_ctor_set(x_223, 2, x_222); +lean_ctor_set(x_223, 3, x_177); +lean_ctor_set(x_223, 4, x_178); +lean_ctor_set(x_223, 5, x_179); +x_224 = lean_ctor_get(x_7, 0); lean_inc(x_224); -x_225 = lean_ctor_get(x_223, 1); +x_225 = lean_ctor_get(x_7, 1); lean_inc(x_225); -lean_dec(x_223); -x_226 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_226, 0, x_224); -x_178 = x_226; -x_179 = x_225; -goto block_210; -} -else -{ -lean_object* x_227; lean_object* x_228; lean_object* x_229; -x_227 = lean_ctor_get(x_223, 0); +x_226 = lean_ctor_get(x_7, 2); +lean_inc(x_226); +x_227 = lean_ctor_get(x_7, 3); lean_inc(x_227); -x_228 = lean_ctor_get(x_223, 1); +x_228 = lean_ctor_get(x_7, 4); lean_inc(x_228); -lean_dec(x_223); -x_229 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_229, 0, x_227); -x_178 = x_229; -x_179 = x_228; -goto block_210; +if (lean_is_exclusive(x_7)) { + lean_ctor_release(x_7, 0); + lean_ctor_release(x_7, 1); + lean_ctor_release(x_7, 2); + lean_ctor_release(x_7, 3); + lean_ctor_release(x_7, 4); + x_229 = x_7; +} else { + lean_dec_ref(x_7); + x_229 = lean_box(0); } -block_210: +x_230 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_230, 0, x_27); +lean_ctor_set(x_230, 1, x_14); +x_231 = lean_array_push(x_226, x_230); +if (lean_is_scalar(x_229)) { + x_232 = lean_alloc_ctor(0, 5, 0); +} else { + x_232 = x_229; +} +lean_ctor_set(x_232, 0, x_224); +lean_ctor_set(x_232, 1, x_225); +lean_ctor_set(x_232, 2, x_231); +lean_ctor_set(x_232, 3, x_227); +lean_ctor_set(x_232, 4, x_228); +x_233 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_232, x_223); +if (lean_obj_tag(x_233) == 0) { -if (lean_obj_tag(x_178) == 0) -{ -lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; -x_180 = lean_ctor_get(x_179, 2); -lean_inc(x_180); -x_181 = lean_ctor_get(x_178, 0); -lean_inc(x_181); -lean_dec(x_178); -x_182 = lean_ctor_get(x_179, 0); -lean_inc(x_182); -x_183 = lean_ctor_get(x_179, 1); -lean_inc(x_183); -x_184 = lean_ctor_get(x_179, 3); -lean_inc(x_184); -x_185 = lean_ctor_get(x_179, 4); -lean_inc(x_185); -x_186 = lean_ctor_get(x_179, 5); -lean_inc(x_186); -if (lean_is_exclusive(x_179)) { - lean_ctor_release(x_179, 0); - lean_ctor_release(x_179, 1); - lean_ctor_release(x_179, 2); - lean_ctor_release(x_179, 3); - lean_ctor_release(x_179, 4); - lean_ctor_release(x_179, 5); - x_187 = x_179; -} else { - lean_dec_ref(x_179); - x_187 = lean_box(0); -} -x_188 = lean_ctor_get(x_180, 0); -lean_inc(x_188); -x_189 = lean_ctor_get(x_180, 1); -lean_inc(x_189); -x_190 = lean_ctor_get(x_180, 3); -lean_inc(x_190); -if (lean_is_exclusive(x_180)) { - lean_ctor_release(x_180, 0); - lean_ctor_release(x_180, 1); - lean_ctor_release(x_180, 2); - lean_ctor_release(x_180, 3); - x_191 = x_180; -} else { - lean_dec_ref(x_180); - x_191 = lean_box(0); -} -if (lean_is_scalar(x_191)) { - x_192 = lean_alloc_ctor(0, 4, 0); -} else { - x_192 = x_191; -} -lean_ctor_set(x_192, 0, x_188); -lean_ctor_set(x_192, 1, x_189); -lean_ctor_set(x_192, 2, x_175); -lean_ctor_set(x_192, 3, x_190); -if (lean_is_scalar(x_187)) { - x_193 = lean_alloc_ctor(0, 6, 0); -} else { - x_193 = x_187; -} -lean_ctor_set(x_193, 0, x_182); -lean_ctor_set(x_193, 1, x_183); -lean_ctor_set(x_193, 2, x_192); -lean_ctor_set(x_193, 3, x_184); -lean_ctor_set(x_193, 4, x_185); -lean_ctor_set(x_193, 5, x_186); -if (lean_is_scalar(x_26)) { - x_194 = lean_alloc_ctor(1, 2, 0); -} else { - x_194 = x_26; - lean_ctor_set_tag(x_194, 1); -} -lean_ctor_set(x_194, 0, x_181); -lean_ctor_set(x_194, 1, x_193); -return x_194; +lean_object* x_234; lean_object* x_235; lean_object* x_236; +x_234 = lean_ctor_get(x_233, 0); +lean_inc(x_234); +x_235 = lean_ctor_get(x_233, 1); +lean_inc(x_235); +lean_dec(x_233); +x_236 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_236, 0, x_234); +x_186 = x_236; +x_187 = x_235; +goto block_220; } else { -lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; -x_195 = lean_ctor_get(x_179, 2); -lean_inc(x_195); -x_196 = lean_ctor_get(x_178, 0); +lean_object* x_237; lean_object* x_238; lean_object* x_239; +x_237 = lean_ctor_get(x_233, 0); +lean_inc(x_237); +x_238 = lean_ctor_get(x_233, 1); +lean_inc(x_238); +lean_dec(x_233); +x_239 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_239, 0, x_237); +x_186 = x_239; +x_187 = x_238; +goto block_220; +} +block_220: +{ +if (lean_obj_tag(x_186) == 0) +{ +lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; +x_188 = lean_ctor_get(x_187, 2); +lean_inc(x_188); +x_189 = lean_ctor_get(x_186, 0); +lean_inc(x_189); +lean_dec(x_186); +x_190 = lean_ctor_get(x_187, 0); +lean_inc(x_190); +x_191 = lean_ctor_get(x_187, 1); +lean_inc(x_191); +x_192 = lean_ctor_get(x_187, 3); +lean_inc(x_192); +x_193 = lean_ctor_get(x_187, 4); +lean_inc(x_193); +x_194 = lean_ctor_get(x_187, 5); +lean_inc(x_194); +if (lean_is_exclusive(x_187)) { + lean_ctor_release(x_187, 0); + lean_ctor_release(x_187, 1); + lean_ctor_release(x_187, 2); + lean_ctor_release(x_187, 3); + lean_ctor_release(x_187, 4); + lean_ctor_release(x_187, 5); + x_195 = x_187; +} else { + lean_dec_ref(x_187); + x_195 = lean_box(0); +} +x_196 = lean_ctor_get(x_188, 0); lean_inc(x_196); -lean_dec(x_178); -x_197 = lean_ctor_get(x_179, 0); +x_197 = lean_ctor_get(x_188, 1); lean_inc(x_197); -x_198 = lean_ctor_get(x_179, 1); +x_198 = lean_ctor_get(x_188, 3); lean_inc(x_198); -x_199 = lean_ctor_get(x_179, 3); +x_199 = lean_ctor_get(x_188, 4); lean_inc(x_199); -x_200 = lean_ctor_get(x_179, 4); -lean_inc(x_200); -x_201 = lean_ctor_get(x_179, 5); -lean_inc(x_201); -if (lean_is_exclusive(x_179)) { - lean_ctor_release(x_179, 0); - lean_ctor_release(x_179, 1); - lean_ctor_release(x_179, 2); - lean_ctor_release(x_179, 3); - lean_ctor_release(x_179, 4); - lean_ctor_release(x_179, 5); - x_202 = x_179; +if (lean_is_exclusive(x_188)) { + lean_ctor_release(x_188, 0); + lean_ctor_release(x_188, 1); + lean_ctor_release(x_188, 2); + lean_ctor_release(x_188, 3); + lean_ctor_release(x_188, 4); + x_200 = x_188; } else { - lean_dec_ref(x_179); - x_202 = lean_box(0); + lean_dec_ref(x_188); + x_200 = lean_box(0); } -x_203 = lean_ctor_get(x_195, 0); -lean_inc(x_203); -x_204 = lean_ctor_get(x_195, 1); -lean_inc(x_204); -x_205 = lean_ctor_get(x_195, 3); -lean_inc(x_205); -if (lean_is_exclusive(x_195)) { - lean_ctor_release(x_195, 0); - lean_ctor_release(x_195, 1); - lean_ctor_release(x_195, 2); - lean_ctor_release(x_195, 3); - x_206 = x_195; +if (lean_is_scalar(x_200)) { + x_201 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_195); - x_206 = lean_box(0); + x_201 = x_200; } -if (lean_is_scalar(x_206)) { - x_207 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_201, 0, x_196); +lean_ctor_set(x_201, 1, x_197); +lean_ctor_set(x_201, 2, x_182); +lean_ctor_set(x_201, 3, x_198); +lean_ctor_set(x_201, 4, x_199); +if (lean_is_scalar(x_195)) { + x_202 = lean_alloc_ctor(0, 6, 0); } else { - x_207 = x_206; + x_202 = x_195; } -lean_ctor_set(x_207, 0, x_203); -lean_ctor_set(x_207, 1, x_204); -lean_ctor_set(x_207, 2, x_175); -lean_ctor_set(x_207, 3, x_205); -if (lean_is_scalar(x_202)) { - x_208 = lean_alloc_ctor(0, 6, 0); -} else { - x_208 = x_202; -} -lean_ctor_set(x_208, 0, x_197); -lean_ctor_set(x_208, 1, x_198); -lean_ctor_set(x_208, 2, x_207); -lean_ctor_set(x_208, 3, x_199); -lean_ctor_set(x_208, 4, x_200); -lean_ctor_set(x_208, 5, x_201); +lean_ctor_set(x_202, 0, x_190); +lean_ctor_set(x_202, 1, x_191); +lean_ctor_set(x_202, 2, x_201); +lean_ctor_set(x_202, 3, x_192); +lean_ctor_set(x_202, 4, x_193); +lean_ctor_set(x_202, 5, x_194); if (lean_is_scalar(x_26)) { - x_209 = lean_alloc_ctor(0, 2, 0); + x_203 = lean_alloc_ctor(1, 2, 0); } else { - x_209 = x_26; + x_203 = x_26; + lean_ctor_set_tag(x_203, 1); } -lean_ctor_set(x_209, 0, x_196); -lean_ctor_set(x_209, 1, x_208); -return x_209; +lean_ctor_set(x_203, 0, x_189); +lean_ctor_set(x_203, 1, x_202); +return x_203; +} +else +{ +lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; +x_204 = lean_ctor_get(x_187, 2); +lean_inc(x_204); +x_205 = lean_ctor_get(x_186, 0); +lean_inc(x_205); +lean_dec(x_186); +x_206 = lean_ctor_get(x_187, 0); +lean_inc(x_206); +x_207 = lean_ctor_get(x_187, 1); +lean_inc(x_207); +x_208 = lean_ctor_get(x_187, 3); +lean_inc(x_208); +x_209 = lean_ctor_get(x_187, 4); +lean_inc(x_209); +x_210 = lean_ctor_get(x_187, 5); +lean_inc(x_210); +if (lean_is_exclusive(x_187)) { + lean_ctor_release(x_187, 0); + lean_ctor_release(x_187, 1); + lean_ctor_release(x_187, 2); + lean_ctor_release(x_187, 3); + lean_ctor_release(x_187, 4); + lean_ctor_release(x_187, 5); + x_211 = x_187; +} else { + lean_dec_ref(x_187); + x_211 = lean_box(0); +} +x_212 = lean_ctor_get(x_204, 0); +lean_inc(x_212); +x_213 = lean_ctor_get(x_204, 1); +lean_inc(x_213); +x_214 = lean_ctor_get(x_204, 3); +lean_inc(x_214); +x_215 = lean_ctor_get(x_204, 4); +lean_inc(x_215); +if (lean_is_exclusive(x_204)) { + lean_ctor_release(x_204, 0); + lean_ctor_release(x_204, 1); + lean_ctor_release(x_204, 2); + lean_ctor_release(x_204, 3); + lean_ctor_release(x_204, 4); + x_216 = x_204; +} else { + lean_dec_ref(x_204); + x_216 = lean_box(0); +} +if (lean_is_scalar(x_216)) { + x_217 = lean_alloc_ctor(0, 5, 0); +} else { + x_217 = x_216; +} +lean_ctor_set(x_217, 0, x_212); +lean_ctor_set(x_217, 1, x_213); +lean_ctor_set(x_217, 2, x_182); +lean_ctor_set(x_217, 3, x_214); +lean_ctor_set(x_217, 4, x_215); +if (lean_is_scalar(x_211)) { + x_218 = lean_alloc_ctor(0, 6, 0); +} else { + x_218 = x_211; +} +lean_ctor_set(x_218, 0, x_206); +lean_ctor_set(x_218, 1, x_207); +lean_ctor_set(x_218, 2, x_217); +lean_ctor_set(x_218, 3, x_208); +lean_ctor_set(x_218, 4, x_209); +lean_ctor_set(x_218, 5, x_210); +if (lean_is_scalar(x_26)) { + x_219 = lean_alloc_ctor(0, 2, 0); +} else { + x_219 = x_26; +} +lean_ctor_set(x_219, 0, x_205); +lean_ctor_set(x_219, 1, x_218); +return x_219; } } } } default: { -lean_object* x_230; lean_object* x_231; -x_230 = lean_ctor_get(x_19, 1); -lean_inc(x_230); +lean_object* x_240; lean_object* x_241; +x_240 = lean_ctor_get(x_19, 1); +lean_inc(x_240); lean_dec(x_19); lean_inc(x_7); -x_231 = l_Lean_Meta_isClassExpensive___main(x_18, x_7, x_230); -if (lean_obj_tag(x_231) == 0) +x_241 = l_Lean_Meta_isClassExpensive___main(x_18, x_7, x_240); +if (lean_obj_tag(x_241) == 0) { -lean_object* x_232; -x_232 = lean_ctor_get(x_231, 0); -lean_inc(x_232); -if (lean_obj_tag(x_232) == 0) +lean_object* x_242; +x_242 = lean_ctor_get(x_241, 0); +lean_inc(x_242); +if (lean_obj_tag(x_242) == 0) { -lean_object* x_233; lean_object* x_234; lean_object* x_235; +lean_object* x_243; lean_object* x_244; lean_object* x_245; lean_dec(x_14); -x_233 = lean_ctor_get(x_231, 1); -lean_inc(x_233); -lean_dec(x_231); -x_234 = lean_unsigned_to_nat(1u); -x_235 = lean_nat_add(x_6, x_234); +x_243 = lean_ctor_get(x_241, 1); +lean_inc(x_243); +lean_dec(x_241); +x_244 = lean_unsigned_to_nat(1u); +x_245 = lean_nat_add(x_6, x_244); lean_dec(x_6); -x_6 = x_235; -x_8 = x_233; +x_6 = x_245; +x_8 = x_243; goto _start; } else { -lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; uint8_t x_242; -x_237 = lean_ctor_get(x_231, 1); -lean_inc(x_237); -if (lean_is_exclusive(x_231)) { - lean_ctor_release(x_231, 0); - lean_ctor_release(x_231, 1); - x_238 = x_231; +lean_object* x_247; lean_object* x_248; lean_object* x_249; lean_object* x_250; lean_object* x_251; uint8_t x_252; +x_247 = lean_ctor_get(x_241, 1); +lean_inc(x_247); +if (lean_is_exclusive(x_241)) { + lean_ctor_release(x_241, 0); + lean_ctor_release(x_241, 1); + x_248 = x_241; } else { - lean_dec_ref(x_231); - x_238 = lean_box(0); + lean_dec_ref(x_241); + x_248 = lean_box(0); } -x_239 = lean_ctor_get(x_232, 0); -lean_inc(x_239); -lean_dec(x_232); -x_240 = lean_unsigned_to_nat(1u); -x_241 = lean_nat_add(x_6, x_240); -lean_dec(x_6); -x_242 = !lean_is_exclusive(x_237); -if (x_242 == 0) -{ -lean_object* x_243; uint8_t x_244; -x_243 = lean_ctor_get(x_237, 2); -x_244 = !lean_is_exclusive(x_243); -if (x_244 == 0) -{ -lean_object* x_245; lean_object* x_246; lean_object* x_247; lean_object* x_297; uint8_t x_298; -x_245 = lean_ctor_get(x_243, 2); -x_297 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_243, 2, x_297); -x_298 = !lean_is_exclusive(x_7); -if (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_7, 2); -x_300 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_300, 0, x_239); -lean_ctor_set(x_300, 1, x_14); -x_301 = lean_array_push(x_299, x_300); -lean_ctor_set(x_7, 2, x_301); -x_302 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_241, x_7, x_237); -if (lean_obj_tag(x_302) == 0) -{ -lean_object* x_303; lean_object* x_304; lean_object* x_305; -x_303 = lean_ctor_get(x_302, 0); -lean_inc(x_303); -x_304 = lean_ctor_get(x_302, 1); -lean_inc(x_304); -lean_dec(x_302); -x_305 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_305, 0, x_303); -x_246 = x_305; -x_247 = x_304; -goto block_296; -} -else -{ -lean_object* x_306; lean_object* x_307; lean_object* x_308; -x_306 = lean_ctor_get(x_302, 0); -lean_inc(x_306); -x_307 = lean_ctor_get(x_302, 1); -lean_inc(x_307); -lean_dec(x_302); -x_308 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_308, 0, x_306); -x_246 = x_308; -x_247 = x_307; -goto block_296; -} -} -else -{ -lean_object* x_309; lean_object* x_310; lean_object* x_311; lean_object* x_312; lean_object* x_313; lean_object* x_314; lean_object* x_315; lean_object* x_316; lean_object* x_317; -x_309 = lean_ctor_get(x_7, 0); -x_310 = lean_ctor_get(x_7, 1); -x_311 = lean_ctor_get(x_7, 2); -x_312 = lean_ctor_get(x_7, 3); -x_313 = lean_ctor_get(x_7, 4); -lean_inc(x_313); -lean_inc(x_312); -lean_inc(x_311); -lean_inc(x_310); -lean_inc(x_309); -lean_dec(x_7); -x_314 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_314, 0, x_239); -lean_ctor_set(x_314, 1, x_14); -x_315 = lean_array_push(x_311, x_314); -x_316 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_316, 0, x_309); -lean_ctor_set(x_316, 1, x_310); -lean_ctor_set(x_316, 2, x_315); -lean_ctor_set(x_316, 3, x_312); -lean_ctor_set(x_316, 4, x_313); -x_317 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_241, x_316, x_237); -if (lean_obj_tag(x_317) == 0) -{ -lean_object* x_318; lean_object* x_319; lean_object* x_320; -x_318 = lean_ctor_get(x_317, 0); -lean_inc(x_318); -x_319 = lean_ctor_get(x_317, 1); -lean_inc(x_319); -lean_dec(x_317); -x_320 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_320, 0, x_318); -x_246 = x_320; -x_247 = x_319; -goto block_296; -} -else -{ -lean_object* x_321; lean_object* x_322; lean_object* x_323; -x_321 = lean_ctor_get(x_317, 0); -lean_inc(x_321); -x_322 = lean_ctor_get(x_317, 1); -lean_inc(x_322); -lean_dec(x_317); -x_323 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_323, 0, x_321); -x_246 = x_323; -x_247 = x_322; -goto block_296; -} -} -block_296: -{ -if (lean_obj_tag(x_246) == 0) -{ -lean_object* x_248; lean_object* x_249; uint8_t x_250; -x_248 = lean_ctor_get(x_247, 2); -lean_inc(x_248); -x_249 = lean_ctor_get(x_246, 0); +x_249 = lean_ctor_get(x_242, 0); lean_inc(x_249); -lean_dec(x_246); -x_250 = !lean_is_exclusive(x_247); -if (x_250 == 0) -{ -lean_object* x_251; uint8_t x_252; -x_251 = lean_ctor_get(x_247, 2); -lean_dec(x_251); -x_252 = !lean_is_exclusive(x_248); +lean_dec(x_242); +x_250 = lean_unsigned_to_nat(1u); +x_251 = lean_nat_add(x_6, x_250); +lean_dec(x_6); +x_252 = !lean_is_exclusive(x_247); if (x_252 == 0) { -lean_object* x_253; lean_object* x_254; -x_253 = lean_ctor_get(x_248, 2); -lean_dec(x_253); -lean_ctor_set(x_248, 2, x_245); -if (lean_is_scalar(x_238)) { - x_254 = lean_alloc_ctor(1, 2, 0); -} else { - x_254 = x_238; - lean_ctor_set_tag(x_254, 1); -} -lean_ctor_set(x_254, 0, x_249); -lean_ctor_set(x_254, 1, x_247); -return x_254; +lean_object* x_253; uint8_t x_254; +x_253 = lean_ctor_get(x_247, 2); +x_254 = !lean_is_exclusive(x_253); +if (x_254 == 0) +{ +lean_object* x_255; lean_object* x_256; lean_object* x_257; lean_object* x_311; uint8_t x_312; +x_255 = lean_ctor_get(x_253, 2); +x_311 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_253, 2, x_311); +x_312 = !lean_is_exclusive(x_7); +if (x_312 == 0) +{ +lean_object* x_313; lean_object* x_314; lean_object* x_315; lean_object* x_316; +x_313 = lean_ctor_get(x_7, 2); +x_314 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_314, 0, x_249); +lean_ctor_set(x_314, 1, x_14); +x_315 = lean_array_push(x_313, x_314); +lean_ctor_set(x_7, 2, x_315); +x_316 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_251, x_7, x_247); +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); +x_319 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_319, 0, x_317); +x_256 = x_319; +x_257 = x_318; +goto block_310; } else { -lean_object* x_255; lean_object* x_256; lean_object* x_257; lean_object* x_258; lean_object* x_259; -x_255 = lean_ctor_get(x_248, 0); -x_256 = lean_ctor_get(x_248, 1); -x_257 = lean_ctor_get(x_248, 3); -lean_inc(x_257); -lean_inc(x_256); -lean_inc(x_255); -lean_dec(x_248); -x_258 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_258, 0, x_255); -lean_ctor_set(x_258, 1, x_256); -lean_ctor_set(x_258, 2, x_245); -lean_ctor_set(x_258, 3, x_257); -lean_ctor_set(x_247, 2, x_258); -if (lean_is_scalar(x_238)) { - x_259 = lean_alloc_ctor(1, 2, 0); -} else { - x_259 = x_238; - lean_ctor_set_tag(x_259, 1); -} -lean_ctor_set(x_259, 0, x_249); -lean_ctor_set(x_259, 1, x_247); -return x_259; +lean_object* x_320; lean_object* x_321; lean_object* x_322; +x_320 = lean_ctor_get(x_316, 0); +lean_inc(x_320); +x_321 = lean_ctor_get(x_316, 1); +lean_inc(x_321); +lean_dec(x_316); +x_322 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_322, 0, x_320); +x_256 = x_322; +x_257 = x_321; +goto block_310; } } else { -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_260 = lean_ctor_get(x_247, 0); -x_261 = lean_ctor_get(x_247, 1); -x_262 = lean_ctor_get(x_247, 3); -x_263 = lean_ctor_get(x_247, 4); -x_264 = lean_ctor_get(x_247, 5); -lean_inc(x_264); -lean_inc(x_263); -lean_inc(x_262); -lean_inc(x_261); -lean_inc(x_260); -lean_dec(x_247); -x_265 = lean_ctor_get(x_248, 0); -lean_inc(x_265); -x_266 = lean_ctor_get(x_248, 1); -lean_inc(x_266); -x_267 = lean_ctor_get(x_248, 3); +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; +x_323 = lean_ctor_get(x_7, 0); +x_324 = lean_ctor_get(x_7, 1); +x_325 = lean_ctor_get(x_7, 2); +x_326 = lean_ctor_get(x_7, 3); +x_327 = lean_ctor_get(x_7, 4); +lean_inc(x_327); +lean_inc(x_326); +lean_inc(x_325); +lean_inc(x_324); +lean_inc(x_323); +lean_dec(x_7); +x_328 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_328, 0, x_249); +lean_ctor_set(x_328, 1, x_14); +x_329 = lean_array_push(x_325, x_328); +x_330 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_330, 0, x_323); +lean_ctor_set(x_330, 1, x_324); +lean_ctor_set(x_330, 2, x_329); +lean_ctor_set(x_330, 3, x_326); +lean_ctor_set(x_330, 4, x_327); +x_331 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_251, x_330, x_247); +if (lean_obj_tag(x_331) == 0) +{ +lean_object* x_332; lean_object* x_333; lean_object* x_334; +x_332 = lean_ctor_get(x_331, 0); +lean_inc(x_332); +x_333 = lean_ctor_get(x_331, 1); +lean_inc(x_333); +lean_dec(x_331); +x_334 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_334, 0, x_332); +x_256 = x_334; +x_257 = x_333; +goto block_310; +} +else +{ +lean_object* x_335; lean_object* x_336; lean_object* x_337; +x_335 = lean_ctor_get(x_331, 0); +lean_inc(x_335); +x_336 = lean_ctor_get(x_331, 1); +lean_inc(x_336); +lean_dec(x_331); +x_337 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_337, 0, x_335); +x_256 = x_337; +x_257 = x_336; +goto block_310; +} +} +block_310: +{ +if (lean_obj_tag(x_256) == 0) +{ +lean_object* x_258; lean_object* x_259; uint8_t x_260; +x_258 = lean_ctor_get(x_257, 2); +lean_inc(x_258); +x_259 = lean_ctor_get(x_256, 0); +lean_inc(x_259); +lean_dec(x_256); +x_260 = !lean_is_exclusive(x_257); +if (x_260 == 0) +{ +lean_object* x_261; uint8_t x_262; +x_261 = lean_ctor_get(x_257, 2); +lean_dec(x_261); +x_262 = !lean_is_exclusive(x_258); +if (x_262 == 0) +{ +lean_object* x_263; lean_object* x_264; +x_263 = lean_ctor_get(x_258, 2); +lean_dec(x_263); +lean_ctor_set(x_258, 2, x_255); +if (lean_is_scalar(x_248)) { + x_264 = lean_alloc_ctor(1, 2, 0); +} else { + x_264 = x_248; + lean_ctor_set_tag(x_264, 1); +} +lean_ctor_set(x_264, 0, x_259); +lean_ctor_set(x_264, 1, x_257); +return x_264; +} +else +{ +lean_object* x_265; lean_object* x_266; lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_object* x_270; +x_265 = lean_ctor_get(x_258, 0); +x_266 = lean_ctor_get(x_258, 1); +x_267 = lean_ctor_get(x_258, 3); +x_268 = lean_ctor_get(x_258, 4); +lean_inc(x_268); lean_inc(x_267); -if (lean_is_exclusive(x_248)) { - lean_ctor_release(x_248, 0); - lean_ctor_release(x_248, 1); - lean_ctor_release(x_248, 2); - lean_ctor_release(x_248, 3); - x_268 = x_248; -} else { - lean_dec_ref(x_248); - x_268 = lean_box(0); -} -if (lean_is_scalar(x_268)) { - x_269 = lean_alloc_ctor(0, 4, 0); -} else { - x_269 = x_268; -} +lean_inc(x_266); +lean_inc(x_265); +lean_dec(x_258); +x_269 = lean_alloc_ctor(0, 5, 0); lean_ctor_set(x_269, 0, x_265); lean_ctor_set(x_269, 1, x_266); -lean_ctor_set(x_269, 2, x_245); +lean_ctor_set(x_269, 2, x_255); lean_ctor_set(x_269, 3, x_267); -x_270 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_270, 0, x_260); -lean_ctor_set(x_270, 1, x_261); -lean_ctor_set(x_270, 2, x_269); -lean_ctor_set(x_270, 3, x_262); -lean_ctor_set(x_270, 4, x_263); -lean_ctor_set(x_270, 5, x_264); -if (lean_is_scalar(x_238)) { - x_271 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_269, 4, x_268); +lean_ctor_set(x_257, 2, x_269); +if (lean_is_scalar(x_248)) { + x_270 = lean_alloc_ctor(1, 2, 0); } else { - x_271 = x_238; - lean_ctor_set_tag(x_271, 1); + x_270 = x_248; + lean_ctor_set_tag(x_270, 1); } -lean_ctor_set(x_271, 0, x_249); -lean_ctor_set(x_271, 1, x_270); -return x_271; +lean_ctor_set(x_270, 0, x_259); +lean_ctor_set(x_270, 1, x_257); +return x_270; } } else { -lean_object* x_272; lean_object* x_273; uint8_t x_274; -x_272 = lean_ctor_get(x_247, 2); -lean_inc(x_272); -x_273 = lean_ctor_get(x_246, 0); +lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_object* x_276; lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; lean_object* x_281; lean_object* x_282; lean_object* x_283; +x_271 = lean_ctor_get(x_257, 0); +x_272 = lean_ctor_get(x_257, 1); +x_273 = lean_ctor_get(x_257, 3); +x_274 = lean_ctor_get(x_257, 4); +x_275 = lean_ctor_get(x_257, 5); +lean_inc(x_275); +lean_inc(x_274); lean_inc(x_273); -lean_dec(x_246); -x_274 = !lean_is_exclusive(x_247); -if (x_274 == 0) -{ -lean_object* x_275; uint8_t x_276; -x_275 = lean_ctor_get(x_247, 2); -lean_dec(x_275); -x_276 = !lean_is_exclusive(x_272); -if (x_276 == 0) -{ -lean_object* x_277; lean_object* x_278; -x_277 = lean_ctor_get(x_272, 2); -lean_dec(x_277); -lean_ctor_set(x_272, 2, x_245); -if (lean_is_scalar(x_238)) { - x_278 = lean_alloc_ctor(0, 2, 0); -} else { - x_278 = x_238; -} -lean_ctor_set(x_278, 0, x_273); -lean_ctor_set(x_278, 1, x_247); -return x_278; -} -else -{ -lean_object* x_279; lean_object* x_280; lean_object* x_281; lean_object* x_282; lean_object* x_283; -x_279 = lean_ctor_get(x_272, 0); -x_280 = lean_ctor_get(x_272, 1); -x_281 = lean_ctor_get(x_272, 3); -lean_inc(x_281); -lean_inc(x_280); +lean_inc(x_272); +lean_inc(x_271); +lean_dec(x_257); +x_276 = lean_ctor_get(x_258, 0); +lean_inc(x_276); +x_277 = lean_ctor_get(x_258, 1); +lean_inc(x_277); +x_278 = lean_ctor_get(x_258, 3); +lean_inc(x_278); +x_279 = lean_ctor_get(x_258, 4); lean_inc(x_279); -lean_dec(x_272); -x_282 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_282, 0, x_279); -lean_ctor_set(x_282, 1, x_280); -lean_ctor_set(x_282, 2, x_245); -lean_ctor_set(x_282, 3, x_281); -lean_ctor_set(x_247, 2, x_282); -if (lean_is_scalar(x_238)) { - x_283 = lean_alloc_ctor(0, 2, 0); +if (lean_is_exclusive(x_258)) { + lean_ctor_release(x_258, 0); + lean_ctor_release(x_258, 1); + lean_ctor_release(x_258, 2); + lean_ctor_release(x_258, 3); + lean_ctor_release(x_258, 4); + x_280 = x_258; } else { - x_283 = x_238; + lean_dec_ref(x_258); + x_280 = lean_box(0); } -lean_ctor_set(x_283, 0, x_273); -lean_ctor_set(x_283, 1, x_247); +if (lean_is_scalar(x_280)) { + x_281 = lean_alloc_ctor(0, 5, 0); +} else { + x_281 = x_280; +} +lean_ctor_set(x_281, 0, x_276); +lean_ctor_set(x_281, 1, x_277); +lean_ctor_set(x_281, 2, x_255); +lean_ctor_set(x_281, 3, x_278); +lean_ctor_set(x_281, 4, x_279); +x_282 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_282, 0, x_271); +lean_ctor_set(x_282, 1, x_272); +lean_ctor_set(x_282, 2, x_281); +lean_ctor_set(x_282, 3, x_273); +lean_ctor_set(x_282, 4, x_274); +lean_ctor_set(x_282, 5, x_275); +if (lean_is_scalar(x_248)) { + x_283 = lean_alloc_ctor(1, 2, 0); +} else { + x_283 = x_248; + lean_ctor_set_tag(x_283, 1); +} +lean_ctor_set(x_283, 0, x_259); +lean_ctor_set(x_283, 1, x_282); return x_283; } } else { -lean_object* x_284; lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; lean_object* x_289; lean_object* x_290; lean_object* x_291; lean_object* x_292; lean_object* x_293; lean_object* x_294; lean_object* x_295; -x_284 = lean_ctor_get(x_247, 0); -x_285 = lean_ctor_get(x_247, 1); -x_286 = lean_ctor_get(x_247, 3); -x_287 = lean_ctor_get(x_247, 4); -x_288 = lean_ctor_get(x_247, 5); -lean_inc(x_288); -lean_inc(x_287); -lean_inc(x_286); -lean_inc(x_285); +lean_object* x_284; lean_object* x_285; uint8_t x_286; +x_284 = lean_ctor_get(x_257, 2); lean_inc(x_284); -lean_dec(x_247); -x_289 = lean_ctor_get(x_272, 0); -lean_inc(x_289); -x_290 = lean_ctor_get(x_272, 1); -lean_inc(x_290); -x_291 = lean_ctor_get(x_272, 3); +x_285 = lean_ctor_get(x_256, 0); +lean_inc(x_285); +lean_dec(x_256); +x_286 = !lean_is_exclusive(x_257); +if (x_286 == 0) +{ +lean_object* x_287; uint8_t x_288; +x_287 = lean_ctor_get(x_257, 2); +lean_dec(x_287); +x_288 = !lean_is_exclusive(x_284); +if (x_288 == 0) +{ +lean_object* x_289; lean_object* x_290; +x_289 = lean_ctor_get(x_284, 2); +lean_dec(x_289); +lean_ctor_set(x_284, 2, x_255); +if (lean_is_scalar(x_248)) { + x_290 = lean_alloc_ctor(0, 2, 0); +} else { + x_290 = x_248; +} +lean_ctor_set(x_290, 0, x_285); +lean_ctor_set(x_290, 1, x_257); +return x_290; +} +else +{ +lean_object* x_291; lean_object* x_292; lean_object* x_293; lean_object* x_294; lean_object* x_295; lean_object* x_296; +x_291 = lean_ctor_get(x_284, 0); +x_292 = lean_ctor_get(x_284, 1); +x_293 = lean_ctor_get(x_284, 3); +x_294 = lean_ctor_get(x_284, 4); +lean_inc(x_294); +lean_inc(x_293); +lean_inc(x_292); lean_inc(x_291); -if (lean_is_exclusive(x_272)) { - lean_ctor_release(x_272, 0); - lean_ctor_release(x_272, 1); - lean_ctor_release(x_272, 2); - lean_ctor_release(x_272, 3); - x_292 = x_272; +lean_dec(x_284); +x_295 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_295, 0, x_291); +lean_ctor_set(x_295, 1, x_292); +lean_ctor_set(x_295, 2, x_255); +lean_ctor_set(x_295, 3, x_293); +lean_ctor_set(x_295, 4, x_294); +lean_ctor_set(x_257, 2, x_295); +if (lean_is_scalar(x_248)) { + x_296 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_272); - x_292 = lean_box(0); + x_296 = x_248; } -if (lean_is_scalar(x_292)) { - x_293 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_296, 0, x_285); +lean_ctor_set(x_296, 1, x_257); +return x_296; +} +} +else +{ +lean_object* x_297; lean_object* x_298; lean_object* x_299; lean_object* x_300; lean_object* x_301; lean_object* x_302; lean_object* x_303; lean_object* x_304; lean_object* x_305; lean_object* x_306; lean_object* x_307; lean_object* x_308; lean_object* x_309; +x_297 = lean_ctor_get(x_257, 0); +x_298 = lean_ctor_get(x_257, 1); +x_299 = lean_ctor_get(x_257, 3); +x_300 = lean_ctor_get(x_257, 4); +x_301 = lean_ctor_get(x_257, 5); +lean_inc(x_301); +lean_inc(x_300); +lean_inc(x_299); +lean_inc(x_298); +lean_inc(x_297); +lean_dec(x_257); +x_302 = lean_ctor_get(x_284, 0); +lean_inc(x_302); +x_303 = lean_ctor_get(x_284, 1); +lean_inc(x_303); +x_304 = lean_ctor_get(x_284, 3); +lean_inc(x_304); +x_305 = lean_ctor_get(x_284, 4); +lean_inc(x_305); +if (lean_is_exclusive(x_284)) { + lean_ctor_release(x_284, 0); + lean_ctor_release(x_284, 1); + lean_ctor_release(x_284, 2); + lean_ctor_release(x_284, 3); + lean_ctor_release(x_284, 4); + x_306 = x_284; } else { - x_293 = x_292; + lean_dec_ref(x_284); + x_306 = lean_box(0); } -lean_ctor_set(x_293, 0, x_289); -lean_ctor_set(x_293, 1, x_290); -lean_ctor_set(x_293, 2, x_245); -lean_ctor_set(x_293, 3, x_291); -x_294 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_294, 0, x_284); -lean_ctor_set(x_294, 1, x_285); -lean_ctor_set(x_294, 2, x_293); -lean_ctor_set(x_294, 3, x_286); -lean_ctor_set(x_294, 4, x_287); -lean_ctor_set(x_294, 5, x_288); -if (lean_is_scalar(x_238)) { - x_295 = lean_alloc_ctor(0, 2, 0); +if (lean_is_scalar(x_306)) { + x_307 = lean_alloc_ctor(0, 5, 0); } else { - x_295 = x_238; + x_307 = x_306; } -lean_ctor_set(x_295, 0, x_273); -lean_ctor_set(x_295, 1, x_294); -return x_295; +lean_ctor_set(x_307, 0, x_302); +lean_ctor_set(x_307, 1, x_303); +lean_ctor_set(x_307, 2, x_255); +lean_ctor_set(x_307, 3, x_304); +lean_ctor_set(x_307, 4, x_305); +x_308 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_308, 0, x_297); +lean_ctor_set(x_308, 1, x_298); +lean_ctor_set(x_308, 2, x_307); +lean_ctor_set(x_308, 3, x_299); +lean_ctor_set(x_308, 4, x_300); +lean_ctor_set(x_308, 5, x_301); +if (lean_is_scalar(x_248)) { + x_309 = lean_alloc_ctor(0, 2, 0); +} else { + x_309 = x_248; +} +lean_ctor_set(x_309, 0, x_285); +lean_ctor_set(x_309, 1, x_308); +return x_309; } } } } else { -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_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; -x_324 = lean_ctor_get(x_243, 0); -x_325 = lean_ctor_get(x_243, 1); -x_326 = lean_ctor_get(x_243, 2); -x_327 = lean_ctor_get(x_243, 3); -lean_inc(x_327); -lean_inc(x_326); -lean_inc(x_325); -lean_inc(x_324); -lean_dec(x_243); -x_361 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_362 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_362, 0, x_324); -lean_ctor_set(x_362, 1, x_325); -lean_ctor_set(x_362, 2, x_361); -lean_ctor_set(x_362, 3, x_327); -lean_ctor_set(x_237, 2, x_362); -x_363 = lean_ctor_get(x_7, 0); -lean_inc(x_363); -x_364 = lean_ctor_get(x_7, 1); -lean_inc(x_364); -x_365 = lean_ctor_get(x_7, 2); -lean_inc(x_365); -x_366 = lean_ctor_get(x_7, 3); -lean_inc(x_366); -x_367 = lean_ctor_get(x_7, 4); -lean_inc(x_367); +lean_object* x_338; lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; lean_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; +x_338 = lean_ctor_get(x_253, 0); +x_339 = lean_ctor_get(x_253, 1); +x_340 = lean_ctor_get(x_253, 2); +x_341 = lean_ctor_get(x_253, 3); +x_342 = lean_ctor_get(x_253, 4); +lean_inc(x_342); +lean_inc(x_341); +lean_inc(x_340); +lean_inc(x_339); +lean_inc(x_338); +lean_dec(x_253); +x_378 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_379 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_379, 0, x_338); +lean_ctor_set(x_379, 1, x_339); +lean_ctor_set(x_379, 2, x_378); +lean_ctor_set(x_379, 3, x_341); +lean_ctor_set(x_379, 4, x_342); +lean_ctor_set(x_247, 2, x_379); +x_380 = lean_ctor_get(x_7, 0); +lean_inc(x_380); +x_381 = lean_ctor_get(x_7, 1); +lean_inc(x_381); +x_382 = lean_ctor_get(x_7, 2); +lean_inc(x_382); +x_383 = lean_ctor_get(x_7, 3); +lean_inc(x_383); +x_384 = lean_ctor_get(x_7, 4); +lean_inc(x_384); if (lean_is_exclusive(x_7)) { lean_ctor_release(x_7, 0); lean_ctor_release(x_7, 1); lean_ctor_release(x_7, 2); lean_ctor_release(x_7, 3); lean_ctor_release(x_7, 4); - x_368 = x_7; + x_385 = x_7; } else { lean_dec_ref(x_7); - x_368 = lean_box(0); + x_385 = lean_box(0); } -x_369 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_369, 0, x_239); -lean_ctor_set(x_369, 1, x_14); -x_370 = lean_array_push(x_365, x_369); -if (lean_is_scalar(x_368)) { - x_371 = lean_alloc_ctor(0, 5, 0); +x_386 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_386, 0, x_249); +lean_ctor_set(x_386, 1, x_14); +x_387 = lean_array_push(x_382, x_386); +if (lean_is_scalar(x_385)) { + x_388 = lean_alloc_ctor(0, 5, 0); } else { - x_371 = x_368; + x_388 = x_385; } -lean_ctor_set(x_371, 0, x_363); -lean_ctor_set(x_371, 1, x_364); -lean_ctor_set(x_371, 2, x_370); -lean_ctor_set(x_371, 3, x_366); -lean_ctor_set(x_371, 4, x_367); -x_372 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_241, x_371, x_237); -if (lean_obj_tag(x_372) == 0) +lean_ctor_set(x_388, 0, x_380); +lean_ctor_set(x_388, 1, x_381); +lean_ctor_set(x_388, 2, x_387); +lean_ctor_set(x_388, 3, x_383); +lean_ctor_set(x_388, 4, x_384); +x_389 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_251, x_388, x_247); +if (lean_obj_tag(x_389) == 0) { -lean_object* x_373; lean_object* x_374; lean_object* x_375; -x_373 = lean_ctor_get(x_372, 0); -lean_inc(x_373); -x_374 = lean_ctor_get(x_372, 1); -lean_inc(x_374); -lean_dec(x_372); -x_375 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_375, 0, x_373); -x_328 = x_375; -x_329 = x_374; -goto block_360; +lean_object* x_390; lean_object* x_391; lean_object* x_392; +x_390 = lean_ctor_get(x_389, 0); +lean_inc(x_390); +x_391 = lean_ctor_get(x_389, 1); +lean_inc(x_391); +lean_dec(x_389); +x_392 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_392, 0, x_390); +x_343 = x_392; +x_344 = x_391; +goto block_377; } else { -lean_object* x_376; lean_object* x_377; lean_object* x_378; -x_376 = lean_ctor_get(x_372, 0); -lean_inc(x_376); -x_377 = lean_ctor_get(x_372, 1); -lean_inc(x_377); -lean_dec(x_372); -x_378 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_378, 0, x_376); -x_328 = x_378; -x_329 = x_377; -goto block_360; +lean_object* x_393; lean_object* x_394; lean_object* x_395; +x_393 = lean_ctor_get(x_389, 0); +lean_inc(x_393); +x_394 = lean_ctor_get(x_389, 1); +lean_inc(x_394); +lean_dec(x_389); +x_395 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_395, 0, x_393); +x_343 = x_395; +x_344 = x_394; +goto block_377; } -block_360: +block_377: { -if (lean_obj_tag(x_328) == 0) +if (lean_obj_tag(x_343) == 0) { -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; lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; -x_330 = lean_ctor_get(x_329, 2); -lean_inc(x_330); -x_331 = lean_ctor_get(x_328, 0); -lean_inc(x_331); -lean_dec(x_328); -x_332 = lean_ctor_get(x_329, 0); -lean_inc(x_332); -x_333 = lean_ctor_get(x_329, 1); -lean_inc(x_333); -x_334 = lean_ctor_get(x_329, 3); -lean_inc(x_334); -x_335 = lean_ctor_get(x_329, 4); -lean_inc(x_335); -x_336 = lean_ctor_get(x_329, 5); -lean_inc(x_336); -if (lean_is_exclusive(x_329)) { - lean_ctor_release(x_329, 0); - lean_ctor_release(x_329, 1); - lean_ctor_release(x_329, 2); - lean_ctor_release(x_329, 3); - lean_ctor_release(x_329, 4); - lean_ctor_release(x_329, 5); - x_337 = x_329; -} else { - lean_dec_ref(x_329); - x_337 = lean_box(0); -} -x_338 = lean_ctor_get(x_330, 0); -lean_inc(x_338); -x_339 = lean_ctor_get(x_330, 1); -lean_inc(x_339); -x_340 = lean_ctor_get(x_330, 3); -lean_inc(x_340); -if (lean_is_exclusive(x_330)) { - lean_ctor_release(x_330, 0); - lean_ctor_release(x_330, 1); - lean_ctor_release(x_330, 2); - lean_ctor_release(x_330, 3); - x_341 = x_330; -} else { - lean_dec_ref(x_330); - x_341 = lean_box(0); -} -if (lean_is_scalar(x_341)) { - x_342 = lean_alloc_ctor(0, 4, 0); -} else { - x_342 = x_341; -} -lean_ctor_set(x_342, 0, x_338); -lean_ctor_set(x_342, 1, x_339); -lean_ctor_set(x_342, 2, x_326); -lean_ctor_set(x_342, 3, x_340); -if (lean_is_scalar(x_337)) { - x_343 = lean_alloc_ctor(0, 6, 0); -} else { - x_343 = x_337; -} -lean_ctor_set(x_343, 0, x_332); -lean_ctor_set(x_343, 1, x_333); -lean_ctor_set(x_343, 2, x_342); -lean_ctor_set(x_343, 3, x_334); -lean_ctor_set(x_343, 4, x_335); -lean_ctor_set(x_343, 5, x_336); -if (lean_is_scalar(x_238)) { - x_344 = lean_alloc_ctor(1, 2, 0); -} else { - x_344 = x_238; - lean_ctor_set_tag(x_344, 1); -} -lean_ctor_set(x_344, 0, x_331); -lean_ctor_set(x_344, 1, x_343); -return x_344; -} -else -{ -lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; lean_object* x_350; lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; lean_object* x_358; lean_object* x_359; -x_345 = lean_ctor_get(x_329, 2); +lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; lean_object* x_350; lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; lean_object* x_358; lean_object* x_359; lean_object* x_360; +x_345 = lean_ctor_get(x_344, 2); lean_inc(x_345); -x_346 = lean_ctor_get(x_328, 0); +x_346 = lean_ctor_get(x_343, 0); lean_inc(x_346); -lean_dec(x_328); -x_347 = lean_ctor_get(x_329, 0); +lean_dec(x_343); +x_347 = lean_ctor_get(x_344, 0); lean_inc(x_347); -x_348 = lean_ctor_get(x_329, 1); +x_348 = lean_ctor_get(x_344, 1); lean_inc(x_348); -x_349 = lean_ctor_get(x_329, 3); +x_349 = lean_ctor_get(x_344, 3); lean_inc(x_349); -x_350 = lean_ctor_get(x_329, 4); +x_350 = lean_ctor_get(x_344, 4); lean_inc(x_350); -x_351 = lean_ctor_get(x_329, 5); +x_351 = lean_ctor_get(x_344, 5); lean_inc(x_351); -if (lean_is_exclusive(x_329)) { - lean_ctor_release(x_329, 0); - lean_ctor_release(x_329, 1); - lean_ctor_release(x_329, 2); - lean_ctor_release(x_329, 3); - lean_ctor_release(x_329, 4); - lean_ctor_release(x_329, 5); - x_352 = x_329; +if (lean_is_exclusive(x_344)) { + lean_ctor_release(x_344, 0); + lean_ctor_release(x_344, 1); + lean_ctor_release(x_344, 2); + lean_ctor_release(x_344, 3); + lean_ctor_release(x_344, 4); + lean_ctor_release(x_344, 5); + x_352 = x_344; } else { - lean_dec_ref(x_329); + lean_dec_ref(x_344); x_352 = lean_box(0); } x_353 = lean_ctor_get(x_345, 0); @@ -24915,315 +25591,411 @@ x_354 = lean_ctor_get(x_345, 1); lean_inc(x_354); x_355 = lean_ctor_get(x_345, 3); lean_inc(x_355); +x_356 = lean_ctor_get(x_345, 4); +lean_inc(x_356); if (lean_is_exclusive(x_345)) { lean_ctor_release(x_345, 0); lean_ctor_release(x_345, 1); lean_ctor_release(x_345, 2); lean_ctor_release(x_345, 3); - x_356 = x_345; + lean_ctor_release(x_345, 4); + x_357 = x_345; } else { lean_dec_ref(x_345); - x_356 = lean_box(0); + x_357 = lean_box(0); } -if (lean_is_scalar(x_356)) { - x_357 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_357)) { + x_358 = lean_alloc_ctor(0, 5, 0); } else { - x_357 = x_356; + x_358 = x_357; } -lean_ctor_set(x_357, 0, x_353); -lean_ctor_set(x_357, 1, x_354); -lean_ctor_set(x_357, 2, x_326); -lean_ctor_set(x_357, 3, x_355); +lean_ctor_set(x_358, 0, x_353); +lean_ctor_set(x_358, 1, x_354); +lean_ctor_set(x_358, 2, x_340); +lean_ctor_set(x_358, 3, x_355); +lean_ctor_set(x_358, 4, x_356); if (lean_is_scalar(x_352)) { - x_358 = lean_alloc_ctor(0, 6, 0); + x_359 = lean_alloc_ctor(0, 6, 0); } else { - x_358 = x_352; + x_359 = x_352; } -lean_ctor_set(x_358, 0, x_347); -lean_ctor_set(x_358, 1, x_348); -lean_ctor_set(x_358, 2, x_357); -lean_ctor_set(x_358, 3, x_349); -lean_ctor_set(x_358, 4, x_350); -lean_ctor_set(x_358, 5, x_351); -if (lean_is_scalar(x_238)) { - x_359 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_359, 0, x_347); +lean_ctor_set(x_359, 1, x_348); +lean_ctor_set(x_359, 2, x_358); +lean_ctor_set(x_359, 3, x_349); +lean_ctor_set(x_359, 4, x_350); +lean_ctor_set(x_359, 5, x_351); +if (lean_is_scalar(x_248)) { + x_360 = lean_alloc_ctor(1, 2, 0); } else { - x_359 = x_238; + x_360 = x_248; + lean_ctor_set_tag(x_360, 1); } -lean_ctor_set(x_359, 0, x_346); -lean_ctor_set(x_359, 1, x_358); -return x_359; +lean_ctor_set(x_360, 0, x_346); +lean_ctor_set(x_360, 1, x_359); +return x_360; +} +else +{ +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; lean_object* x_374; lean_object* x_375; lean_object* x_376; +x_361 = lean_ctor_get(x_344, 2); +lean_inc(x_361); +x_362 = lean_ctor_get(x_343, 0); +lean_inc(x_362); +lean_dec(x_343); +x_363 = lean_ctor_get(x_344, 0); +lean_inc(x_363); +x_364 = lean_ctor_get(x_344, 1); +lean_inc(x_364); +x_365 = lean_ctor_get(x_344, 3); +lean_inc(x_365); +x_366 = lean_ctor_get(x_344, 4); +lean_inc(x_366); +x_367 = lean_ctor_get(x_344, 5); +lean_inc(x_367); +if (lean_is_exclusive(x_344)) { + lean_ctor_release(x_344, 0); + lean_ctor_release(x_344, 1); + lean_ctor_release(x_344, 2); + lean_ctor_release(x_344, 3); + lean_ctor_release(x_344, 4); + lean_ctor_release(x_344, 5); + x_368 = x_344; +} else { + lean_dec_ref(x_344); + x_368 = lean_box(0); +} +x_369 = lean_ctor_get(x_361, 0); +lean_inc(x_369); +x_370 = lean_ctor_get(x_361, 1); +lean_inc(x_370); +x_371 = lean_ctor_get(x_361, 3); +lean_inc(x_371); +x_372 = lean_ctor_get(x_361, 4); +lean_inc(x_372); +if (lean_is_exclusive(x_361)) { + lean_ctor_release(x_361, 0); + lean_ctor_release(x_361, 1); + lean_ctor_release(x_361, 2); + lean_ctor_release(x_361, 3); + lean_ctor_release(x_361, 4); + x_373 = x_361; +} else { + lean_dec_ref(x_361); + x_373 = lean_box(0); +} +if (lean_is_scalar(x_373)) { + x_374 = lean_alloc_ctor(0, 5, 0); +} else { + x_374 = x_373; +} +lean_ctor_set(x_374, 0, x_369); +lean_ctor_set(x_374, 1, x_370); +lean_ctor_set(x_374, 2, x_340); +lean_ctor_set(x_374, 3, x_371); +lean_ctor_set(x_374, 4, x_372); +if (lean_is_scalar(x_368)) { + x_375 = lean_alloc_ctor(0, 6, 0); +} else { + x_375 = x_368; +} +lean_ctor_set(x_375, 0, x_363); +lean_ctor_set(x_375, 1, x_364); +lean_ctor_set(x_375, 2, x_374); +lean_ctor_set(x_375, 3, x_365); +lean_ctor_set(x_375, 4, x_366); +lean_ctor_set(x_375, 5, x_367); +if (lean_is_scalar(x_248)) { + x_376 = lean_alloc_ctor(0, 2, 0); +} else { + x_376 = x_248; +} +lean_ctor_set(x_376, 0, x_362); +lean_ctor_set(x_376, 1, x_375); +return x_376; } } } } else { -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; lean_object* x_391; lean_object* x_423; lean_object* x_424; lean_object* x_425; lean_object* x_426; lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; lean_object* x_432; lean_object* x_433; lean_object* x_434; lean_object* x_435; -x_379 = lean_ctor_get(x_237, 2); -x_380 = lean_ctor_get(x_237, 0); -x_381 = lean_ctor_get(x_237, 1); -x_382 = lean_ctor_get(x_237, 3); -x_383 = lean_ctor_get(x_237, 4); -x_384 = lean_ctor_get(x_237, 5); -lean_inc(x_384); -lean_inc(x_383); -lean_inc(x_382); -lean_inc(x_379); -lean_inc(x_381); -lean_inc(x_380); -lean_dec(x_237); -x_385 = lean_ctor_get(x_379, 0); -lean_inc(x_385); -x_386 = lean_ctor_get(x_379, 1); -lean_inc(x_386); -x_387 = lean_ctor_get(x_379, 2); -lean_inc(x_387); -x_388 = lean_ctor_get(x_379, 3); -lean_inc(x_388); -if (lean_is_exclusive(x_379)) { - lean_ctor_release(x_379, 0); - lean_ctor_release(x_379, 1); - lean_ctor_release(x_379, 2); - lean_ctor_release(x_379, 3); - x_389 = x_379; +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; lean_object* x_408; lean_object* x_409; lean_object* x_443; lean_object* x_444; lean_object* x_445; lean_object* x_446; lean_object* x_447; lean_object* x_448; lean_object* x_449; lean_object* x_450; lean_object* x_451; lean_object* x_452; lean_object* x_453; lean_object* x_454; lean_object* x_455; +x_396 = lean_ctor_get(x_247, 2); +x_397 = lean_ctor_get(x_247, 0); +x_398 = lean_ctor_get(x_247, 1); +x_399 = lean_ctor_get(x_247, 3); +x_400 = lean_ctor_get(x_247, 4); +x_401 = lean_ctor_get(x_247, 5); +lean_inc(x_401); +lean_inc(x_400); +lean_inc(x_399); +lean_inc(x_396); +lean_inc(x_398); +lean_inc(x_397); +lean_dec(x_247); +x_402 = lean_ctor_get(x_396, 0); +lean_inc(x_402); +x_403 = lean_ctor_get(x_396, 1); +lean_inc(x_403); +x_404 = lean_ctor_get(x_396, 2); +lean_inc(x_404); +x_405 = lean_ctor_get(x_396, 3); +lean_inc(x_405); +x_406 = lean_ctor_get(x_396, 4); +lean_inc(x_406); +if (lean_is_exclusive(x_396)) { + lean_ctor_release(x_396, 0); + lean_ctor_release(x_396, 1); + lean_ctor_release(x_396, 2); + lean_ctor_release(x_396, 3); + lean_ctor_release(x_396, 4); + x_407 = x_396; } else { - lean_dec_ref(x_379); - x_389 = lean_box(0); + lean_dec_ref(x_396); + x_407 = lean_box(0); } -x_423 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_389)) { - x_424 = lean_alloc_ctor(0, 4, 0); +x_443 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_407)) { + x_444 = lean_alloc_ctor(0, 5, 0); } else { - x_424 = x_389; + x_444 = x_407; } -lean_ctor_set(x_424, 0, x_385); -lean_ctor_set(x_424, 1, x_386); -lean_ctor_set(x_424, 2, x_423); -lean_ctor_set(x_424, 3, x_388); -x_425 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_425, 0, x_380); -lean_ctor_set(x_425, 1, x_381); -lean_ctor_set(x_425, 2, x_424); -lean_ctor_set(x_425, 3, x_382); -lean_ctor_set(x_425, 4, x_383); -lean_ctor_set(x_425, 5, x_384); -x_426 = lean_ctor_get(x_7, 0); -lean_inc(x_426); -x_427 = lean_ctor_get(x_7, 1); -lean_inc(x_427); -x_428 = lean_ctor_get(x_7, 2); -lean_inc(x_428); -x_429 = lean_ctor_get(x_7, 3); -lean_inc(x_429); -x_430 = lean_ctor_get(x_7, 4); -lean_inc(x_430); +lean_ctor_set(x_444, 0, x_402); +lean_ctor_set(x_444, 1, x_403); +lean_ctor_set(x_444, 2, x_443); +lean_ctor_set(x_444, 3, x_405); +lean_ctor_set(x_444, 4, x_406); +x_445 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_445, 0, x_397); +lean_ctor_set(x_445, 1, x_398); +lean_ctor_set(x_445, 2, x_444); +lean_ctor_set(x_445, 3, x_399); +lean_ctor_set(x_445, 4, x_400); +lean_ctor_set(x_445, 5, x_401); +x_446 = lean_ctor_get(x_7, 0); +lean_inc(x_446); +x_447 = lean_ctor_get(x_7, 1); +lean_inc(x_447); +x_448 = lean_ctor_get(x_7, 2); +lean_inc(x_448); +x_449 = lean_ctor_get(x_7, 3); +lean_inc(x_449); +x_450 = lean_ctor_get(x_7, 4); +lean_inc(x_450); if (lean_is_exclusive(x_7)) { lean_ctor_release(x_7, 0); lean_ctor_release(x_7, 1); lean_ctor_release(x_7, 2); lean_ctor_release(x_7, 3); lean_ctor_release(x_7, 4); - x_431 = x_7; + x_451 = x_7; } else { lean_dec_ref(x_7); - x_431 = lean_box(0); + x_451 = lean_box(0); } -x_432 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_432, 0, x_239); -lean_ctor_set(x_432, 1, x_14); -x_433 = lean_array_push(x_428, x_432); -if (lean_is_scalar(x_431)) { - x_434 = lean_alloc_ctor(0, 5, 0); +x_452 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_452, 0, x_249); +lean_ctor_set(x_452, 1, x_14); +x_453 = lean_array_push(x_448, x_452); +if (lean_is_scalar(x_451)) { + x_454 = lean_alloc_ctor(0, 5, 0); } else { - x_434 = x_431; + x_454 = x_451; } -lean_ctor_set(x_434, 0, x_426); -lean_ctor_set(x_434, 1, x_427); -lean_ctor_set(x_434, 2, x_433); -lean_ctor_set(x_434, 3, x_429); -lean_ctor_set(x_434, 4, x_430); -x_435 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_241, x_434, x_425); -if (lean_obj_tag(x_435) == 0) +lean_ctor_set(x_454, 0, x_446); +lean_ctor_set(x_454, 1, x_447); +lean_ctor_set(x_454, 2, x_453); +lean_ctor_set(x_454, 3, x_449); +lean_ctor_set(x_454, 4, x_450); +x_455 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_251, x_454, x_445); +if (lean_obj_tag(x_455) == 0) { -lean_object* x_436; lean_object* x_437; lean_object* x_438; -x_436 = lean_ctor_get(x_435, 0); -lean_inc(x_436); -x_437 = lean_ctor_get(x_435, 1); -lean_inc(x_437); -lean_dec(x_435); -x_438 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_438, 0, x_436); -x_390 = x_438; -x_391 = x_437; -goto block_422; +lean_object* x_456; lean_object* x_457; lean_object* x_458; +x_456 = lean_ctor_get(x_455, 0); +lean_inc(x_456); +x_457 = lean_ctor_get(x_455, 1); +lean_inc(x_457); +lean_dec(x_455); +x_458 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_458, 0, x_456); +x_408 = x_458; +x_409 = x_457; +goto block_442; } else { -lean_object* x_439; lean_object* x_440; lean_object* x_441; -x_439 = lean_ctor_get(x_435, 0); -lean_inc(x_439); -x_440 = lean_ctor_get(x_435, 1); -lean_inc(x_440); -lean_dec(x_435); -x_441 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_441, 0, x_439); -x_390 = x_441; -x_391 = x_440; -goto block_422; +lean_object* x_459; lean_object* x_460; lean_object* x_461; +x_459 = lean_ctor_get(x_455, 0); +lean_inc(x_459); +x_460 = lean_ctor_get(x_455, 1); +lean_inc(x_460); +lean_dec(x_455); +x_461 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_461, 0, x_459); +x_408 = x_461; +x_409 = x_460; +goto block_442; } -block_422: +block_442: { -if (lean_obj_tag(x_390) == 0) +if (lean_obj_tag(x_408) == 0) { -lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; lean_object* x_400; lean_object* x_401; lean_object* x_402; lean_object* x_403; lean_object* x_404; lean_object* x_405; lean_object* x_406; -x_392 = lean_ctor_get(x_391, 2); -lean_inc(x_392); -x_393 = lean_ctor_get(x_390, 0); -lean_inc(x_393); -lean_dec(x_390); -x_394 = lean_ctor_get(x_391, 0); -lean_inc(x_394); -x_395 = lean_ctor_get(x_391, 1); -lean_inc(x_395); -x_396 = lean_ctor_get(x_391, 3); -lean_inc(x_396); -x_397 = lean_ctor_get(x_391, 4); -lean_inc(x_397); -x_398 = lean_ctor_get(x_391, 5); -lean_inc(x_398); -if (lean_is_exclusive(x_391)) { - lean_ctor_release(x_391, 0); - lean_ctor_release(x_391, 1); - lean_ctor_release(x_391, 2); - lean_ctor_release(x_391, 3); - lean_ctor_release(x_391, 4); - lean_ctor_release(x_391, 5); - x_399 = x_391; -} else { - lean_dec_ref(x_391); - x_399 = lean_box(0); -} -x_400 = lean_ctor_get(x_392, 0); -lean_inc(x_400); -x_401 = lean_ctor_get(x_392, 1); -lean_inc(x_401); -x_402 = lean_ctor_get(x_392, 3); -lean_inc(x_402); -if (lean_is_exclusive(x_392)) { - lean_ctor_release(x_392, 0); - lean_ctor_release(x_392, 1); - lean_ctor_release(x_392, 2); - lean_ctor_release(x_392, 3); - x_403 = x_392; -} else { - lean_dec_ref(x_392); - x_403 = lean_box(0); -} -if (lean_is_scalar(x_403)) { - x_404 = lean_alloc_ctor(0, 4, 0); -} else { - x_404 = x_403; -} -lean_ctor_set(x_404, 0, x_400); -lean_ctor_set(x_404, 1, x_401); -lean_ctor_set(x_404, 2, x_387); -lean_ctor_set(x_404, 3, x_402); -if (lean_is_scalar(x_399)) { - x_405 = lean_alloc_ctor(0, 6, 0); -} else { - x_405 = x_399; -} -lean_ctor_set(x_405, 0, x_394); -lean_ctor_set(x_405, 1, x_395); -lean_ctor_set(x_405, 2, x_404); -lean_ctor_set(x_405, 3, x_396); -lean_ctor_set(x_405, 4, x_397); -lean_ctor_set(x_405, 5, x_398); -if (lean_is_scalar(x_238)) { - x_406 = lean_alloc_ctor(1, 2, 0); -} else { - x_406 = x_238; - lean_ctor_set_tag(x_406, 1); -} -lean_ctor_set(x_406, 0, x_393); -lean_ctor_set(x_406, 1, x_405); -return x_406; -} -else -{ -lean_object* x_407; lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_object* x_412; lean_object* x_413; lean_object* x_414; lean_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; -x_407 = lean_ctor_get(x_391, 2); -lean_inc(x_407); -x_408 = lean_ctor_get(x_390, 0); -lean_inc(x_408); -lean_dec(x_390); -x_409 = lean_ctor_get(x_391, 0); -lean_inc(x_409); -x_410 = lean_ctor_get(x_391, 1); +lean_object* x_410; 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_410 = lean_ctor_get(x_409, 2); lean_inc(x_410); -x_411 = lean_ctor_get(x_391, 3); +x_411 = lean_ctor_get(x_408, 0); lean_inc(x_411); -x_412 = lean_ctor_get(x_391, 4); +lean_dec(x_408); +x_412 = lean_ctor_get(x_409, 0); lean_inc(x_412); -x_413 = lean_ctor_get(x_391, 5); +x_413 = lean_ctor_get(x_409, 1); lean_inc(x_413); -if (lean_is_exclusive(x_391)) { - lean_ctor_release(x_391, 0); - lean_ctor_release(x_391, 1); - lean_ctor_release(x_391, 2); - lean_ctor_release(x_391, 3); - lean_ctor_release(x_391, 4); - lean_ctor_release(x_391, 5); - x_414 = x_391; -} else { - lean_dec_ref(x_391); - x_414 = lean_box(0); -} -x_415 = lean_ctor_get(x_407, 0); +x_414 = lean_ctor_get(x_409, 3); +lean_inc(x_414); +x_415 = lean_ctor_get(x_409, 4); lean_inc(x_415); -x_416 = lean_ctor_get(x_407, 1); +x_416 = lean_ctor_get(x_409, 5); lean_inc(x_416); -x_417 = lean_ctor_get(x_407, 3); -lean_inc(x_417); -if (lean_is_exclusive(x_407)) { - lean_ctor_release(x_407, 0); - lean_ctor_release(x_407, 1); - lean_ctor_release(x_407, 2); - lean_ctor_release(x_407, 3); - x_418 = x_407; +if (lean_is_exclusive(x_409)) { + lean_ctor_release(x_409, 0); + lean_ctor_release(x_409, 1); + lean_ctor_release(x_409, 2); + lean_ctor_release(x_409, 3); + lean_ctor_release(x_409, 4); + lean_ctor_release(x_409, 5); + x_417 = x_409; } else { - lean_dec_ref(x_407); - x_418 = lean_box(0); + lean_dec_ref(x_409); + x_417 = lean_box(0); } -if (lean_is_scalar(x_418)) { - x_419 = lean_alloc_ctor(0, 4, 0); +x_418 = lean_ctor_get(x_410, 0); +lean_inc(x_418); +x_419 = lean_ctor_get(x_410, 1); +lean_inc(x_419); +x_420 = lean_ctor_get(x_410, 3); +lean_inc(x_420); +x_421 = lean_ctor_get(x_410, 4); +lean_inc(x_421); +if (lean_is_exclusive(x_410)) { + lean_ctor_release(x_410, 0); + lean_ctor_release(x_410, 1); + lean_ctor_release(x_410, 2); + lean_ctor_release(x_410, 3); + lean_ctor_release(x_410, 4); + x_422 = x_410; } else { - x_419 = x_418; + lean_dec_ref(x_410); + x_422 = lean_box(0); } -lean_ctor_set(x_419, 0, x_415); -lean_ctor_set(x_419, 1, x_416); -lean_ctor_set(x_419, 2, x_387); -lean_ctor_set(x_419, 3, x_417); -if (lean_is_scalar(x_414)) { - x_420 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_422)) { + x_423 = lean_alloc_ctor(0, 5, 0); } else { - x_420 = x_414; + x_423 = x_422; } -lean_ctor_set(x_420, 0, x_409); -lean_ctor_set(x_420, 1, x_410); -lean_ctor_set(x_420, 2, x_419); -lean_ctor_set(x_420, 3, x_411); -lean_ctor_set(x_420, 4, x_412); -lean_ctor_set(x_420, 5, x_413); -if (lean_is_scalar(x_238)) { - x_421 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_423, 0, x_418); +lean_ctor_set(x_423, 1, x_419); +lean_ctor_set(x_423, 2, x_404); +lean_ctor_set(x_423, 3, x_420); +lean_ctor_set(x_423, 4, x_421); +if (lean_is_scalar(x_417)) { + x_424 = lean_alloc_ctor(0, 6, 0); } else { - x_421 = x_238; + x_424 = x_417; } -lean_ctor_set(x_421, 0, x_408); -lean_ctor_set(x_421, 1, x_420); -return x_421; +lean_ctor_set(x_424, 0, x_412); +lean_ctor_set(x_424, 1, x_413); +lean_ctor_set(x_424, 2, x_423); +lean_ctor_set(x_424, 3, x_414); +lean_ctor_set(x_424, 4, x_415); +lean_ctor_set(x_424, 5, x_416); +if (lean_is_scalar(x_248)) { + x_425 = lean_alloc_ctor(1, 2, 0); +} else { + x_425 = x_248; + lean_ctor_set_tag(x_425, 1); +} +lean_ctor_set(x_425, 0, x_411); +lean_ctor_set(x_425, 1, x_424); +return x_425; +} +else +{ +lean_object* x_426; lean_object* x_427; 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; +x_426 = lean_ctor_get(x_409, 2); +lean_inc(x_426); +x_427 = lean_ctor_get(x_408, 0); +lean_inc(x_427); +lean_dec(x_408); +x_428 = lean_ctor_get(x_409, 0); +lean_inc(x_428); +x_429 = lean_ctor_get(x_409, 1); +lean_inc(x_429); +x_430 = lean_ctor_get(x_409, 3); +lean_inc(x_430); +x_431 = lean_ctor_get(x_409, 4); +lean_inc(x_431); +x_432 = lean_ctor_get(x_409, 5); +lean_inc(x_432); +if (lean_is_exclusive(x_409)) { + lean_ctor_release(x_409, 0); + lean_ctor_release(x_409, 1); + lean_ctor_release(x_409, 2); + lean_ctor_release(x_409, 3); + lean_ctor_release(x_409, 4); + lean_ctor_release(x_409, 5); + x_433 = x_409; +} else { + lean_dec_ref(x_409); + x_433 = lean_box(0); +} +x_434 = lean_ctor_get(x_426, 0); +lean_inc(x_434); +x_435 = lean_ctor_get(x_426, 1); +lean_inc(x_435); +x_436 = lean_ctor_get(x_426, 3); +lean_inc(x_436); +x_437 = lean_ctor_get(x_426, 4); +lean_inc(x_437); +if (lean_is_exclusive(x_426)) { + lean_ctor_release(x_426, 0); + lean_ctor_release(x_426, 1); + lean_ctor_release(x_426, 2); + lean_ctor_release(x_426, 3); + lean_ctor_release(x_426, 4); + x_438 = x_426; +} else { + lean_dec_ref(x_426); + x_438 = lean_box(0); +} +if (lean_is_scalar(x_438)) { + x_439 = lean_alloc_ctor(0, 5, 0); +} else { + x_439 = x_438; +} +lean_ctor_set(x_439, 0, x_434); +lean_ctor_set(x_439, 1, x_435); +lean_ctor_set(x_439, 2, x_404); +lean_ctor_set(x_439, 3, x_436); +lean_ctor_set(x_439, 4, x_437); +if (lean_is_scalar(x_433)) { + x_440 = lean_alloc_ctor(0, 6, 0); +} else { + x_440 = x_433; +} +lean_ctor_set(x_440, 0, x_428); +lean_ctor_set(x_440, 1, x_429); +lean_ctor_set(x_440, 2, x_439); +lean_ctor_set(x_440, 3, x_430); +lean_ctor_set(x_440, 4, x_431); +lean_ctor_set(x_440, 5, x_432); +if (lean_is_scalar(x_248)) { + x_441 = lean_alloc_ctor(0, 2, 0); +} else { + x_441 = x_248; +} +lean_ctor_set(x_441, 0, x_427); +lean_ctor_set(x_441, 1, x_440); +return x_441; } } } @@ -25231,29 +26003,29 @@ return x_421; } else { -uint8_t x_442; +uint8_t x_462; lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_442 = !lean_is_exclusive(x_231); -if (x_442 == 0) +x_462 = !lean_is_exclusive(x_241); +if (x_462 == 0) { -return x_231; +return x_241; } else { -lean_object* x_443; lean_object* x_444; lean_object* x_445; -x_443 = lean_ctor_get(x_231, 0); -x_444 = lean_ctor_get(x_231, 1); -lean_inc(x_444); -lean_inc(x_443); -lean_dec(x_231); -x_445 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_445, 0, x_443); -lean_ctor_set(x_445, 1, x_444); -return x_445; +lean_object* x_463; lean_object* x_464; lean_object* x_465; +x_463 = lean_ctor_get(x_241, 0); +x_464 = lean_ctor_get(x_241, 1); +lean_inc(x_464); +lean_inc(x_463); +lean_dec(x_241); +x_465 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_465, 0, x_463); +lean_ctor_set(x_465, 1, x_464); +return x_465; } } } @@ -25261,58 +26033,58 @@ return x_445; } else { -uint8_t x_446; +uint8_t x_466; lean_dec(x_18); lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_446 = !lean_is_exclusive(x_19); -if (x_446 == 0) +x_466 = !lean_is_exclusive(x_19); +if (x_466 == 0) { return x_19; } else { -lean_object* x_447; lean_object* x_448; lean_object* x_449; -x_447 = lean_ctor_get(x_19, 0); -x_448 = lean_ctor_get(x_19, 1); -lean_inc(x_448); -lean_inc(x_447); +lean_object* x_467; lean_object* x_468; lean_object* x_469; +x_467 = lean_ctor_get(x_19, 0); +x_468 = lean_ctor_get(x_19, 1); +lean_inc(x_468); +lean_inc(x_467); lean_dec(x_19); -x_449 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_449, 0, x_447); -lean_ctor_set(x_449, 1, x_448); -return x_449; +x_469 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_469, 0, x_467); +lean_ctor_set(x_469, 1, x_468); +return x_469; } } } else { -uint8_t x_450; +uint8_t x_470; lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_450 = !lean_is_exclusive(x_15); -if (x_450 == 0) +x_470 = !lean_is_exclusive(x_15); +if (x_470 == 0) { return x_15; } else { -lean_object* x_451; lean_object* x_452; lean_object* x_453; -x_451 = lean_ctor_get(x_15, 0); -x_452 = lean_ctor_get(x_15, 1); -lean_inc(x_452); -lean_inc(x_451); +lean_object* x_471; lean_object* x_472; lean_object* x_473; +x_471 = lean_ctor_get(x_15, 0); +x_472 = lean_ctor_get(x_15, 1); +lean_inc(x_472); +lean_inc(x_471); lean_dec(x_15); -x_453 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_453, 0, x_451); -lean_ctor_set(x_453, 1, x_452); -return x_453; +x_473 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_473, 0, x_471); +lean_ctor_set(x_473, 1, x_472); +return x_473; } } } @@ -25458,105 +26230,105 @@ x_37 = lean_ctor_get(x_31, 2); x_38 = !lean_is_exclusive(x_37); if (x_38 == 0) { -lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_91; uint8_t x_92; +lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_95; uint8_t x_96; x_39 = lean_ctor_get(x_37, 2); -x_91 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_37, 2, x_91); -x_92 = !lean_is_exclusive(x_12); -if (x_92 == 0) +x_95 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_37, 2, x_95); +x_96 = !lean_is_exclusive(x_12); +if (x_96 == 0) { -lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; -x_93 = lean_ctor_get(x_12, 2); -x_94 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_94, 0, x_33); -lean_ctor_set(x_94, 1, x_20); -x_95 = lean_array_push(x_93, x_94); -lean_ctor_set(x_12, 2, x_95); -x_96 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_35, x_12, x_31); -if (lean_obj_tag(x_96) == 0) +lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; +x_97 = lean_ctor_get(x_12, 2); +x_98 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_98, 0, x_33); +lean_ctor_set(x_98, 1, x_20); +x_99 = lean_array_push(x_97, x_98); +lean_ctor_set(x_12, 2, x_99); +x_100 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_35, x_12, x_31); +if (lean_obj_tag(x_100) == 0) { -lean_object* x_97; lean_object* x_98; lean_object* x_99; -x_97 = lean_ctor_get(x_96, 0); -lean_inc(x_97); -x_98 = lean_ctor_get(x_96, 1); -lean_inc(x_98); -lean_dec(x_96); -x_99 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_99, 0, x_97); -x_40 = x_99; -x_41 = x_98; -goto block_90; -} -else -{ -lean_object* x_100; lean_object* x_101; lean_object* x_102; -x_100 = lean_ctor_get(x_96, 0); -lean_inc(x_100); -x_101 = lean_ctor_get(x_96, 1); +lean_object* x_101; lean_object* x_102; lean_object* x_103; +x_101 = lean_ctor_get(x_100, 0); lean_inc(x_101); -lean_dec(x_96); -x_102 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_102, 0, x_100); -x_40 = x_102; -x_41 = x_101; -goto block_90; -} +x_102 = lean_ctor_get(x_100, 1); +lean_inc(x_102); +lean_dec(x_100); +x_103 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_103, 0, x_101); +x_40 = x_103; +x_41 = x_102; +goto block_94; } else { -lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; -x_103 = lean_ctor_get(x_12, 0); -x_104 = lean_ctor_get(x_12, 1); -x_105 = lean_ctor_get(x_12, 2); -x_106 = lean_ctor_get(x_12, 3); -x_107 = lean_ctor_get(x_12, 4); -lean_inc(x_107); -lean_inc(x_106); -lean_inc(x_105); +lean_object* x_104; lean_object* x_105; lean_object* x_106; +x_104 = lean_ctor_get(x_100, 0); lean_inc(x_104); -lean_inc(x_103); -lean_dec(x_12); -x_108 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_108, 0, x_33); -lean_ctor_set(x_108, 1, x_20); -x_109 = lean_array_push(x_105, x_108); -x_110 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_110, 0, x_103); -lean_ctor_set(x_110, 1, x_104); -lean_ctor_set(x_110, 2, x_109); -lean_ctor_set(x_110, 3, x_106); -lean_ctor_set(x_110, 4, x_107); -x_111 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_35, x_110, x_31); -if (lean_obj_tag(x_111) == 0) -{ -lean_object* x_112; lean_object* x_113; lean_object* x_114; -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_alloc_ctor(1, 1, 0); -lean_ctor_set(x_114, 0, x_112); -x_40 = x_114; -x_41 = x_113; -goto block_90; +x_105 = lean_ctor_get(x_100, 1); +lean_inc(x_105); +lean_dec(x_100); +x_106 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_106, 0, x_104); +x_40 = x_106; +x_41 = x_105; +goto block_94; +} } else { -lean_object* x_115; lean_object* x_116; lean_object* x_117; -x_115 = lean_ctor_get(x_111, 0); -lean_inc(x_115); -x_116 = lean_ctor_get(x_111, 1); +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; +x_107 = lean_ctor_get(x_12, 0); +x_108 = lean_ctor_get(x_12, 1); +x_109 = lean_ctor_get(x_12, 2); +x_110 = lean_ctor_get(x_12, 3); +x_111 = lean_ctor_get(x_12, 4); +lean_inc(x_111); +lean_inc(x_110); +lean_inc(x_109); +lean_inc(x_108); +lean_inc(x_107); +lean_dec(x_12); +x_112 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_112, 0, x_33); +lean_ctor_set(x_112, 1, x_20); +x_113 = lean_array_push(x_109, x_112); +x_114 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_114, 0, x_107); +lean_ctor_set(x_114, 1, x_108); +lean_ctor_set(x_114, 2, x_113); +lean_ctor_set(x_114, 3, x_110); +lean_ctor_set(x_114, 4, x_111); +x_115 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_35, x_114, x_31); +if (lean_obj_tag(x_115) == 0) +{ +lean_object* x_116; lean_object* x_117; lean_object* x_118; +x_116 = lean_ctor_get(x_115, 0); lean_inc(x_116); -lean_dec(x_111); -x_117 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_117, 0, x_115); -x_40 = x_117; -x_41 = x_116; -goto block_90; +x_117 = lean_ctor_get(x_115, 1); +lean_inc(x_117); +lean_dec(x_115); +x_118 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_118, 0, x_116); +x_40 = x_118; +x_41 = x_117; +goto block_94; +} +else +{ +lean_object* x_119; lean_object* x_120; lean_object* x_121; +x_119 = lean_ctor_get(x_115, 0); +lean_inc(x_119); +x_120 = lean_ctor_get(x_115, 1); +lean_inc(x_120); +lean_dec(x_115); +x_121 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_121, 0, x_119); +x_40 = x_121; +x_41 = x_120; +goto block_94; } } -block_90: +block_94: { if (lean_obj_tag(x_40) == 0) { @@ -25591,1284 +26363,1262 @@ return x_48; } else { -lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; +lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; x_49 = lean_ctor_get(x_42, 0); x_50 = lean_ctor_get(x_42, 1); x_51 = lean_ctor_get(x_42, 3); +x_52 = lean_ctor_get(x_42, 4); +lean_inc(x_52); lean_inc(x_51); lean_inc(x_50); lean_inc(x_49); lean_dec(x_42); -x_52 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_52, 0, x_49); -lean_ctor_set(x_52, 1, x_50); -lean_ctor_set(x_52, 2, x_39); -lean_ctor_set(x_52, 3, x_51); -lean_ctor_set(x_41, 2, x_52); +x_53 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_53, 0, x_49); +lean_ctor_set(x_53, 1, x_50); +lean_ctor_set(x_53, 2, x_39); +lean_ctor_set(x_53, 3, x_51); +lean_ctor_set(x_53, 4, x_52); +lean_ctor_set(x_41, 2, x_53); if (lean_is_scalar(x_32)) { - x_53 = lean_alloc_ctor(1, 2, 0); + x_54 = lean_alloc_ctor(1, 2, 0); } else { - x_53 = x_32; - lean_ctor_set_tag(x_53, 1); + x_54 = x_32; + lean_ctor_set_tag(x_54, 1); } -lean_ctor_set(x_53, 0, x_43); -lean_ctor_set(x_53, 1, x_41); -return x_53; +lean_ctor_set(x_54, 0, x_43); +lean_ctor_set(x_54, 1, x_41); +return x_54; } } else { -lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; -x_54 = lean_ctor_get(x_41, 0); -x_55 = lean_ctor_get(x_41, 1); -x_56 = lean_ctor_get(x_41, 3); -x_57 = lean_ctor_get(x_41, 4); -x_58 = lean_ctor_get(x_41, 5); +lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; +x_55 = lean_ctor_get(x_41, 0); +x_56 = lean_ctor_get(x_41, 1); +x_57 = lean_ctor_get(x_41, 3); +x_58 = lean_ctor_get(x_41, 4); +x_59 = lean_ctor_get(x_41, 5); +lean_inc(x_59); lean_inc(x_58); lean_inc(x_57); lean_inc(x_56); lean_inc(x_55); -lean_inc(x_54); lean_dec(x_41); -x_59 = lean_ctor_get(x_42, 0); -lean_inc(x_59); -x_60 = lean_ctor_get(x_42, 1); +x_60 = lean_ctor_get(x_42, 0); lean_inc(x_60); -x_61 = lean_ctor_get(x_42, 3); +x_61 = lean_ctor_get(x_42, 1); lean_inc(x_61); +x_62 = lean_ctor_get(x_42, 3); +lean_inc(x_62); +x_63 = lean_ctor_get(x_42, 4); +lean_inc(x_63); if (lean_is_exclusive(x_42)) { lean_ctor_release(x_42, 0); lean_ctor_release(x_42, 1); lean_ctor_release(x_42, 2); lean_ctor_release(x_42, 3); - x_62 = x_42; + lean_ctor_release(x_42, 4); + x_64 = x_42; } else { lean_dec_ref(x_42); - x_62 = lean_box(0); + x_64 = lean_box(0); } -if (lean_is_scalar(x_62)) { - x_63 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_64)) { + x_65 = lean_alloc_ctor(0, 5, 0); } else { - x_63 = x_62; + x_65 = x_64; } -lean_ctor_set(x_63, 0, x_59); -lean_ctor_set(x_63, 1, x_60); -lean_ctor_set(x_63, 2, x_39); -lean_ctor_set(x_63, 3, x_61); -x_64 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_64, 0, x_54); -lean_ctor_set(x_64, 1, x_55); -lean_ctor_set(x_64, 2, x_63); -lean_ctor_set(x_64, 3, x_56); -lean_ctor_set(x_64, 4, x_57); -lean_ctor_set(x_64, 5, x_58); +lean_ctor_set(x_65, 0, x_60); +lean_ctor_set(x_65, 1, x_61); +lean_ctor_set(x_65, 2, x_39); +lean_ctor_set(x_65, 3, x_62); +lean_ctor_set(x_65, 4, x_63); +x_66 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_66, 0, x_55); +lean_ctor_set(x_66, 1, x_56); +lean_ctor_set(x_66, 2, x_65); +lean_ctor_set(x_66, 3, x_57); +lean_ctor_set(x_66, 4, x_58); +lean_ctor_set(x_66, 5, x_59); if (lean_is_scalar(x_32)) { - x_65 = lean_alloc_ctor(1, 2, 0); + x_67 = lean_alloc_ctor(1, 2, 0); } else { - x_65 = x_32; - lean_ctor_set_tag(x_65, 1); + x_67 = x_32; + lean_ctor_set_tag(x_67, 1); } -lean_ctor_set(x_65, 0, x_43); -lean_ctor_set(x_65, 1, x_64); -return x_65; +lean_ctor_set(x_67, 0, x_43); +lean_ctor_set(x_67, 1, x_66); +return x_67; } } else { -lean_object* x_66; lean_object* x_67; uint8_t x_68; -x_66 = lean_ctor_get(x_41, 2); -lean_inc(x_66); -x_67 = lean_ctor_get(x_40, 0); -lean_inc(x_67); +lean_object* x_68; lean_object* x_69; uint8_t x_70; +x_68 = lean_ctor_get(x_41, 2); +lean_inc(x_68); +x_69 = lean_ctor_get(x_40, 0); +lean_inc(x_69); lean_dec(x_40); -x_68 = !lean_is_exclusive(x_41); -if (x_68 == 0) -{ -lean_object* x_69; uint8_t x_70; -x_69 = lean_ctor_get(x_41, 2); -lean_dec(x_69); -x_70 = !lean_is_exclusive(x_66); +x_70 = !lean_is_exclusive(x_41); if (x_70 == 0) { -lean_object* x_71; lean_object* x_72; -x_71 = lean_ctor_get(x_66, 2); +lean_object* x_71; uint8_t x_72; +x_71 = lean_ctor_get(x_41, 2); lean_dec(x_71); -lean_ctor_set(x_66, 2, x_39); +x_72 = !lean_is_exclusive(x_68); +if (x_72 == 0) +{ +lean_object* x_73; lean_object* x_74; +x_73 = lean_ctor_get(x_68, 2); +lean_dec(x_73); +lean_ctor_set(x_68, 2, x_39); if (lean_is_scalar(x_32)) { - x_72 = lean_alloc_ctor(0, 2, 0); + x_74 = lean_alloc_ctor(0, 2, 0); } else { - x_72 = x_32; + x_74 = x_32; } -lean_ctor_set(x_72, 0, x_67); -lean_ctor_set(x_72, 1, x_41); -return x_72; +lean_ctor_set(x_74, 0, x_69); +lean_ctor_set(x_74, 1, x_41); +return x_74; } else { -lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; -x_73 = lean_ctor_get(x_66, 0); -x_74 = lean_ctor_get(x_66, 1); -x_75 = lean_ctor_get(x_66, 3); +lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; +x_75 = lean_ctor_get(x_68, 0); +x_76 = lean_ctor_get(x_68, 1); +x_77 = lean_ctor_get(x_68, 3); +x_78 = lean_ctor_get(x_68, 4); +lean_inc(x_78); +lean_inc(x_77); +lean_inc(x_76); lean_inc(x_75); -lean_inc(x_74); -lean_inc(x_73); -lean_dec(x_66); -x_76 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_76, 0, x_73); -lean_ctor_set(x_76, 1, x_74); -lean_ctor_set(x_76, 2, x_39); -lean_ctor_set(x_76, 3, x_75); -lean_ctor_set(x_41, 2, x_76); +lean_dec(x_68); +x_79 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_79, 0, x_75); +lean_ctor_set(x_79, 1, x_76); +lean_ctor_set(x_79, 2, x_39); +lean_ctor_set(x_79, 3, x_77); +lean_ctor_set(x_79, 4, x_78); +lean_ctor_set(x_41, 2, x_79); if (lean_is_scalar(x_32)) { - x_77 = lean_alloc_ctor(0, 2, 0); + x_80 = lean_alloc_ctor(0, 2, 0); } else { - x_77 = x_32; + x_80 = x_32; } -lean_ctor_set(x_77, 0, x_67); -lean_ctor_set(x_77, 1, x_41); -return x_77; +lean_ctor_set(x_80, 0, x_69); +lean_ctor_set(x_80, 1, x_41); +return x_80; } } else { -lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; -x_78 = lean_ctor_get(x_41, 0); -x_79 = lean_ctor_get(x_41, 1); -x_80 = lean_ctor_get(x_41, 3); -x_81 = lean_ctor_get(x_41, 4); -x_82 = lean_ctor_get(x_41, 5); +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; +x_81 = lean_ctor_get(x_41, 0); +x_82 = lean_ctor_get(x_41, 1); +x_83 = lean_ctor_get(x_41, 3); +x_84 = lean_ctor_get(x_41, 4); +x_85 = lean_ctor_get(x_41, 5); +lean_inc(x_85); +lean_inc(x_84); +lean_inc(x_83); lean_inc(x_82); lean_inc(x_81); -lean_inc(x_80); -lean_inc(x_79); -lean_inc(x_78); lean_dec(x_41); -x_83 = lean_ctor_get(x_66, 0); -lean_inc(x_83); -x_84 = lean_ctor_get(x_66, 1); -lean_inc(x_84); -x_85 = lean_ctor_get(x_66, 3); -lean_inc(x_85); -if (lean_is_exclusive(x_66)) { - lean_ctor_release(x_66, 0); - lean_ctor_release(x_66, 1); - lean_ctor_release(x_66, 2); - lean_ctor_release(x_66, 3); - x_86 = x_66; +x_86 = lean_ctor_get(x_68, 0); +lean_inc(x_86); +x_87 = lean_ctor_get(x_68, 1); +lean_inc(x_87); +x_88 = lean_ctor_get(x_68, 3); +lean_inc(x_88); +x_89 = lean_ctor_get(x_68, 4); +lean_inc(x_89); +if (lean_is_exclusive(x_68)) { + lean_ctor_release(x_68, 0); + lean_ctor_release(x_68, 1); + lean_ctor_release(x_68, 2); + lean_ctor_release(x_68, 3); + lean_ctor_release(x_68, 4); + x_90 = x_68; } else { - lean_dec_ref(x_66); - x_86 = lean_box(0); + lean_dec_ref(x_68); + x_90 = lean_box(0); } -if (lean_is_scalar(x_86)) { - x_87 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_90)) { + x_91 = lean_alloc_ctor(0, 5, 0); } else { - x_87 = x_86; + x_91 = x_90; } -lean_ctor_set(x_87, 0, x_83); -lean_ctor_set(x_87, 1, x_84); -lean_ctor_set(x_87, 2, x_39); -lean_ctor_set(x_87, 3, x_85); -x_88 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_88, 0, x_78); -lean_ctor_set(x_88, 1, x_79); -lean_ctor_set(x_88, 2, x_87); -lean_ctor_set(x_88, 3, x_80); -lean_ctor_set(x_88, 4, x_81); -lean_ctor_set(x_88, 5, x_82); +lean_ctor_set(x_91, 0, x_86); +lean_ctor_set(x_91, 1, x_87); +lean_ctor_set(x_91, 2, x_39); +lean_ctor_set(x_91, 3, x_88); +lean_ctor_set(x_91, 4, x_89); +x_92 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_92, 0, x_81); +lean_ctor_set(x_92, 1, x_82); +lean_ctor_set(x_92, 2, x_91); +lean_ctor_set(x_92, 3, x_83); +lean_ctor_set(x_92, 4, x_84); +lean_ctor_set(x_92, 5, x_85); if (lean_is_scalar(x_32)) { - x_89 = lean_alloc_ctor(0, 2, 0); + x_93 = lean_alloc_ctor(0, 2, 0); } else { - x_89 = x_32; + x_93 = x_32; } -lean_ctor_set(x_89, 0, x_67); -lean_ctor_set(x_89, 1, x_88); -return x_89; +lean_ctor_set(x_93, 0, x_69); +lean_ctor_set(x_93, 1, x_92); +return x_93; } } } } else { -lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_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; -x_118 = lean_ctor_get(x_37, 0); -x_119 = lean_ctor_get(x_37, 1); -x_120 = lean_ctor_get(x_37, 2); -x_121 = lean_ctor_get(x_37, 3); -lean_inc(x_121); -lean_inc(x_120); -lean_inc(x_119); -lean_inc(x_118); -lean_dec(x_37); -x_155 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_156 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_156, 0, x_118); -lean_ctor_set(x_156, 1, x_119); -lean_ctor_set(x_156, 2, x_155); -lean_ctor_set(x_156, 3, x_121); -lean_ctor_set(x_31, 2, x_156); -x_157 = lean_ctor_get(x_12, 0); -lean_inc(x_157); -x_158 = lean_ctor_get(x_12, 1); -lean_inc(x_158); -x_159 = lean_ctor_get(x_12, 2); -lean_inc(x_159); -x_160 = lean_ctor_get(x_12, 3); -lean_inc(x_160); -x_161 = lean_ctor_get(x_12, 4); -lean_inc(x_161); -if (lean_is_exclusive(x_12)) { - lean_ctor_release(x_12, 0); - lean_ctor_release(x_12, 1); - lean_ctor_release(x_12, 2); - lean_ctor_release(x_12, 3); - lean_ctor_release(x_12, 4); - x_162 = x_12; -} else { - lean_dec_ref(x_12); - x_162 = lean_box(0); -} -x_163 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_163, 0, x_33); -lean_ctor_set(x_163, 1, x_20); -x_164 = lean_array_push(x_159, x_163); -if (lean_is_scalar(x_162)) { - x_165 = lean_alloc_ctor(0, 5, 0); -} else { - x_165 = x_162; -} -lean_ctor_set(x_165, 0, x_157); -lean_ctor_set(x_165, 1, x_158); -lean_ctor_set(x_165, 2, x_164); -lean_ctor_set(x_165, 3, x_160); -lean_ctor_set(x_165, 4, x_161); -x_166 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_35, x_165, x_31); -if (lean_obj_tag(x_166) == 0) -{ -lean_object* x_167; lean_object* x_168; lean_object* x_169; -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, 1, 0); -lean_ctor_set(x_169, 0, x_167); -x_122 = x_169; -x_123 = x_168; -goto block_154; -} -else -{ -lean_object* x_170; lean_object* x_171; lean_object* x_172; -x_170 = lean_ctor_get(x_166, 0); -lean_inc(x_170); -x_171 = lean_ctor_get(x_166, 1); -lean_inc(x_171); -lean_dec(x_166); -x_172 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_172, 0, x_170); -x_122 = x_172; -x_123 = x_171; -goto block_154; -} -block_154: -{ -if (lean_obj_tag(x_122) == 0) -{ -lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; -x_124 = lean_ctor_get(x_123, 2); -lean_inc(x_124); -x_125 = lean_ctor_get(x_122, 0); -lean_inc(x_125); -lean_dec(x_122); -x_126 = lean_ctor_get(x_123, 0); +lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; lean_object* x_173; +x_122 = lean_ctor_get(x_37, 0); +x_123 = lean_ctor_get(x_37, 1); +x_124 = lean_ctor_get(x_37, 2); +x_125 = lean_ctor_get(x_37, 3); +x_126 = lean_ctor_get(x_37, 4); lean_inc(x_126); -x_127 = lean_ctor_get(x_123, 1); -lean_inc(x_127); -x_128 = lean_ctor_get(x_123, 3); -lean_inc(x_128); -x_129 = lean_ctor_get(x_123, 4); -lean_inc(x_129); -x_130 = lean_ctor_get(x_123, 5); -lean_inc(x_130); -if (lean_is_exclusive(x_123)) { - lean_ctor_release(x_123, 0); - lean_ctor_release(x_123, 1); - lean_ctor_release(x_123, 2); - lean_ctor_release(x_123, 3); - lean_ctor_release(x_123, 4); - lean_ctor_release(x_123, 5); - x_131 = x_123; -} else { - lean_dec_ref(x_123); - x_131 = lean_box(0); -} -x_132 = lean_ctor_get(x_124, 0); -lean_inc(x_132); -x_133 = lean_ctor_get(x_124, 1); -lean_inc(x_133); -x_134 = lean_ctor_get(x_124, 3); -lean_inc(x_134); -if (lean_is_exclusive(x_124)) { - lean_ctor_release(x_124, 0); - lean_ctor_release(x_124, 1); - lean_ctor_release(x_124, 2); - lean_ctor_release(x_124, 3); - x_135 = x_124; -} else { - lean_dec_ref(x_124); - x_135 = lean_box(0); -} -if (lean_is_scalar(x_135)) { - x_136 = lean_alloc_ctor(0, 4, 0); -} else { - x_136 = x_135; -} -lean_ctor_set(x_136, 0, x_132); -lean_ctor_set(x_136, 1, x_133); -lean_ctor_set(x_136, 2, x_120); -lean_ctor_set(x_136, 3, x_134); -if (lean_is_scalar(x_131)) { - x_137 = lean_alloc_ctor(0, 6, 0); -} else { - x_137 = x_131; -} -lean_ctor_set(x_137, 0, x_126); -lean_ctor_set(x_137, 1, x_127); -lean_ctor_set(x_137, 2, x_136); -lean_ctor_set(x_137, 3, x_128); -lean_ctor_set(x_137, 4, x_129); -lean_ctor_set(x_137, 5, x_130); -if (lean_is_scalar(x_32)) { - x_138 = lean_alloc_ctor(1, 2, 0); -} else { - x_138 = x_32; - lean_ctor_set_tag(x_138, 1); -} -lean_ctor_set(x_138, 0, x_125); -lean_ctor_set(x_138, 1, x_137); -return x_138; -} -else -{ -lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_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; -x_139 = lean_ctor_get(x_123, 2); -lean_inc(x_139); -x_140 = lean_ctor_get(x_122, 0); -lean_inc(x_140); -lean_dec(x_122); -x_141 = lean_ctor_get(x_123, 0); -lean_inc(x_141); -x_142 = lean_ctor_get(x_123, 1); -lean_inc(x_142); -x_143 = lean_ctor_get(x_123, 3); -lean_inc(x_143); -x_144 = lean_ctor_get(x_123, 4); -lean_inc(x_144); -x_145 = lean_ctor_get(x_123, 5); -lean_inc(x_145); -if (lean_is_exclusive(x_123)) { - lean_ctor_release(x_123, 0); - lean_ctor_release(x_123, 1); - lean_ctor_release(x_123, 2); - lean_ctor_release(x_123, 3); - lean_ctor_release(x_123, 4); - lean_ctor_release(x_123, 5); - x_146 = x_123; -} else { - lean_dec_ref(x_123); - x_146 = lean_box(0); -} -x_147 = lean_ctor_get(x_139, 0); -lean_inc(x_147); -x_148 = lean_ctor_get(x_139, 1); -lean_inc(x_148); -x_149 = lean_ctor_get(x_139, 3); -lean_inc(x_149); -if (lean_is_exclusive(x_139)) { - lean_ctor_release(x_139, 0); - lean_ctor_release(x_139, 1); - lean_ctor_release(x_139, 2); - lean_ctor_release(x_139, 3); - x_150 = x_139; -} else { - lean_dec_ref(x_139); - x_150 = lean_box(0); -} -if (lean_is_scalar(x_150)) { - x_151 = lean_alloc_ctor(0, 4, 0); -} else { - x_151 = x_150; -} -lean_ctor_set(x_151, 0, x_147); -lean_ctor_set(x_151, 1, x_148); -lean_ctor_set(x_151, 2, x_120); -lean_ctor_set(x_151, 3, x_149); -if (lean_is_scalar(x_146)) { - x_152 = lean_alloc_ctor(0, 6, 0); -} else { - x_152 = x_146; -} -lean_ctor_set(x_152, 0, x_141); -lean_ctor_set(x_152, 1, x_142); -lean_ctor_set(x_152, 2, x_151); -lean_ctor_set(x_152, 3, x_143); -lean_ctor_set(x_152, 4, x_144); -lean_ctor_set(x_152, 5, x_145); -if (lean_is_scalar(x_32)) { - x_153 = lean_alloc_ctor(0, 2, 0); -} else { - x_153 = x_32; -} -lean_ctor_set(x_153, 0, x_140); -lean_ctor_set(x_153, 1, x_152); -return x_153; -} -} -} -} -else -{ -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; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; lean_object* x_224; lean_object* x_225; lean_object* x_226; lean_object* x_227; lean_object* x_228; lean_object* x_229; -x_173 = lean_ctor_get(x_31, 2); -x_174 = lean_ctor_get(x_31, 0); -x_175 = lean_ctor_get(x_31, 1); -x_176 = lean_ctor_get(x_31, 3); -x_177 = lean_ctor_get(x_31, 4); -x_178 = lean_ctor_get(x_31, 5); -lean_inc(x_178); -lean_inc(x_177); -lean_inc(x_176); -lean_inc(x_173); -lean_inc(x_175); -lean_inc(x_174); -lean_dec(x_31); -x_179 = lean_ctor_get(x_173, 0); -lean_inc(x_179); -x_180 = lean_ctor_get(x_173, 1); -lean_inc(x_180); -x_181 = lean_ctor_get(x_173, 2); -lean_inc(x_181); -x_182 = lean_ctor_get(x_173, 3); -lean_inc(x_182); -if (lean_is_exclusive(x_173)) { - lean_ctor_release(x_173, 0); - lean_ctor_release(x_173, 1); - lean_ctor_release(x_173, 2); - lean_ctor_release(x_173, 3); - x_183 = x_173; -} else { - lean_dec_ref(x_173); - x_183 = lean_box(0); -} -x_217 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_183)) { - x_218 = lean_alloc_ctor(0, 4, 0); -} else { - x_218 = x_183; -} -lean_ctor_set(x_218, 0, x_179); -lean_ctor_set(x_218, 1, x_180); -lean_ctor_set(x_218, 2, x_217); -lean_ctor_set(x_218, 3, x_182); -x_219 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_219, 0, x_174); -lean_ctor_set(x_219, 1, x_175); -lean_ctor_set(x_219, 2, x_218); -lean_ctor_set(x_219, 3, x_176); -lean_ctor_set(x_219, 4, x_177); -lean_ctor_set(x_219, 5, x_178); -x_220 = lean_ctor_get(x_12, 0); -lean_inc(x_220); -x_221 = lean_ctor_get(x_12, 1); -lean_inc(x_221); -x_222 = lean_ctor_get(x_12, 2); -lean_inc(x_222); -x_223 = lean_ctor_get(x_12, 3); -lean_inc(x_223); -x_224 = lean_ctor_get(x_12, 4); -lean_inc(x_224); +lean_inc(x_125); +lean_inc(x_124); +lean_inc(x_123); +lean_inc(x_122); +lean_dec(x_37); +x_162 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_163 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_163, 0, x_122); +lean_ctor_set(x_163, 1, x_123); +lean_ctor_set(x_163, 2, x_162); +lean_ctor_set(x_163, 3, x_125); +lean_ctor_set(x_163, 4, x_126); +lean_ctor_set(x_31, 2, x_163); +x_164 = lean_ctor_get(x_12, 0); +lean_inc(x_164); +x_165 = lean_ctor_get(x_12, 1); +lean_inc(x_165); +x_166 = lean_ctor_get(x_12, 2); +lean_inc(x_166); +x_167 = lean_ctor_get(x_12, 3); +lean_inc(x_167); +x_168 = lean_ctor_get(x_12, 4); +lean_inc(x_168); if (lean_is_exclusive(x_12)) { lean_ctor_release(x_12, 0); lean_ctor_release(x_12, 1); lean_ctor_release(x_12, 2); lean_ctor_release(x_12, 3); lean_ctor_release(x_12, 4); - x_225 = x_12; + x_169 = x_12; } else { lean_dec_ref(x_12); - x_225 = lean_box(0); + x_169 = lean_box(0); } -x_226 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_226, 0, x_33); -lean_ctor_set(x_226, 1, x_20); -x_227 = lean_array_push(x_222, x_226); -if (lean_is_scalar(x_225)) { +x_170 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_170, 0, x_33); +lean_ctor_set(x_170, 1, x_20); +x_171 = lean_array_push(x_166, x_170); +if (lean_is_scalar(x_169)) { + x_172 = lean_alloc_ctor(0, 5, 0); +} else { + x_172 = x_169; +} +lean_ctor_set(x_172, 0, x_164); +lean_ctor_set(x_172, 1, x_165); +lean_ctor_set(x_172, 2, x_171); +lean_ctor_set(x_172, 3, x_167); +lean_ctor_set(x_172, 4, x_168); +x_173 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_35, x_172, x_31); +if (lean_obj_tag(x_173) == 0) +{ +lean_object* x_174; lean_object* x_175; lean_object* x_176; +x_174 = lean_ctor_get(x_173, 0); +lean_inc(x_174); +x_175 = lean_ctor_get(x_173, 1); +lean_inc(x_175); +lean_dec(x_173); +x_176 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_176, 0, x_174); +x_127 = x_176; +x_128 = x_175; +goto block_161; +} +else +{ +lean_object* x_177; lean_object* x_178; lean_object* x_179; +x_177 = lean_ctor_get(x_173, 0); +lean_inc(x_177); +x_178 = lean_ctor_get(x_173, 1); +lean_inc(x_178); +lean_dec(x_173); +x_179 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_179, 0, x_177); +x_127 = x_179; +x_128 = x_178; +goto block_161; +} +block_161: +{ +if (lean_obj_tag(x_127) == 0) +{ +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; +x_129 = lean_ctor_get(x_128, 2); +lean_inc(x_129); +x_130 = lean_ctor_get(x_127, 0); +lean_inc(x_130); +lean_dec(x_127); +x_131 = lean_ctor_get(x_128, 0); +lean_inc(x_131); +x_132 = lean_ctor_get(x_128, 1); +lean_inc(x_132); +x_133 = lean_ctor_get(x_128, 3); +lean_inc(x_133); +x_134 = lean_ctor_get(x_128, 4); +lean_inc(x_134); +x_135 = lean_ctor_get(x_128, 5); +lean_inc(x_135); +if (lean_is_exclusive(x_128)) { + lean_ctor_release(x_128, 0); + lean_ctor_release(x_128, 1); + lean_ctor_release(x_128, 2); + lean_ctor_release(x_128, 3); + lean_ctor_release(x_128, 4); + lean_ctor_release(x_128, 5); + x_136 = x_128; +} else { + lean_dec_ref(x_128); + x_136 = lean_box(0); +} +x_137 = lean_ctor_get(x_129, 0); +lean_inc(x_137); +x_138 = lean_ctor_get(x_129, 1); +lean_inc(x_138); +x_139 = lean_ctor_get(x_129, 3); +lean_inc(x_139); +x_140 = lean_ctor_get(x_129, 4); +lean_inc(x_140); +if (lean_is_exclusive(x_129)) { + lean_ctor_release(x_129, 0); + lean_ctor_release(x_129, 1); + lean_ctor_release(x_129, 2); + lean_ctor_release(x_129, 3); + lean_ctor_release(x_129, 4); + x_141 = x_129; +} else { + lean_dec_ref(x_129); + x_141 = lean_box(0); +} +if (lean_is_scalar(x_141)) { + x_142 = lean_alloc_ctor(0, 5, 0); +} else { + x_142 = x_141; +} +lean_ctor_set(x_142, 0, x_137); +lean_ctor_set(x_142, 1, x_138); +lean_ctor_set(x_142, 2, x_124); +lean_ctor_set(x_142, 3, x_139); +lean_ctor_set(x_142, 4, x_140); +if (lean_is_scalar(x_136)) { + x_143 = lean_alloc_ctor(0, 6, 0); +} else { + x_143 = x_136; +} +lean_ctor_set(x_143, 0, x_131); +lean_ctor_set(x_143, 1, x_132); +lean_ctor_set(x_143, 2, x_142); +lean_ctor_set(x_143, 3, x_133); +lean_ctor_set(x_143, 4, x_134); +lean_ctor_set(x_143, 5, x_135); +if (lean_is_scalar(x_32)) { + x_144 = lean_alloc_ctor(1, 2, 0); +} else { + x_144 = x_32; + lean_ctor_set_tag(x_144, 1); +} +lean_ctor_set(x_144, 0, x_130); +lean_ctor_set(x_144, 1, x_143); +return x_144; +} +else +{ +lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_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; +x_145 = lean_ctor_get(x_128, 2); +lean_inc(x_145); +x_146 = lean_ctor_get(x_127, 0); +lean_inc(x_146); +lean_dec(x_127); +x_147 = lean_ctor_get(x_128, 0); +lean_inc(x_147); +x_148 = lean_ctor_get(x_128, 1); +lean_inc(x_148); +x_149 = lean_ctor_get(x_128, 3); +lean_inc(x_149); +x_150 = lean_ctor_get(x_128, 4); +lean_inc(x_150); +x_151 = lean_ctor_get(x_128, 5); +lean_inc(x_151); +if (lean_is_exclusive(x_128)) { + lean_ctor_release(x_128, 0); + lean_ctor_release(x_128, 1); + lean_ctor_release(x_128, 2); + lean_ctor_release(x_128, 3); + lean_ctor_release(x_128, 4); + lean_ctor_release(x_128, 5); + x_152 = x_128; +} else { + lean_dec_ref(x_128); + x_152 = lean_box(0); +} +x_153 = lean_ctor_get(x_145, 0); +lean_inc(x_153); +x_154 = lean_ctor_get(x_145, 1); +lean_inc(x_154); +x_155 = lean_ctor_get(x_145, 3); +lean_inc(x_155); +x_156 = lean_ctor_get(x_145, 4); +lean_inc(x_156); +if (lean_is_exclusive(x_145)) { + lean_ctor_release(x_145, 0); + lean_ctor_release(x_145, 1); + lean_ctor_release(x_145, 2); + lean_ctor_release(x_145, 3); + lean_ctor_release(x_145, 4); + x_157 = x_145; +} else { + lean_dec_ref(x_145); + x_157 = lean_box(0); +} +if (lean_is_scalar(x_157)) { + x_158 = lean_alloc_ctor(0, 5, 0); +} else { + x_158 = x_157; +} +lean_ctor_set(x_158, 0, x_153); +lean_ctor_set(x_158, 1, x_154); +lean_ctor_set(x_158, 2, x_124); +lean_ctor_set(x_158, 3, x_155); +lean_ctor_set(x_158, 4, x_156); +if (lean_is_scalar(x_152)) { + x_159 = lean_alloc_ctor(0, 6, 0); +} else { + x_159 = x_152; +} +lean_ctor_set(x_159, 0, x_147); +lean_ctor_set(x_159, 1, x_148); +lean_ctor_set(x_159, 2, x_158); +lean_ctor_set(x_159, 3, x_149); +lean_ctor_set(x_159, 4, x_150); +lean_ctor_set(x_159, 5, x_151); +if (lean_is_scalar(x_32)) { + x_160 = lean_alloc_ctor(0, 2, 0); +} else { + x_160 = x_32; +} +lean_ctor_set(x_160, 0, x_146); +lean_ctor_set(x_160, 1, x_159); +return x_160; +} +} +} +} +else +{ +lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; 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_227; lean_object* x_228; lean_object* x_229; lean_object* x_230; lean_object* x_231; lean_object* x_232; lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_object* x_236; lean_object* x_237; lean_object* x_238; lean_object* x_239; +x_180 = lean_ctor_get(x_31, 2); +x_181 = lean_ctor_get(x_31, 0); +x_182 = lean_ctor_get(x_31, 1); +x_183 = lean_ctor_get(x_31, 3); +x_184 = lean_ctor_get(x_31, 4); +x_185 = lean_ctor_get(x_31, 5); +lean_inc(x_185); +lean_inc(x_184); +lean_inc(x_183); +lean_inc(x_180); +lean_inc(x_182); +lean_inc(x_181); +lean_dec(x_31); +x_186 = lean_ctor_get(x_180, 0); +lean_inc(x_186); +x_187 = lean_ctor_get(x_180, 1); +lean_inc(x_187); +x_188 = lean_ctor_get(x_180, 2); +lean_inc(x_188); +x_189 = lean_ctor_get(x_180, 3); +lean_inc(x_189); +x_190 = lean_ctor_get(x_180, 4); +lean_inc(x_190); +if (lean_is_exclusive(x_180)) { + lean_ctor_release(x_180, 0); + lean_ctor_release(x_180, 1); + lean_ctor_release(x_180, 2); + lean_ctor_release(x_180, 3); + lean_ctor_release(x_180, 4); + x_191 = x_180; +} else { + lean_dec_ref(x_180); + x_191 = lean_box(0); +} +x_227 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_191)) { x_228 = lean_alloc_ctor(0, 5, 0); } else { - x_228 = x_225; + x_228 = x_191; } -lean_ctor_set(x_228, 0, x_220); -lean_ctor_set(x_228, 1, x_221); +lean_ctor_set(x_228, 0, x_186); +lean_ctor_set(x_228, 1, x_187); lean_ctor_set(x_228, 2, x_227); -lean_ctor_set(x_228, 3, x_223); -lean_ctor_set(x_228, 4, x_224); -x_229 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_35, x_228, x_219); -if (lean_obj_tag(x_229) == 0) -{ -lean_object* x_230; lean_object* x_231; lean_object* x_232; -x_230 = lean_ctor_get(x_229, 0); +lean_ctor_set(x_228, 3, x_189); +lean_ctor_set(x_228, 4, x_190); +x_229 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_229, 0, x_181); +lean_ctor_set(x_229, 1, x_182); +lean_ctor_set(x_229, 2, x_228); +lean_ctor_set(x_229, 3, x_183); +lean_ctor_set(x_229, 4, x_184); +lean_ctor_set(x_229, 5, x_185); +x_230 = lean_ctor_get(x_12, 0); lean_inc(x_230); -x_231 = lean_ctor_get(x_229, 1); +x_231 = lean_ctor_get(x_12, 1); lean_inc(x_231); -lean_dec(x_229); -x_232 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_232, 0, x_230); -x_184 = x_232; -x_185 = x_231; -goto block_216; -} -else -{ -lean_object* x_233; lean_object* x_234; lean_object* x_235; -x_233 = lean_ctor_get(x_229, 0); +x_232 = lean_ctor_get(x_12, 2); +lean_inc(x_232); +x_233 = lean_ctor_get(x_12, 3); lean_inc(x_233); -x_234 = lean_ctor_get(x_229, 1); +x_234 = lean_ctor_get(x_12, 4); lean_inc(x_234); -lean_dec(x_229); -x_235 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_235, 0, x_233); -x_184 = x_235; -x_185 = x_234; -goto block_216; +if (lean_is_exclusive(x_12)) { + lean_ctor_release(x_12, 0); + lean_ctor_release(x_12, 1); + lean_ctor_release(x_12, 2); + lean_ctor_release(x_12, 3); + lean_ctor_release(x_12, 4); + x_235 = x_12; +} else { + lean_dec_ref(x_12); + x_235 = lean_box(0); } -block_216: +x_236 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_236, 0, x_33); +lean_ctor_set(x_236, 1, x_20); +x_237 = lean_array_push(x_232, x_236); +if (lean_is_scalar(x_235)) { + x_238 = lean_alloc_ctor(0, 5, 0); +} else { + x_238 = x_235; +} +lean_ctor_set(x_238, 0, x_230); +lean_ctor_set(x_238, 1, x_231); +lean_ctor_set(x_238, 2, x_237); +lean_ctor_set(x_238, 3, x_233); +lean_ctor_set(x_238, 4, x_234); +x_239 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_35, x_238, x_229); +if (lean_obj_tag(x_239) == 0) { -if (lean_obj_tag(x_184) == 0) -{ -lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; -x_186 = lean_ctor_get(x_185, 2); -lean_inc(x_186); -x_187 = lean_ctor_get(x_184, 0); -lean_inc(x_187); -lean_dec(x_184); -x_188 = lean_ctor_get(x_185, 0); -lean_inc(x_188); -x_189 = lean_ctor_get(x_185, 1); -lean_inc(x_189); -x_190 = lean_ctor_get(x_185, 3); -lean_inc(x_190); -x_191 = lean_ctor_get(x_185, 4); -lean_inc(x_191); -x_192 = lean_ctor_get(x_185, 5); -lean_inc(x_192); -if (lean_is_exclusive(x_185)) { - lean_ctor_release(x_185, 0); - lean_ctor_release(x_185, 1); - lean_ctor_release(x_185, 2); - lean_ctor_release(x_185, 3); - lean_ctor_release(x_185, 4); - lean_ctor_release(x_185, 5); - x_193 = x_185; -} else { - lean_dec_ref(x_185); - x_193 = lean_box(0); -} -x_194 = lean_ctor_get(x_186, 0); -lean_inc(x_194); -x_195 = lean_ctor_get(x_186, 1); -lean_inc(x_195); -x_196 = lean_ctor_get(x_186, 3); -lean_inc(x_196); -if (lean_is_exclusive(x_186)) { - lean_ctor_release(x_186, 0); - lean_ctor_release(x_186, 1); - lean_ctor_release(x_186, 2); - lean_ctor_release(x_186, 3); - x_197 = x_186; -} else { - lean_dec_ref(x_186); - x_197 = lean_box(0); -} -if (lean_is_scalar(x_197)) { - x_198 = lean_alloc_ctor(0, 4, 0); -} else { - x_198 = x_197; -} -lean_ctor_set(x_198, 0, x_194); -lean_ctor_set(x_198, 1, x_195); -lean_ctor_set(x_198, 2, x_181); -lean_ctor_set(x_198, 3, x_196); -if (lean_is_scalar(x_193)) { - x_199 = lean_alloc_ctor(0, 6, 0); -} else { - x_199 = x_193; -} -lean_ctor_set(x_199, 0, x_188); -lean_ctor_set(x_199, 1, x_189); -lean_ctor_set(x_199, 2, x_198); -lean_ctor_set(x_199, 3, x_190); -lean_ctor_set(x_199, 4, x_191); -lean_ctor_set(x_199, 5, x_192); -if (lean_is_scalar(x_32)) { - x_200 = lean_alloc_ctor(1, 2, 0); -} else { - x_200 = x_32; - lean_ctor_set_tag(x_200, 1); -} -lean_ctor_set(x_200, 0, x_187); -lean_ctor_set(x_200, 1, x_199); -return x_200; +lean_object* x_240; lean_object* x_241; lean_object* x_242; +x_240 = lean_ctor_get(x_239, 0); +lean_inc(x_240); +x_241 = lean_ctor_get(x_239, 1); +lean_inc(x_241); +lean_dec(x_239); +x_242 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_242, 0, x_240); +x_192 = x_242; +x_193 = x_241; +goto block_226; } else { -lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; -x_201 = lean_ctor_get(x_185, 2); -lean_inc(x_201); -x_202 = lean_ctor_get(x_184, 0); +lean_object* x_243; lean_object* x_244; lean_object* x_245; +x_243 = lean_ctor_get(x_239, 0); +lean_inc(x_243); +x_244 = lean_ctor_get(x_239, 1); +lean_inc(x_244); +lean_dec(x_239); +x_245 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_245, 0, x_243); +x_192 = x_245; +x_193 = x_244; +goto block_226; +} +block_226: +{ +if (lean_obj_tag(x_192) == 0) +{ +lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; +x_194 = lean_ctor_get(x_193, 2); +lean_inc(x_194); +x_195 = lean_ctor_get(x_192, 0); +lean_inc(x_195); +lean_dec(x_192); +x_196 = lean_ctor_get(x_193, 0); +lean_inc(x_196); +x_197 = lean_ctor_get(x_193, 1); +lean_inc(x_197); +x_198 = lean_ctor_get(x_193, 3); +lean_inc(x_198); +x_199 = lean_ctor_get(x_193, 4); +lean_inc(x_199); +x_200 = lean_ctor_get(x_193, 5); +lean_inc(x_200); +if (lean_is_exclusive(x_193)) { + lean_ctor_release(x_193, 0); + lean_ctor_release(x_193, 1); + lean_ctor_release(x_193, 2); + lean_ctor_release(x_193, 3); + lean_ctor_release(x_193, 4); + lean_ctor_release(x_193, 5); + x_201 = x_193; +} else { + lean_dec_ref(x_193); + x_201 = lean_box(0); +} +x_202 = lean_ctor_get(x_194, 0); lean_inc(x_202); -lean_dec(x_184); -x_203 = lean_ctor_get(x_185, 0); +x_203 = lean_ctor_get(x_194, 1); lean_inc(x_203); -x_204 = lean_ctor_get(x_185, 1); +x_204 = lean_ctor_get(x_194, 3); lean_inc(x_204); -x_205 = lean_ctor_get(x_185, 3); +x_205 = lean_ctor_get(x_194, 4); lean_inc(x_205); -x_206 = lean_ctor_get(x_185, 4); -lean_inc(x_206); -x_207 = lean_ctor_get(x_185, 5); -lean_inc(x_207); -if (lean_is_exclusive(x_185)) { - lean_ctor_release(x_185, 0); - lean_ctor_release(x_185, 1); - lean_ctor_release(x_185, 2); - lean_ctor_release(x_185, 3); - lean_ctor_release(x_185, 4); - lean_ctor_release(x_185, 5); - x_208 = x_185; +if (lean_is_exclusive(x_194)) { + lean_ctor_release(x_194, 0); + lean_ctor_release(x_194, 1); + lean_ctor_release(x_194, 2); + lean_ctor_release(x_194, 3); + lean_ctor_release(x_194, 4); + x_206 = x_194; } else { - lean_dec_ref(x_185); - x_208 = lean_box(0); + lean_dec_ref(x_194); + x_206 = lean_box(0); } -x_209 = lean_ctor_get(x_201, 0); -lean_inc(x_209); -x_210 = lean_ctor_get(x_201, 1); -lean_inc(x_210); -x_211 = lean_ctor_get(x_201, 3); -lean_inc(x_211); -if (lean_is_exclusive(x_201)) { - lean_ctor_release(x_201, 0); - lean_ctor_release(x_201, 1); - lean_ctor_release(x_201, 2); - lean_ctor_release(x_201, 3); - x_212 = x_201; +if (lean_is_scalar(x_206)) { + x_207 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_201); - x_212 = lean_box(0); + x_207 = x_206; } -if (lean_is_scalar(x_212)) { - x_213 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_207, 0, x_202); +lean_ctor_set(x_207, 1, x_203); +lean_ctor_set(x_207, 2, x_188); +lean_ctor_set(x_207, 3, x_204); +lean_ctor_set(x_207, 4, x_205); +if (lean_is_scalar(x_201)) { + x_208 = lean_alloc_ctor(0, 6, 0); } else { - x_213 = x_212; + x_208 = x_201; } -lean_ctor_set(x_213, 0, x_209); -lean_ctor_set(x_213, 1, x_210); -lean_ctor_set(x_213, 2, x_181); -lean_ctor_set(x_213, 3, x_211); -if (lean_is_scalar(x_208)) { - x_214 = lean_alloc_ctor(0, 6, 0); -} else { - x_214 = x_208; -} -lean_ctor_set(x_214, 0, x_203); -lean_ctor_set(x_214, 1, x_204); -lean_ctor_set(x_214, 2, x_213); -lean_ctor_set(x_214, 3, x_205); -lean_ctor_set(x_214, 4, x_206); -lean_ctor_set(x_214, 5, x_207); +lean_ctor_set(x_208, 0, x_196); +lean_ctor_set(x_208, 1, x_197); +lean_ctor_set(x_208, 2, x_207); +lean_ctor_set(x_208, 3, x_198); +lean_ctor_set(x_208, 4, x_199); +lean_ctor_set(x_208, 5, x_200); if (lean_is_scalar(x_32)) { - x_215 = lean_alloc_ctor(0, 2, 0); + x_209 = lean_alloc_ctor(1, 2, 0); } else { - x_215 = x_32; + x_209 = x_32; + lean_ctor_set_tag(x_209, 1); } -lean_ctor_set(x_215, 0, x_202); -lean_ctor_set(x_215, 1, x_214); -return x_215; +lean_ctor_set(x_209, 0, x_195); +lean_ctor_set(x_209, 1, x_208); +return x_209; +} +else +{ +lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; lean_object* x_224; lean_object* x_225; +x_210 = lean_ctor_get(x_193, 2); +lean_inc(x_210); +x_211 = lean_ctor_get(x_192, 0); +lean_inc(x_211); +lean_dec(x_192); +x_212 = lean_ctor_get(x_193, 0); +lean_inc(x_212); +x_213 = lean_ctor_get(x_193, 1); +lean_inc(x_213); +x_214 = lean_ctor_get(x_193, 3); +lean_inc(x_214); +x_215 = lean_ctor_get(x_193, 4); +lean_inc(x_215); +x_216 = lean_ctor_get(x_193, 5); +lean_inc(x_216); +if (lean_is_exclusive(x_193)) { + lean_ctor_release(x_193, 0); + lean_ctor_release(x_193, 1); + lean_ctor_release(x_193, 2); + lean_ctor_release(x_193, 3); + lean_ctor_release(x_193, 4); + lean_ctor_release(x_193, 5); + x_217 = x_193; +} else { + lean_dec_ref(x_193); + x_217 = lean_box(0); +} +x_218 = lean_ctor_get(x_210, 0); +lean_inc(x_218); +x_219 = lean_ctor_get(x_210, 1); +lean_inc(x_219); +x_220 = lean_ctor_get(x_210, 3); +lean_inc(x_220); +x_221 = lean_ctor_get(x_210, 4); +lean_inc(x_221); +if (lean_is_exclusive(x_210)) { + lean_ctor_release(x_210, 0); + lean_ctor_release(x_210, 1); + lean_ctor_release(x_210, 2); + lean_ctor_release(x_210, 3); + lean_ctor_release(x_210, 4); + x_222 = x_210; +} else { + lean_dec_ref(x_210); + x_222 = lean_box(0); +} +if (lean_is_scalar(x_222)) { + x_223 = lean_alloc_ctor(0, 5, 0); +} else { + x_223 = x_222; +} +lean_ctor_set(x_223, 0, x_218); +lean_ctor_set(x_223, 1, x_219); +lean_ctor_set(x_223, 2, x_188); +lean_ctor_set(x_223, 3, x_220); +lean_ctor_set(x_223, 4, x_221); +if (lean_is_scalar(x_217)) { + x_224 = lean_alloc_ctor(0, 6, 0); +} else { + x_224 = x_217; +} +lean_ctor_set(x_224, 0, x_212); +lean_ctor_set(x_224, 1, x_213); +lean_ctor_set(x_224, 2, x_223); +lean_ctor_set(x_224, 3, x_214); +lean_ctor_set(x_224, 4, x_215); +lean_ctor_set(x_224, 5, x_216); +if (lean_is_scalar(x_32)) { + x_225 = lean_alloc_ctor(0, 2, 0); +} else { + x_225 = x_32; +} +lean_ctor_set(x_225, 0, x_211); +lean_ctor_set(x_225, 1, x_224); +return x_225; } } } } default: { -lean_object* x_236; lean_object* x_237; -x_236 = lean_ctor_get(x_25, 1); -lean_inc(x_236); +lean_object* x_246; lean_object* x_247; +x_246 = lean_ctor_get(x_25, 1); +lean_inc(x_246); lean_dec(x_25); lean_inc(x_12); -x_237 = l_Lean_Meta_isClassExpensive___main(x_24, x_12, x_236); -if (lean_obj_tag(x_237) == 0) +x_247 = l_Lean_Meta_isClassExpensive___main(x_24, x_12, x_246); +if (lean_obj_tag(x_247) == 0) { -lean_object* x_238; -x_238 = lean_ctor_get(x_237, 0); -lean_inc(x_238); -if (lean_obj_tag(x_238) == 0) +lean_object* x_248; +x_248 = lean_ctor_get(x_247, 0); +lean_inc(x_248); +if (lean_obj_tag(x_248) == 0) { -lean_object* x_239; lean_object* x_240; lean_object* x_241; +lean_object* x_249; lean_object* x_250; lean_object* x_251; lean_dec(x_20); -x_239 = lean_ctor_get(x_237, 1); -lean_inc(x_239); -lean_dec(x_237); -x_240 = lean_unsigned_to_nat(1u); -x_241 = lean_nat_add(x_11, x_240); +x_249 = lean_ctor_get(x_247, 1); +lean_inc(x_249); +lean_dec(x_247); +x_250 = lean_unsigned_to_nat(1u); +x_251 = lean_nat_add(x_11, x_250); lean_dec(x_11); -x_11 = x_241; -x_13 = x_239; +x_11 = x_251; +x_13 = x_249; goto _start; } else { -lean_object* x_243; lean_object* x_244; lean_object* x_245; lean_object* x_246; lean_object* x_247; uint8_t x_248; -x_243 = lean_ctor_get(x_237, 1); -lean_inc(x_243); -if (lean_is_exclusive(x_237)) { - lean_ctor_release(x_237, 0); - lean_ctor_release(x_237, 1); - x_244 = x_237; +lean_object* x_253; lean_object* x_254; lean_object* x_255; lean_object* x_256; lean_object* x_257; uint8_t x_258; +x_253 = lean_ctor_get(x_247, 1); +lean_inc(x_253); +if (lean_is_exclusive(x_247)) { + lean_ctor_release(x_247, 0); + lean_ctor_release(x_247, 1); + x_254 = x_247; } else { - lean_dec_ref(x_237); - x_244 = lean_box(0); + lean_dec_ref(x_247); + x_254 = lean_box(0); } -x_245 = lean_ctor_get(x_238, 0); -lean_inc(x_245); -lean_dec(x_238); -x_246 = lean_unsigned_to_nat(1u); -x_247 = lean_nat_add(x_11, x_246); -lean_dec(x_11); -x_248 = !lean_is_exclusive(x_243); -if (x_248 == 0) -{ -lean_object* x_249; uint8_t x_250; -x_249 = lean_ctor_get(x_243, 2); -x_250 = !lean_is_exclusive(x_249); -if (x_250 == 0) -{ -lean_object* x_251; lean_object* x_252; lean_object* x_253; lean_object* x_303; uint8_t x_304; -x_251 = lean_ctor_get(x_249, 2); -x_303 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_249, 2, x_303); -x_304 = !lean_is_exclusive(x_12); -if (x_304 == 0) -{ -lean_object* x_305; lean_object* x_306; lean_object* x_307; lean_object* x_308; -x_305 = lean_ctor_get(x_12, 2); -x_306 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_306, 0, x_245); -lean_ctor_set(x_306, 1, x_20); -x_307 = lean_array_push(x_305, x_306); -lean_ctor_set(x_12, 2, x_307); -x_308 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_247, x_12, x_243); -if (lean_obj_tag(x_308) == 0) -{ -lean_object* x_309; lean_object* x_310; lean_object* x_311; -x_309 = lean_ctor_get(x_308, 0); -lean_inc(x_309); -x_310 = lean_ctor_get(x_308, 1); -lean_inc(x_310); -lean_dec(x_308); -x_311 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_311, 0, x_309); -x_252 = x_311; -x_253 = x_310; -goto block_302; -} -else -{ -lean_object* x_312; lean_object* x_313; lean_object* x_314; -x_312 = lean_ctor_get(x_308, 0); -lean_inc(x_312); -x_313 = lean_ctor_get(x_308, 1); -lean_inc(x_313); -lean_dec(x_308); -x_314 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_314, 0, x_312); -x_252 = x_314; -x_253 = x_313; -goto block_302; -} -} -else -{ -lean_object* x_315; lean_object* x_316; lean_object* x_317; lean_object* x_318; lean_object* x_319; lean_object* x_320; lean_object* x_321; lean_object* x_322; lean_object* x_323; -x_315 = lean_ctor_get(x_12, 0); -x_316 = lean_ctor_get(x_12, 1); -x_317 = lean_ctor_get(x_12, 2); -x_318 = lean_ctor_get(x_12, 3); -x_319 = lean_ctor_get(x_12, 4); -lean_inc(x_319); -lean_inc(x_318); -lean_inc(x_317); -lean_inc(x_316); -lean_inc(x_315); -lean_dec(x_12); -x_320 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_320, 0, x_245); -lean_ctor_set(x_320, 1, x_20); -x_321 = lean_array_push(x_317, x_320); -x_322 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_322, 0, x_315); -lean_ctor_set(x_322, 1, x_316); -lean_ctor_set(x_322, 2, x_321); -lean_ctor_set(x_322, 3, x_318); -lean_ctor_set(x_322, 4, x_319); -x_323 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_247, x_322, x_243); -if (lean_obj_tag(x_323) == 0) -{ -lean_object* x_324; lean_object* x_325; lean_object* x_326; -x_324 = lean_ctor_get(x_323, 0); -lean_inc(x_324); -x_325 = lean_ctor_get(x_323, 1); -lean_inc(x_325); -lean_dec(x_323); -x_326 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_326, 0, x_324); -x_252 = x_326; -x_253 = x_325; -goto block_302; -} -else -{ -lean_object* x_327; lean_object* x_328; lean_object* x_329; -x_327 = lean_ctor_get(x_323, 0); -lean_inc(x_327); -x_328 = lean_ctor_get(x_323, 1); -lean_inc(x_328); -lean_dec(x_323); -x_329 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_329, 0, x_327); -x_252 = x_329; -x_253 = x_328; -goto block_302; -} -} -block_302: -{ -if (lean_obj_tag(x_252) == 0) -{ -lean_object* x_254; lean_object* x_255; uint8_t x_256; -x_254 = lean_ctor_get(x_253, 2); -lean_inc(x_254); -x_255 = lean_ctor_get(x_252, 0); +x_255 = lean_ctor_get(x_248, 0); lean_inc(x_255); -lean_dec(x_252); -x_256 = !lean_is_exclusive(x_253); -if (x_256 == 0) -{ -lean_object* x_257; uint8_t x_258; -x_257 = lean_ctor_get(x_253, 2); -lean_dec(x_257); -x_258 = !lean_is_exclusive(x_254); +lean_dec(x_248); +x_256 = lean_unsigned_to_nat(1u); +x_257 = lean_nat_add(x_11, x_256); +lean_dec(x_11); +x_258 = !lean_is_exclusive(x_253); if (x_258 == 0) { -lean_object* x_259; lean_object* x_260; -x_259 = lean_ctor_get(x_254, 2); -lean_dec(x_259); -lean_ctor_set(x_254, 2, x_251); -if (lean_is_scalar(x_244)) { - x_260 = lean_alloc_ctor(1, 2, 0); -} else { - x_260 = x_244; - lean_ctor_set_tag(x_260, 1); -} -lean_ctor_set(x_260, 0, x_255); -lean_ctor_set(x_260, 1, x_253); -return x_260; +lean_object* x_259; uint8_t x_260; +x_259 = lean_ctor_get(x_253, 2); +x_260 = !lean_is_exclusive(x_259); +if (x_260 == 0) +{ +lean_object* x_261; lean_object* x_262; lean_object* x_263; lean_object* x_317; uint8_t x_318; +x_261 = lean_ctor_get(x_259, 2); +x_317 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_259, 2, x_317); +x_318 = !lean_is_exclusive(x_12); +if (x_318 == 0) +{ +lean_object* x_319; lean_object* x_320; lean_object* x_321; lean_object* x_322; +x_319 = lean_ctor_get(x_12, 2); +x_320 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_320, 0, x_255); +lean_ctor_set(x_320, 1, x_20); +x_321 = lean_array_push(x_319, x_320); +lean_ctor_set(x_12, 2, x_321); +x_322 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_257, x_12, x_253); +if (lean_obj_tag(x_322) == 0) +{ +lean_object* x_323; lean_object* x_324; lean_object* x_325; +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_alloc_ctor(1, 1, 0); +lean_ctor_set(x_325, 0, x_323); +x_262 = x_325; +x_263 = x_324; +goto block_316; } else { -lean_object* x_261; lean_object* x_262; lean_object* x_263; lean_object* x_264; lean_object* x_265; -x_261 = lean_ctor_get(x_254, 0); -x_262 = lean_ctor_get(x_254, 1); -x_263 = lean_ctor_get(x_254, 3); -lean_inc(x_263); -lean_inc(x_262); -lean_inc(x_261); -lean_dec(x_254); -x_264 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_264, 0, x_261); -lean_ctor_set(x_264, 1, x_262); -lean_ctor_set(x_264, 2, x_251); -lean_ctor_set(x_264, 3, x_263); -lean_ctor_set(x_253, 2, x_264); -if (lean_is_scalar(x_244)) { - x_265 = lean_alloc_ctor(1, 2, 0); -} else { - x_265 = x_244; - lean_ctor_set_tag(x_265, 1); -} -lean_ctor_set(x_265, 0, x_255); -lean_ctor_set(x_265, 1, x_253); -return x_265; +lean_object* x_326; lean_object* x_327; lean_object* x_328; +x_326 = lean_ctor_get(x_322, 0); +lean_inc(x_326); +x_327 = lean_ctor_get(x_322, 1); +lean_inc(x_327); +lean_dec(x_322); +x_328 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_328, 0, x_326); +x_262 = x_328; +x_263 = x_327; +goto block_316; } } else { -lean_object* x_266; lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_object* x_270; lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_object* x_276; lean_object* x_277; -x_266 = lean_ctor_get(x_253, 0); -x_267 = lean_ctor_get(x_253, 1); -x_268 = lean_ctor_get(x_253, 3); -x_269 = lean_ctor_get(x_253, 4); -x_270 = lean_ctor_get(x_253, 5); -lean_inc(x_270); -lean_inc(x_269); -lean_inc(x_268); -lean_inc(x_267); -lean_inc(x_266); -lean_dec(x_253); -x_271 = lean_ctor_get(x_254, 0); -lean_inc(x_271); -x_272 = lean_ctor_get(x_254, 1); -lean_inc(x_272); -x_273 = lean_ctor_get(x_254, 3); +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; +x_329 = lean_ctor_get(x_12, 0); +x_330 = lean_ctor_get(x_12, 1); +x_331 = lean_ctor_get(x_12, 2); +x_332 = lean_ctor_get(x_12, 3); +x_333 = lean_ctor_get(x_12, 4); +lean_inc(x_333); +lean_inc(x_332); +lean_inc(x_331); +lean_inc(x_330); +lean_inc(x_329); +lean_dec(x_12); +x_334 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_334, 0, x_255); +lean_ctor_set(x_334, 1, x_20); +x_335 = lean_array_push(x_331, x_334); +x_336 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_336, 0, x_329); +lean_ctor_set(x_336, 1, x_330); +lean_ctor_set(x_336, 2, x_335); +lean_ctor_set(x_336, 3, x_332); +lean_ctor_set(x_336, 4, x_333); +x_337 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_257, x_336, x_253); +if (lean_obj_tag(x_337) == 0) +{ +lean_object* x_338; lean_object* x_339; lean_object* x_340; +x_338 = lean_ctor_get(x_337, 0); +lean_inc(x_338); +x_339 = lean_ctor_get(x_337, 1); +lean_inc(x_339); +lean_dec(x_337); +x_340 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_340, 0, x_338); +x_262 = x_340; +x_263 = x_339; +goto block_316; +} +else +{ +lean_object* x_341; lean_object* x_342; lean_object* x_343; +x_341 = lean_ctor_get(x_337, 0); +lean_inc(x_341); +x_342 = lean_ctor_get(x_337, 1); +lean_inc(x_342); +lean_dec(x_337); +x_343 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_343, 0, x_341); +x_262 = x_343; +x_263 = x_342; +goto block_316; +} +} +block_316: +{ +if (lean_obj_tag(x_262) == 0) +{ +lean_object* x_264; lean_object* x_265; uint8_t x_266; +x_264 = lean_ctor_get(x_263, 2); +lean_inc(x_264); +x_265 = lean_ctor_get(x_262, 0); +lean_inc(x_265); +lean_dec(x_262); +x_266 = !lean_is_exclusive(x_263); +if (x_266 == 0) +{ +lean_object* x_267; uint8_t x_268; +x_267 = lean_ctor_get(x_263, 2); +lean_dec(x_267); +x_268 = !lean_is_exclusive(x_264); +if (x_268 == 0) +{ +lean_object* x_269; lean_object* x_270; +x_269 = lean_ctor_get(x_264, 2); +lean_dec(x_269); +lean_ctor_set(x_264, 2, x_261); +if (lean_is_scalar(x_254)) { + x_270 = lean_alloc_ctor(1, 2, 0); +} else { + x_270 = x_254; + lean_ctor_set_tag(x_270, 1); +} +lean_ctor_set(x_270, 0, x_265); +lean_ctor_set(x_270, 1, x_263); +return x_270; +} +else +{ +lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_object* x_276; +x_271 = lean_ctor_get(x_264, 0); +x_272 = lean_ctor_get(x_264, 1); +x_273 = lean_ctor_get(x_264, 3); +x_274 = lean_ctor_get(x_264, 4); +lean_inc(x_274); lean_inc(x_273); -if (lean_is_exclusive(x_254)) { - lean_ctor_release(x_254, 0); - lean_ctor_release(x_254, 1); - lean_ctor_release(x_254, 2); - lean_ctor_release(x_254, 3); - x_274 = x_254; -} else { - lean_dec_ref(x_254); - x_274 = lean_box(0); -} -if (lean_is_scalar(x_274)) { - x_275 = lean_alloc_ctor(0, 4, 0); -} else { - x_275 = x_274; -} +lean_inc(x_272); +lean_inc(x_271); +lean_dec(x_264); +x_275 = lean_alloc_ctor(0, 5, 0); lean_ctor_set(x_275, 0, x_271); lean_ctor_set(x_275, 1, x_272); -lean_ctor_set(x_275, 2, x_251); +lean_ctor_set(x_275, 2, x_261); lean_ctor_set(x_275, 3, x_273); -x_276 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_276, 0, x_266); -lean_ctor_set(x_276, 1, x_267); -lean_ctor_set(x_276, 2, x_275); -lean_ctor_set(x_276, 3, x_268); -lean_ctor_set(x_276, 4, x_269); -lean_ctor_set(x_276, 5, x_270); -if (lean_is_scalar(x_244)) { - x_277 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_275, 4, x_274); +lean_ctor_set(x_263, 2, x_275); +if (lean_is_scalar(x_254)) { + x_276 = lean_alloc_ctor(1, 2, 0); } else { - x_277 = x_244; - lean_ctor_set_tag(x_277, 1); + x_276 = x_254; + lean_ctor_set_tag(x_276, 1); } -lean_ctor_set(x_277, 0, x_255); -lean_ctor_set(x_277, 1, x_276); -return x_277; +lean_ctor_set(x_276, 0, x_265); +lean_ctor_set(x_276, 1, x_263); +return x_276; } } else { -lean_object* x_278; lean_object* x_279; uint8_t x_280; -x_278 = lean_ctor_get(x_253, 2); -lean_inc(x_278); -x_279 = lean_ctor_get(x_252, 0); +lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; lean_object* x_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; lean_object* x_289; +x_277 = lean_ctor_get(x_263, 0); +x_278 = lean_ctor_get(x_263, 1); +x_279 = lean_ctor_get(x_263, 3); +x_280 = lean_ctor_get(x_263, 4); +x_281 = lean_ctor_get(x_263, 5); +lean_inc(x_281); +lean_inc(x_280); lean_inc(x_279); -lean_dec(x_252); -x_280 = !lean_is_exclusive(x_253); -if (x_280 == 0) -{ -lean_object* x_281; uint8_t x_282; -x_281 = lean_ctor_get(x_253, 2); -lean_dec(x_281); -x_282 = !lean_is_exclusive(x_278); -if (x_282 == 0) -{ -lean_object* x_283; lean_object* x_284; -x_283 = lean_ctor_get(x_278, 2); -lean_dec(x_283); -lean_ctor_set(x_278, 2, x_251); -if (lean_is_scalar(x_244)) { - x_284 = lean_alloc_ctor(0, 2, 0); -} else { - x_284 = x_244; -} -lean_ctor_set(x_284, 0, x_279); -lean_ctor_set(x_284, 1, x_253); -return x_284; -} -else -{ -lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; lean_object* x_289; -x_285 = lean_ctor_get(x_278, 0); -x_286 = lean_ctor_get(x_278, 1); -x_287 = lean_ctor_get(x_278, 3); -lean_inc(x_287); -lean_inc(x_286); +lean_inc(x_278); +lean_inc(x_277); +lean_dec(x_263); +x_282 = lean_ctor_get(x_264, 0); +lean_inc(x_282); +x_283 = lean_ctor_get(x_264, 1); +lean_inc(x_283); +x_284 = lean_ctor_get(x_264, 3); +lean_inc(x_284); +x_285 = lean_ctor_get(x_264, 4); lean_inc(x_285); -lean_dec(x_278); -x_288 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_288, 0, x_285); -lean_ctor_set(x_288, 1, x_286); -lean_ctor_set(x_288, 2, x_251); -lean_ctor_set(x_288, 3, x_287); -lean_ctor_set(x_253, 2, x_288); -if (lean_is_scalar(x_244)) { - x_289 = lean_alloc_ctor(0, 2, 0); +if (lean_is_exclusive(x_264)) { + lean_ctor_release(x_264, 0); + lean_ctor_release(x_264, 1); + lean_ctor_release(x_264, 2); + lean_ctor_release(x_264, 3); + lean_ctor_release(x_264, 4); + x_286 = x_264; } else { - x_289 = x_244; + lean_dec_ref(x_264); + x_286 = lean_box(0); } -lean_ctor_set(x_289, 0, x_279); -lean_ctor_set(x_289, 1, x_253); +if (lean_is_scalar(x_286)) { + x_287 = lean_alloc_ctor(0, 5, 0); +} else { + x_287 = x_286; +} +lean_ctor_set(x_287, 0, x_282); +lean_ctor_set(x_287, 1, x_283); +lean_ctor_set(x_287, 2, x_261); +lean_ctor_set(x_287, 3, x_284); +lean_ctor_set(x_287, 4, x_285); +x_288 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_288, 0, x_277); +lean_ctor_set(x_288, 1, x_278); +lean_ctor_set(x_288, 2, x_287); +lean_ctor_set(x_288, 3, x_279); +lean_ctor_set(x_288, 4, x_280); +lean_ctor_set(x_288, 5, x_281); +if (lean_is_scalar(x_254)) { + x_289 = lean_alloc_ctor(1, 2, 0); +} else { + x_289 = x_254; + lean_ctor_set_tag(x_289, 1); +} +lean_ctor_set(x_289, 0, x_265); +lean_ctor_set(x_289, 1, x_288); return x_289; } } else { -lean_object* x_290; lean_object* x_291; lean_object* x_292; lean_object* x_293; lean_object* x_294; lean_object* x_295; lean_object* x_296; lean_object* x_297; lean_object* x_298; lean_object* x_299; lean_object* x_300; lean_object* x_301; -x_290 = lean_ctor_get(x_253, 0); -x_291 = lean_ctor_get(x_253, 1); -x_292 = lean_ctor_get(x_253, 3); -x_293 = lean_ctor_get(x_253, 4); -x_294 = lean_ctor_get(x_253, 5); -lean_inc(x_294); -lean_inc(x_293); -lean_inc(x_292); -lean_inc(x_291); +lean_object* x_290; lean_object* x_291; uint8_t x_292; +x_290 = lean_ctor_get(x_263, 2); lean_inc(x_290); -lean_dec(x_253); -x_295 = lean_ctor_get(x_278, 0); -lean_inc(x_295); -x_296 = lean_ctor_get(x_278, 1); -lean_inc(x_296); -x_297 = lean_ctor_get(x_278, 3); +x_291 = lean_ctor_get(x_262, 0); +lean_inc(x_291); +lean_dec(x_262); +x_292 = !lean_is_exclusive(x_263); +if (x_292 == 0) +{ +lean_object* x_293; uint8_t x_294; +x_293 = lean_ctor_get(x_263, 2); +lean_dec(x_293); +x_294 = !lean_is_exclusive(x_290); +if (x_294 == 0) +{ +lean_object* x_295; lean_object* x_296; +x_295 = lean_ctor_get(x_290, 2); +lean_dec(x_295); +lean_ctor_set(x_290, 2, x_261); +if (lean_is_scalar(x_254)) { + x_296 = lean_alloc_ctor(0, 2, 0); +} else { + x_296 = x_254; +} +lean_ctor_set(x_296, 0, x_291); +lean_ctor_set(x_296, 1, x_263); +return x_296; +} +else +{ +lean_object* x_297; lean_object* x_298; lean_object* x_299; lean_object* x_300; lean_object* x_301; lean_object* x_302; +x_297 = lean_ctor_get(x_290, 0); +x_298 = lean_ctor_get(x_290, 1); +x_299 = lean_ctor_get(x_290, 3); +x_300 = lean_ctor_get(x_290, 4); +lean_inc(x_300); +lean_inc(x_299); +lean_inc(x_298); lean_inc(x_297); -if (lean_is_exclusive(x_278)) { - lean_ctor_release(x_278, 0); - lean_ctor_release(x_278, 1); - lean_ctor_release(x_278, 2); - lean_ctor_release(x_278, 3); - x_298 = x_278; +lean_dec(x_290); +x_301 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_301, 0, x_297); +lean_ctor_set(x_301, 1, x_298); +lean_ctor_set(x_301, 2, x_261); +lean_ctor_set(x_301, 3, x_299); +lean_ctor_set(x_301, 4, x_300); +lean_ctor_set(x_263, 2, x_301); +if (lean_is_scalar(x_254)) { + x_302 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_278); - x_298 = lean_box(0); + x_302 = x_254; } -if (lean_is_scalar(x_298)) { - x_299 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_302, 0, x_291); +lean_ctor_set(x_302, 1, x_263); +return x_302; +} +} +else +{ +lean_object* x_303; lean_object* x_304; lean_object* x_305; lean_object* x_306; lean_object* x_307; lean_object* x_308; lean_object* x_309; lean_object* x_310; lean_object* x_311; lean_object* x_312; lean_object* x_313; lean_object* x_314; lean_object* x_315; +x_303 = lean_ctor_get(x_263, 0); +x_304 = lean_ctor_get(x_263, 1); +x_305 = lean_ctor_get(x_263, 3); +x_306 = lean_ctor_get(x_263, 4); +x_307 = lean_ctor_get(x_263, 5); +lean_inc(x_307); +lean_inc(x_306); +lean_inc(x_305); +lean_inc(x_304); +lean_inc(x_303); +lean_dec(x_263); +x_308 = lean_ctor_get(x_290, 0); +lean_inc(x_308); +x_309 = lean_ctor_get(x_290, 1); +lean_inc(x_309); +x_310 = lean_ctor_get(x_290, 3); +lean_inc(x_310); +x_311 = lean_ctor_get(x_290, 4); +lean_inc(x_311); +if (lean_is_exclusive(x_290)) { + lean_ctor_release(x_290, 0); + lean_ctor_release(x_290, 1); + lean_ctor_release(x_290, 2); + lean_ctor_release(x_290, 3); + lean_ctor_release(x_290, 4); + x_312 = x_290; } else { - x_299 = x_298; + lean_dec_ref(x_290); + x_312 = lean_box(0); } -lean_ctor_set(x_299, 0, x_295); -lean_ctor_set(x_299, 1, x_296); -lean_ctor_set(x_299, 2, x_251); -lean_ctor_set(x_299, 3, x_297); -x_300 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_300, 0, x_290); -lean_ctor_set(x_300, 1, x_291); -lean_ctor_set(x_300, 2, x_299); -lean_ctor_set(x_300, 3, x_292); -lean_ctor_set(x_300, 4, x_293); -lean_ctor_set(x_300, 5, x_294); -if (lean_is_scalar(x_244)) { - x_301 = lean_alloc_ctor(0, 2, 0); +if (lean_is_scalar(x_312)) { + x_313 = lean_alloc_ctor(0, 5, 0); } else { - x_301 = x_244; + x_313 = x_312; } -lean_ctor_set(x_301, 0, x_279); -lean_ctor_set(x_301, 1, x_300); -return x_301; +lean_ctor_set(x_313, 0, x_308); +lean_ctor_set(x_313, 1, x_309); +lean_ctor_set(x_313, 2, x_261); +lean_ctor_set(x_313, 3, x_310); +lean_ctor_set(x_313, 4, x_311); +x_314 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_314, 0, x_303); +lean_ctor_set(x_314, 1, x_304); +lean_ctor_set(x_314, 2, x_313); +lean_ctor_set(x_314, 3, x_305); +lean_ctor_set(x_314, 4, x_306); +lean_ctor_set(x_314, 5, x_307); +if (lean_is_scalar(x_254)) { + x_315 = lean_alloc_ctor(0, 2, 0); +} else { + x_315 = x_254; +} +lean_ctor_set(x_315, 0, x_291); +lean_ctor_set(x_315, 1, x_314); +return x_315; } } } } else { -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_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; lean_object* x_374; lean_object* x_375; lean_object* x_376; lean_object* x_377; lean_object* x_378; -x_330 = lean_ctor_get(x_249, 0); -x_331 = lean_ctor_get(x_249, 1); -x_332 = lean_ctor_get(x_249, 2); -x_333 = lean_ctor_get(x_249, 3); -lean_inc(x_333); -lean_inc(x_332); -lean_inc(x_331); -lean_inc(x_330); -lean_dec(x_249); -x_367 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_368 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_368, 0, x_330); -lean_ctor_set(x_368, 1, x_331); -lean_ctor_set(x_368, 2, x_367); -lean_ctor_set(x_368, 3, x_333); -lean_ctor_set(x_243, 2, x_368); -x_369 = lean_ctor_get(x_12, 0); -lean_inc(x_369); -x_370 = lean_ctor_get(x_12, 1); -lean_inc(x_370); -x_371 = lean_ctor_get(x_12, 2); -lean_inc(x_371); -x_372 = lean_ctor_get(x_12, 3); -lean_inc(x_372); -x_373 = lean_ctor_get(x_12, 4); -lean_inc(x_373); +lean_object* x_344; lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; lean_object* x_350; 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; lean_object* x_391; lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; +x_344 = lean_ctor_get(x_259, 0); +x_345 = lean_ctor_get(x_259, 1); +x_346 = lean_ctor_get(x_259, 2); +x_347 = lean_ctor_get(x_259, 3); +x_348 = lean_ctor_get(x_259, 4); +lean_inc(x_348); +lean_inc(x_347); +lean_inc(x_346); +lean_inc(x_345); +lean_inc(x_344); +lean_dec(x_259); +x_384 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_385 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_385, 0, x_344); +lean_ctor_set(x_385, 1, x_345); +lean_ctor_set(x_385, 2, x_384); +lean_ctor_set(x_385, 3, x_347); +lean_ctor_set(x_385, 4, x_348); +lean_ctor_set(x_253, 2, x_385); +x_386 = lean_ctor_get(x_12, 0); +lean_inc(x_386); +x_387 = lean_ctor_get(x_12, 1); +lean_inc(x_387); +x_388 = lean_ctor_get(x_12, 2); +lean_inc(x_388); +x_389 = lean_ctor_get(x_12, 3); +lean_inc(x_389); +x_390 = lean_ctor_get(x_12, 4); +lean_inc(x_390); if (lean_is_exclusive(x_12)) { lean_ctor_release(x_12, 0); lean_ctor_release(x_12, 1); lean_ctor_release(x_12, 2); lean_ctor_release(x_12, 3); lean_ctor_release(x_12, 4); - x_374 = x_12; + x_391 = x_12; } else { lean_dec_ref(x_12); - x_374 = lean_box(0); + x_391 = lean_box(0); } -x_375 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_375, 0, x_245); -lean_ctor_set(x_375, 1, x_20); -x_376 = lean_array_push(x_371, x_375); -if (lean_is_scalar(x_374)) { - x_377 = lean_alloc_ctor(0, 5, 0); +x_392 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_392, 0, x_255); +lean_ctor_set(x_392, 1, x_20); +x_393 = lean_array_push(x_388, x_392); +if (lean_is_scalar(x_391)) { + x_394 = lean_alloc_ctor(0, 5, 0); } else { - x_377 = x_374; + x_394 = x_391; } -lean_ctor_set(x_377, 0, x_369); -lean_ctor_set(x_377, 1, x_370); -lean_ctor_set(x_377, 2, x_376); -lean_ctor_set(x_377, 3, x_372); -lean_ctor_set(x_377, 4, x_373); -x_378 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_247, x_377, x_243); -if (lean_obj_tag(x_378) == 0) +lean_ctor_set(x_394, 0, x_386); +lean_ctor_set(x_394, 1, x_387); +lean_ctor_set(x_394, 2, x_393); +lean_ctor_set(x_394, 3, x_389); +lean_ctor_set(x_394, 4, x_390); +x_395 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_257, x_394, x_253); +if (lean_obj_tag(x_395) == 0) { -lean_object* x_379; lean_object* x_380; lean_object* x_381; -x_379 = lean_ctor_get(x_378, 0); -lean_inc(x_379); -x_380 = lean_ctor_get(x_378, 1); -lean_inc(x_380); -lean_dec(x_378); -x_381 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_381, 0, x_379); -x_334 = x_381; -x_335 = x_380; -goto block_366; +lean_object* x_396; lean_object* x_397; lean_object* x_398; +x_396 = lean_ctor_get(x_395, 0); +lean_inc(x_396); +x_397 = lean_ctor_get(x_395, 1); +lean_inc(x_397); +lean_dec(x_395); +x_398 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_398, 0, x_396); +x_349 = x_398; +x_350 = x_397; +goto block_383; } else { -lean_object* x_382; lean_object* x_383; lean_object* x_384; -x_382 = lean_ctor_get(x_378, 0); -lean_inc(x_382); -x_383 = lean_ctor_get(x_378, 1); -lean_inc(x_383); -lean_dec(x_378); -x_384 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_384, 0, x_382); -x_334 = x_384; -x_335 = x_383; -goto block_366; +lean_object* x_399; lean_object* x_400; lean_object* x_401; +x_399 = lean_ctor_get(x_395, 0); +lean_inc(x_399); +x_400 = lean_ctor_get(x_395, 1); +lean_inc(x_400); +lean_dec(x_395); +x_401 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_401, 0, x_399); +x_349 = x_401; +x_350 = x_400; +goto block_383; } -block_366: +block_383: { -if (lean_obj_tag(x_334) == 0) +if (lean_obj_tag(x_349) == 0) { -lean_object* x_336; lean_object* x_337; lean_object* x_338; lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; lean_object* x_350; -x_336 = lean_ctor_get(x_335, 2); -lean_inc(x_336); -x_337 = lean_ctor_get(x_334, 0); -lean_inc(x_337); -lean_dec(x_334); -x_338 = lean_ctor_get(x_335, 0); -lean_inc(x_338); -x_339 = lean_ctor_get(x_335, 1); -lean_inc(x_339); -x_340 = lean_ctor_get(x_335, 3); -lean_inc(x_340); -x_341 = lean_ctor_get(x_335, 4); -lean_inc(x_341); -x_342 = lean_ctor_get(x_335, 5); -lean_inc(x_342); -if (lean_is_exclusive(x_335)) { - lean_ctor_release(x_335, 0); - lean_ctor_release(x_335, 1); - lean_ctor_release(x_335, 2); - lean_ctor_release(x_335, 3); - lean_ctor_release(x_335, 4); - lean_ctor_release(x_335, 5); - x_343 = x_335; -} else { - lean_dec_ref(x_335); - x_343 = lean_box(0); -} -x_344 = lean_ctor_get(x_336, 0); -lean_inc(x_344); -x_345 = lean_ctor_get(x_336, 1); -lean_inc(x_345); -x_346 = lean_ctor_get(x_336, 3); -lean_inc(x_346); -if (lean_is_exclusive(x_336)) { - lean_ctor_release(x_336, 0); - lean_ctor_release(x_336, 1); - lean_ctor_release(x_336, 2); - lean_ctor_release(x_336, 3); - x_347 = x_336; -} else { - lean_dec_ref(x_336); - x_347 = lean_box(0); -} -if (lean_is_scalar(x_347)) { - x_348 = lean_alloc_ctor(0, 4, 0); -} else { - x_348 = x_347; -} -lean_ctor_set(x_348, 0, x_344); -lean_ctor_set(x_348, 1, x_345); -lean_ctor_set(x_348, 2, x_332); -lean_ctor_set(x_348, 3, x_346); -if (lean_is_scalar(x_343)) { - x_349 = lean_alloc_ctor(0, 6, 0); -} else { - x_349 = x_343; -} -lean_ctor_set(x_349, 0, x_338); -lean_ctor_set(x_349, 1, x_339); -lean_ctor_set(x_349, 2, x_348); -lean_ctor_set(x_349, 3, x_340); -lean_ctor_set(x_349, 4, x_341); -lean_ctor_set(x_349, 5, x_342); -if (lean_is_scalar(x_244)) { - x_350 = lean_alloc_ctor(1, 2, 0); -} else { - x_350 = x_244; - lean_ctor_set_tag(x_350, 1); -} -lean_ctor_set(x_350, 0, x_337); -lean_ctor_set(x_350, 1, x_349); -return x_350; -} -else -{ -lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; 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; -x_351 = lean_ctor_get(x_335, 2); +lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; 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; +x_351 = lean_ctor_get(x_350, 2); lean_inc(x_351); -x_352 = lean_ctor_get(x_334, 0); +x_352 = lean_ctor_get(x_349, 0); lean_inc(x_352); -lean_dec(x_334); -x_353 = lean_ctor_get(x_335, 0); +lean_dec(x_349); +x_353 = lean_ctor_get(x_350, 0); lean_inc(x_353); -x_354 = lean_ctor_get(x_335, 1); +x_354 = lean_ctor_get(x_350, 1); lean_inc(x_354); -x_355 = lean_ctor_get(x_335, 3); +x_355 = lean_ctor_get(x_350, 3); lean_inc(x_355); -x_356 = lean_ctor_get(x_335, 4); +x_356 = lean_ctor_get(x_350, 4); lean_inc(x_356); -x_357 = lean_ctor_get(x_335, 5); +x_357 = lean_ctor_get(x_350, 5); lean_inc(x_357); -if (lean_is_exclusive(x_335)) { - lean_ctor_release(x_335, 0); - lean_ctor_release(x_335, 1); - lean_ctor_release(x_335, 2); - lean_ctor_release(x_335, 3); - lean_ctor_release(x_335, 4); - lean_ctor_release(x_335, 5); - x_358 = x_335; +if (lean_is_exclusive(x_350)) { + lean_ctor_release(x_350, 0); + lean_ctor_release(x_350, 1); + lean_ctor_release(x_350, 2); + lean_ctor_release(x_350, 3); + lean_ctor_release(x_350, 4); + lean_ctor_release(x_350, 5); + x_358 = x_350; } else { - lean_dec_ref(x_335); + lean_dec_ref(x_350); x_358 = lean_box(0); } x_359 = lean_ctor_get(x_351, 0); @@ -26877,315 +27627,411 @@ x_360 = lean_ctor_get(x_351, 1); lean_inc(x_360); x_361 = lean_ctor_get(x_351, 3); lean_inc(x_361); +x_362 = lean_ctor_get(x_351, 4); +lean_inc(x_362); if (lean_is_exclusive(x_351)) { lean_ctor_release(x_351, 0); lean_ctor_release(x_351, 1); lean_ctor_release(x_351, 2); lean_ctor_release(x_351, 3); - x_362 = x_351; + lean_ctor_release(x_351, 4); + x_363 = x_351; } else { lean_dec_ref(x_351); - x_362 = lean_box(0); + x_363 = lean_box(0); } -if (lean_is_scalar(x_362)) { - x_363 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_363)) { + x_364 = lean_alloc_ctor(0, 5, 0); } else { - x_363 = x_362; + x_364 = x_363; } -lean_ctor_set(x_363, 0, x_359); -lean_ctor_set(x_363, 1, x_360); -lean_ctor_set(x_363, 2, x_332); -lean_ctor_set(x_363, 3, x_361); +lean_ctor_set(x_364, 0, x_359); +lean_ctor_set(x_364, 1, x_360); +lean_ctor_set(x_364, 2, x_346); +lean_ctor_set(x_364, 3, x_361); +lean_ctor_set(x_364, 4, x_362); if (lean_is_scalar(x_358)) { - x_364 = lean_alloc_ctor(0, 6, 0); + x_365 = lean_alloc_ctor(0, 6, 0); } else { - x_364 = x_358; + x_365 = x_358; } -lean_ctor_set(x_364, 0, x_353); -lean_ctor_set(x_364, 1, x_354); -lean_ctor_set(x_364, 2, x_363); -lean_ctor_set(x_364, 3, x_355); -lean_ctor_set(x_364, 4, x_356); -lean_ctor_set(x_364, 5, x_357); -if (lean_is_scalar(x_244)) { - x_365 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_365, 0, x_353); +lean_ctor_set(x_365, 1, x_354); +lean_ctor_set(x_365, 2, x_364); +lean_ctor_set(x_365, 3, x_355); +lean_ctor_set(x_365, 4, x_356); +lean_ctor_set(x_365, 5, x_357); +if (lean_is_scalar(x_254)) { + x_366 = lean_alloc_ctor(1, 2, 0); } else { - x_365 = x_244; + x_366 = x_254; + lean_ctor_set_tag(x_366, 1); } -lean_ctor_set(x_365, 0, x_352); -lean_ctor_set(x_365, 1, x_364); -return x_365; +lean_ctor_set(x_366, 0, x_352); +lean_ctor_set(x_366, 1, x_365); +return x_366; +} +else +{ +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; lean_object* x_374; lean_object* x_375; 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; +x_367 = lean_ctor_get(x_350, 2); +lean_inc(x_367); +x_368 = lean_ctor_get(x_349, 0); +lean_inc(x_368); +lean_dec(x_349); +x_369 = lean_ctor_get(x_350, 0); +lean_inc(x_369); +x_370 = lean_ctor_get(x_350, 1); +lean_inc(x_370); +x_371 = lean_ctor_get(x_350, 3); +lean_inc(x_371); +x_372 = lean_ctor_get(x_350, 4); +lean_inc(x_372); +x_373 = lean_ctor_get(x_350, 5); +lean_inc(x_373); +if (lean_is_exclusive(x_350)) { + lean_ctor_release(x_350, 0); + lean_ctor_release(x_350, 1); + lean_ctor_release(x_350, 2); + lean_ctor_release(x_350, 3); + lean_ctor_release(x_350, 4); + lean_ctor_release(x_350, 5); + x_374 = x_350; +} else { + lean_dec_ref(x_350); + x_374 = lean_box(0); +} +x_375 = lean_ctor_get(x_367, 0); +lean_inc(x_375); +x_376 = lean_ctor_get(x_367, 1); +lean_inc(x_376); +x_377 = lean_ctor_get(x_367, 3); +lean_inc(x_377); +x_378 = lean_ctor_get(x_367, 4); +lean_inc(x_378); +if (lean_is_exclusive(x_367)) { + lean_ctor_release(x_367, 0); + lean_ctor_release(x_367, 1); + lean_ctor_release(x_367, 2); + lean_ctor_release(x_367, 3); + lean_ctor_release(x_367, 4); + x_379 = x_367; +} else { + lean_dec_ref(x_367); + x_379 = lean_box(0); +} +if (lean_is_scalar(x_379)) { + x_380 = lean_alloc_ctor(0, 5, 0); +} else { + x_380 = x_379; +} +lean_ctor_set(x_380, 0, x_375); +lean_ctor_set(x_380, 1, x_376); +lean_ctor_set(x_380, 2, x_346); +lean_ctor_set(x_380, 3, x_377); +lean_ctor_set(x_380, 4, x_378); +if (lean_is_scalar(x_374)) { + x_381 = lean_alloc_ctor(0, 6, 0); +} else { + x_381 = x_374; +} +lean_ctor_set(x_381, 0, x_369); +lean_ctor_set(x_381, 1, x_370); +lean_ctor_set(x_381, 2, x_380); +lean_ctor_set(x_381, 3, x_371); +lean_ctor_set(x_381, 4, x_372); +lean_ctor_set(x_381, 5, x_373); +if (lean_is_scalar(x_254)) { + x_382 = lean_alloc_ctor(0, 2, 0); +} else { + x_382 = x_254; +} +lean_ctor_set(x_382, 0, x_368); +lean_ctor_set(x_382, 1, x_381); +return x_382; } } } } else { -lean_object* x_385; lean_object* x_386; lean_object* x_387; lean_object* x_388; lean_object* x_389; lean_object* x_390; lean_object* x_391; lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_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; -x_385 = lean_ctor_get(x_243, 2); -x_386 = lean_ctor_get(x_243, 0); -x_387 = lean_ctor_get(x_243, 1); -x_388 = lean_ctor_get(x_243, 3); -x_389 = lean_ctor_get(x_243, 4); -x_390 = lean_ctor_get(x_243, 5); -lean_inc(x_390); -lean_inc(x_389); -lean_inc(x_388); -lean_inc(x_385); -lean_inc(x_387); -lean_inc(x_386); -lean_dec(x_243); -x_391 = lean_ctor_get(x_385, 0); -lean_inc(x_391); -x_392 = lean_ctor_get(x_385, 1); -lean_inc(x_392); -x_393 = lean_ctor_get(x_385, 2); -lean_inc(x_393); -x_394 = lean_ctor_get(x_385, 3); -lean_inc(x_394); -if (lean_is_exclusive(x_385)) { - lean_ctor_release(x_385, 0); - lean_ctor_release(x_385, 1); - lean_ctor_release(x_385, 2); - lean_ctor_release(x_385, 3); - x_395 = x_385; +lean_object* x_402; lean_object* x_403; lean_object* x_404; lean_object* x_405; lean_object* x_406; lean_object* x_407; lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_object* x_412; lean_object* x_413; lean_object* x_414; lean_object* x_415; lean_object* x_449; lean_object* x_450; lean_object* x_451; lean_object* x_452; lean_object* x_453; lean_object* x_454; lean_object* x_455; lean_object* x_456; lean_object* x_457; lean_object* x_458; lean_object* x_459; lean_object* x_460; lean_object* x_461; +x_402 = lean_ctor_get(x_253, 2); +x_403 = lean_ctor_get(x_253, 0); +x_404 = lean_ctor_get(x_253, 1); +x_405 = lean_ctor_get(x_253, 3); +x_406 = lean_ctor_get(x_253, 4); +x_407 = lean_ctor_get(x_253, 5); +lean_inc(x_407); +lean_inc(x_406); +lean_inc(x_405); +lean_inc(x_402); +lean_inc(x_404); +lean_inc(x_403); +lean_dec(x_253); +x_408 = lean_ctor_get(x_402, 0); +lean_inc(x_408); +x_409 = lean_ctor_get(x_402, 1); +lean_inc(x_409); +x_410 = lean_ctor_get(x_402, 2); +lean_inc(x_410); +x_411 = lean_ctor_get(x_402, 3); +lean_inc(x_411); +x_412 = lean_ctor_get(x_402, 4); +lean_inc(x_412); +if (lean_is_exclusive(x_402)) { + lean_ctor_release(x_402, 0); + lean_ctor_release(x_402, 1); + lean_ctor_release(x_402, 2); + lean_ctor_release(x_402, 3); + lean_ctor_release(x_402, 4); + x_413 = x_402; } else { - lean_dec_ref(x_385); - x_395 = lean_box(0); + lean_dec_ref(x_402); + x_413 = lean_box(0); } -x_429 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_395)) { - x_430 = lean_alloc_ctor(0, 4, 0); +x_449 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_413)) { + x_450 = lean_alloc_ctor(0, 5, 0); } else { - x_430 = x_395; + x_450 = x_413; } -lean_ctor_set(x_430, 0, x_391); -lean_ctor_set(x_430, 1, x_392); -lean_ctor_set(x_430, 2, x_429); -lean_ctor_set(x_430, 3, x_394); -x_431 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_431, 0, x_386); -lean_ctor_set(x_431, 1, x_387); -lean_ctor_set(x_431, 2, x_430); -lean_ctor_set(x_431, 3, x_388); -lean_ctor_set(x_431, 4, x_389); -lean_ctor_set(x_431, 5, x_390); -x_432 = lean_ctor_get(x_12, 0); -lean_inc(x_432); -x_433 = lean_ctor_get(x_12, 1); -lean_inc(x_433); -x_434 = lean_ctor_get(x_12, 2); -lean_inc(x_434); -x_435 = lean_ctor_get(x_12, 3); -lean_inc(x_435); -x_436 = lean_ctor_get(x_12, 4); -lean_inc(x_436); +lean_ctor_set(x_450, 0, x_408); +lean_ctor_set(x_450, 1, x_409); +lean_ctor_set(x_450, 2, x_449); +lean_ctor_set(x_450, 3, x_411); +lean_ctor_set(x_450, 4, x_412); +x_451 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_451, 0, x_403); +lean_ctor_set(x_451, 1, x_404); +lean_ctor_set(x_451, 2, x_450); +lean_ctor_set(x_451, 3, x_405); +lean_ctor_set(x_451, 4, x_406); +lean_ctor_set(x_451, 5, x_407); +x_452 = lean_ctor_get(x_12, 0); +lean_inc(x_452); +x_453 = lean_ctor_get(x_12, 1); +lean_inc(x_453); +x_454 = lean_ctor_get(x_12, 2); +lean_inc(x_454); +x_455 = lean_ctor_get(x_12, 3); +lean_inc(x_455); +x_456 = lean_ctor_get(x_12, 4); +lean_inc(x_456); if (lean_is_exclusive(x_12)) { lean_ctor_release(x_12, 0); lean_ctor_release(x_12, 1); lean_ctor_release(x_12, 2); lean_ctor_release(x_12, 3); lean_ctor_release(x_12, 4); - x_437 = x_12; + x_457 = x_12; } else { lean_dec_ref(x_12); - x_437 = lean_box(0); + x_457 = lean_box(0); } -x_438 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_438, 0, x_245); -lean_ctor_set(x_438, 1, x_20); -x_439 = lean_array_push(x_434, x_438); -if (lean_is_scalar(x_437)) { - x_440 = lean_alloc_ctor(0, 5, 0); +x_458 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_458, 0, x_255); +lean_ctor_set(x_458, 1, x_20); +x_459 = lean_array_push(x_454, x_458); +if (lean_is_scalar(x_457)) { + x_460 = lean_alloc_ctor(0, 5, 0); } else { - x_440 = x_437; + x_460 = x_457; } -lean_ctor_set(x_440, 0, x_432); -lean_ctor_set(x_440, 1, x_433); -lean_ctor_set(x_440, 2, x_439); -lean_ctor_set(x_440, 3, x_435); -lean_ctor_set(x_440, 4, x_436); -x_441 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_247, x_440, x_431); -if (lean_obj_tag(x_441) == 0) +lean_ctor_set(x_460, 0, x_452); +lean_ctor_set(x_460, 1, x_453); +lean_ctor_set(x_460, 2, x_459); +lean_ctor_set(x_460, 3, x_455); +lean_ctor_set(x_460, 4, x_456); +x_461 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_257, x_460, x_451); +if (lean_obj_tag(x_461) == 0) { -lean_object* x_442; lean_object* x_443; lean_object* x_444; -x_442 = lean_ctor_get(x_441, 0); -lean_inc(x_442); -x_443 = lean_ctor_get(x_441, 1); -lean_inc(x_443); -lean_dec(x_441); -x_444 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_444, 0, x_442); -x_396 = x_444; -x_397 = x_443; -goto block_428; +lean_object* x_462; lean_object* x_463; lean_object* x_464; +x_462 = lean_ctor_get(x_461, 0); +lean_inc(x_462); +x_463 = lean_ctor_get(x_461, 1); +lean_inc(x_463); +lean_dec(x_461); +x_464 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_464, 0, x_462); +x_414 = x_464; +x_415 = x_463; +goto block_448; } else { -lean_object* x_445; lean_object* x_446; lean_object* x_447; -x_445 = lean_ctor_get(x_441, 0); -lean_inc(x_445); -x_446 = lean_ctor_get(x_441, 1); -lean_inc(x_446); -lean_dec(x_441); -x_447 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_447, 0, x_445); -x_396 = x_447; -x_397 = x_446; -goto block_428; +lean_object* x_465; lean_object* x_466; lean_object* x_467; +x_465 = lean_ctor_get(x_461, 0); +lean_inc(x_465); +x_466 = lean_ctor_get(x_461, 1); +lean_inc(x_466); +lean_dec(x_461); +x_467 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_467, 0, x_465); +x_414 = x_467; +x_415 = x_466; +goto block_448; } -block_428: +block_448: { -if (lean_obj_tag(x_396) == 0) +if (lean_obj_tag(x_414) == 0) { -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; lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_object* x_412; -x_398 = lean_ctor_get(x_397, 2); -lean_inc(x_398); -x_399 = lean_ctor_get(x_396, 0); -lean_inc(x_399); -lean_dec(x_396); -x_400 = lean_ctor_get(x_397, 0); -lean_inc(x_400); -x_401 = lean_ctor_get(x_397, 1); -lean_inc(x_401); -x_402 = lean_ctor_get(x_397, 3); -lean_inc(x_402); -x_403 = lean_ctor_get(x_397, 4); -lean_inc(x_403); -x_404 = lean_ctor_get(x_397, 5); -lean_inc(x_404); -if (lean_is_exclusive(x_397)) { - lean_ctor_release(x_397, 0); - lean_ctor_release(x_397, 1); - lean_ctor_release(x_397, 2); - lean_ctor_release(x_397, 3); - lean_ctor_release(x_397, 4); - lean_ctor_release(x_397, 5); - x_405 = x_397; -} else { - lean_dec_ref(x_397); - x_405 = lean_box(0); -} -x_406 = lean_ctor_get(x_398, 0); -lean_inc(x_406); -x_407 = lean_ctor_get(x_398, 1); -lean_inc(x_407); -x_408 = lean_ctor_get(x_398, 3); -lean_inc(x_408); -if (lean_is_exclusive(x_398)) { - lean_ctor_release(x_398, 0); - lean_ctor_release(x_398, 1); - lean_ctor_release(x_398, 2); - lean_ctor_release(x_398, 3); - x_409 = x_398; -} else { - lean_dec_ref(x_398); - x_409 = lean_box(0); -} -if (lean_is_scalar(x_409)) { - x_410 = lean_alloc_ctor(0, 4, 0); -} else { - x_410 = x_409; -} -lean_ctor_set(x_410, 0, x_406); -lean_ctor_set(x_410, 1, x_407); -lean_ctor_set(x_410, 2, x_393); -lean_ctor_set(x_410, 3, x_408); -if (lean_is_scalar(x_405)) { - x_411 = lean_alloc_ctor(0, 6, 0); -} else { - x_411 = x_405; -} -lean_ctor_set(x_411, 0, x_400); -lean_ctor_set(x_411, 1, x_401); -lean_ctor_set(x_411, 2, x_410); -lean_ctor_set(x_411, 3, x_402); -lean_ctor_set(x_411, 4, x_403); -lean_ctor_set(x_411, 5, x_404); -if (lean_is_scalar(x_244)) { - x_412 = lean_alloc_ctor(1, 2, 0); -} else { - x_412 = x_244; - lean_ctor_set_tag(x_412, 1); -} -lean_ctor_set(x_412, 0, x_399); -lean_ctor_set(x_412, 1, x_411); -return x_412; -} -else -{ -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; lean_object* x_426; lean_object* x_427; -x_413 = lean_ctor_get(x_397, 2); -lean_inc(x_413); -x_414 = lean_ctor_get(x_396, 0); -lean_inc(x_414); -lean_dec(x_396); -x_415 = lean_ctor_get(x_397, 0); -lean_inc(x_415); -x_416 = lean_ctor_get(x_397, 1); +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; lean_object* x_426; lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; +x_416 = lean_ctor_get(x_415, 2); lean_inc(x_416); -x_417 = lean_ctor_get(x_397, 3); +x_417 = lean_ctor_get(x_414, 0); lean_inc(x_417); -x_418 = lean_ctor_get(x_397, 4); +lean_dec(x_414); +x_418 = lean_ctor_get(x_415, 0); lean_inc(x_418); -x_419 = lean_ctor_get(x_397, 5); +x_419 = lean_ctor_get(x_415, 1); lean_inc(x_419); -if (lean_is_exclusive(x_397)) { - lean_ctor_release(x_397, 0); - lean_ctor_release(x_397, 1); - lean_ctor_release(x_397, 2); - lean_ctor_release(x_397, 3); - lean_ctor_release(x_397, 4); - lean_ctor_release(x_397, 5); - x_420 = x_397; -} else { - lean_dec_ref(x_397); - x_420 = lean_box(0); -} -x_421 = lean_ctor_get(x_413, 0); +x_420 = lean_ctor_get(x_415, 3); +lean_inc(x_420); +x_421 = lean_ctor_get(x_415, 4); lean_inc(x_421); -x_422 = lean_ctor_get(x_413, 1); +x_422 = lean_ctor_get(x_415, 5); lean_inc(x_422); -x_423 = lean_ctor_get(x_413, 3); -lean_inc(x_423); -if (lean_is_exclusive(x_413)) { - lean_ctor_release(x_413, 0); - lean_ctor_release(x_413, 1); - lean_ctor_release(x_413, 2); - lean_ctor_release(x_413, 3); - x_424 = x_413; +if (lean_is_exclusive(x_415)) { + lean_ctor_release(x_415, 0); + lean_ctor_release(x_415, 1); + lean_ctor_release(x_415, 2); + lean_ctor_release(x_415, 3); + lean_ctor_release(x_415, 4); + lean_ctor_release(x_415, 5); + x_423 = x_415; } else { - lean_dec_ref(x_413); - x_424 = lean_box(0); + lean_dec_ref(x_415); + x_423 = lean_box(0); } -if (lean_is_scalar(x_424)) { - x_425 = lean_alloc_ctor(0, 4, 0); +x_424 = lean_ctor_get(x_416, 0); +lean_inc(x_424); +x_425 = lean_ctor_get(x_416, 1); +lean_inc(x_425); +x_426 = lean_ctor_get(x_416, 3); +lean_inc(x_426); +x_427 = lean_ctor_get(x_416, 4); +lean_inc(x_427); +if (lean_is_exclusive(x_416)) { + lean_ctor_release(x_416, 0); + lean_ctor_release(x_416, 1); + lean_ctor_release(x_416, 2); + lean_ctor_release(x_416, 3); + lean_ctor_release(x_416, 4); + x_428 = x_416; } else { - x_425 = x_424; + lean_dec_ref(x_416); + x_428 = lean_box(0); } -lean_ctor_set(x_425, 0, x_421); -lean_ctor_set(x_425, 1, x_422); -lean_ctor_set(x_425, 2, x_393); -lean_ctor_set(x_425, 3, x_423); -if (lean_is_scalar(x_420)) { - x_426 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_428)) { + x_429 = lean_alloc_ctor(0, 5, 0); } else { - x_426 = x_420; + x_429 = x_428; } -lean_ctor_set(x_426, 0, x_415); -lean_ctor_set(x_426, 1, x_416); -lean_ctor_set(x_426, 2, x_425); -lean_ctor_set(x_426, 3, x_417); -lean_ctor_set(x_426, 4, x_418); -lean_ctor_set(x_426, 5, x_419); -if (lean_is_scalar(x_244)) { - x_427 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_429, 0, x_424); +lean_ctor_set(x_429, 1, x_425); +lean_ctor_set(x_429, 2, x_410); +lean_ctor_set(x_429, 3, x_426); +lean_ctor_set(x_429, 4, x_427); +if (lean_is_scalar(x_423)) { + x_430 = lean_alloc_ctor(0, 6, 0); } else { - x_427 = x_244; + x_430 = x_423; } -lean_ctor_set(x_427, 0, x_414); -lean_ctor_set(x_427, 1, x_426); -return x_427; +lean_ctor_set(x_430, 0, x_418); +lean_ctor_set(x_430, 1, x_419); +lean_ctor_set(x_430, 2, x_429); +lean_ctor_set(x_430, 3, x_420); +lean_ctor_set(x_430, 4, x_421); +lean_ctor_set(x_430, 5, x_422); +if (lean_is_scalar(x_254)) { + x_431 = lean_alloc_ctor(1, 2, 0); +} else { + x_431 = x_254; + lean_ctor_set_tag(x_431, 1); +} +lean_ctor_set(x_431, 0, x_417); +lean_ctor_set(x_431, 1, x_430); +return x_431; +} +else +{ +lean_object* x_432; lean_object* x_433; lean_object* x_434; lean_object* x_435; lean_object* x_436; lean_object* x_437; lean_object* x_438; lean_object* x_439; lean_object* x_440; lean_object* x_441; lean_object* x_442; lean_object* x_443; lean_object* x_444; lean_object* x_445; lean_object* x_446; lean_object* x_447; +x_432 = lean_ctor_get(x_415, 2); +lean_inc(x_432); +x_433 = lean_ctor_get(x_414, 0); +lean_inc(x_433); +lean_dec(x_414); +x_434 = lean_ctor_get(x_415, 0); +lean_inc(x_434); +x_435 = lean_ctor_get(x_415, 1); +lean_inc(x_435); +x_436 = lean_ctor_get(x_415, 3); +lean_inc(x_436); +x_437 = lean_ctor_get(x_415, 4); +lean_inc(x_437); +x_438 = lean_ctor_get(x_415, 5); +lean_inc(x_438); +if (lean_is_exclusive(x_415)) { + lean_ctor_release(x_415, 0); + lean_ctor_release(x_415, 1); + lean_ctor_release(x_415, 2); + lean_ctor_release(x_415, 3); + lean_ctor_release(x_415, 4); + lean_ctor_release(x_415, 5); + x_439 = x_415; +} else { + lean_dec_ref(x_415); + x_439 = lean_box(0); +} +x_440 = lean_ctor_get(x_432, 0); +lean_inc(x_440); +x_441 = lean_ctor_get(x_432, 1); +lean_inc(x_441); +x_442 = lean_ctor_get(x_432, 3); +lean_inc(x_442); +x_443 = lean_ctor_get(x_432, 4); +lean_inc(x_443); +if (lean_is_exclusive(x_432)) { + lean_ctor_release(x_432, 0); + lean_ctor_release(x_432, 1); + lean_ctor_release(x_432, 2); + lean_ctor_release(x_432, 3); + lean_ctor_release(x_432, 4); + x_444 = x_432; +} else { + lean_dec_ref(x_432); + x_444 = lean_box(0); +} +if (lean_is_scalar(x_444)) { + x_445 = lean_alloc_ctor(0, 5, 0); +} else { + x_445 = x_444; +} +lean_ctor_set(x_445, 0, x_440); +lean_ctor_set(x_445, 1, x_441); +lean_ctor_set(x_445, 2, x_410); +lean_ctor_set(x_445, 3, x_442); +lean_ctor_set(x_445, 4, x_443); +if (lean_is_scalar(x_439)) { + x_446 = lean_alloc_ctor(0, 6, 0); +} else { + x_446 = x_439; +} +lean_ctor_set(x_446, 0, x_434); +lean_ctor_set(x_446, 1, x_435); +lean_ctor_set(x_446, 2, x_445); +lean_ctor_set(x_446, 3, x_436); +lean_ctor_set(x_446, 4, x_437); +lean_ctor_set(x_446, 5, x_438); +if (lean_is_scalar(x_254)) { + x_447 = lean_alloc_ctor(0, 2, 0); +} else { + x_447 = x_254; +} +lean_ctor_set(x_447, 0, x_433); +lean_ctor_set(x_447, 1, x_446); +return x_447; } } } @@ -27193,7 +28039,7 @@ return x_427; } else { -uint8_t x_448; +uint8_t x_468; lean_dec(x_20); lean_dec(x_12); lean_dec(x_11); @@ -27203,23 +28049,23 @@ lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_448 = !lean_is_exclusive(x_237); -if (x_448 == 0) +x_468 = !lean_is_exclusive(x_247); +if (x_468 == 0) { -return x_237; +return x_247; } else { -lean_object* x_449; lean_object* x_450; lean_object* x_451; -x_449 = lean_ctor_get(x_237, 0); -x_450 = lean_ctor_get(x_237, 1); -lean_inc(x_450); -lean_inc(x_449); -lean_dec(x_237); -x_451 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_451, 0, x_449); -lean_ctor_set(x_451, 1, x_450); -return x_451; +lean_object* x_469; lean_object* x_470; lean_object* x_471; +x_469 = lean_ctor_get(x_247, 0); +x_470 = lean_ctor_get(x_247, 1); +lean_inc(x_470); +lean_inc(x_469); +lean_dec(x_247); +x_471 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_471, 0, x_469); +lean_ctor_set(x_471, 1, x_470); +return x_471; } } } @@ -27227,7 +28073,7 @@ return x_451; } else { -uint8_t x_452; +uint8_t x_472; lean_dec(x_24); lean_dec(x_20); lean_dec(x_12); @@ -27238,29 +28084,29 @@ lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_452 = !lean_is_exclusive(x_25); -if (x_452 == 0) +x_472 = !lean_is_exclusive(x_25); +if (x_472 == 0) { return x_25; } else { -lean_object* x_453; lean_object* x_454; lean_object* x_455; -x_453 = lean_ctor_get(x_25, 0); -x_454 = lean_ctor_get(x_25, 1); -lean_inc(x_454); -lean_inc(x_453); +lean_object* x_473; lean_object* x_474; lean_object* x_475; +x_473 = lean_ctor_get(x_25, 0); +x_474 = lean_ctor_get(x_25, 1); +lean_inc(x_474); +lean_inc(x_473); lean_dec(x_25); -x_455 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_455, 0, x_453); -lean_ctor_set(x_455, 1, x_454); -return x_455; +x_475 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_475, 0, x_473); +lean_ctor_set(x_475, 1, x_474); +return x_475; } } } else { -uint8_t x_456; +uint8_t x_476; lean_dec(x_20); lean_dec(x_12); lean_dec(x_11); @@ -27270,23 +28116,23 @@ lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_456 = !lean_is_exclusive(x_21); -if (x_456 == 0) +x_476 = !lean_is_exclusive(x_21); +if (x_476 == 0) { return x_21; } else { -lean_object* x_457; lean_object* x_458; lean_object* x_459; -x_457 = lean_ctor_get(x_21, 0); -x_458 = lean_ctor_get(x_21, 1); -lean_inc(x_458); -lean_inc(x_457); +lean_object* x_477; lean_object* x_478; lean_object* x_479; +x_477 = lean_ctor_get(x_21, 0); +x_478 = lean_ctor_get(x_21, 1); +lean_inc(x_478); +lean_inc(x_477); lean_dec(x_21); -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_479 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_479, 0, x_477); +lean_ctor_set(x_479, 1, x_478); +return x_479; } } } @@ -27386,105 +28232,105 @@ x_31 = lean_ctor_get(x_25, 2); x_32 = !lean_is_exclusive(x_31); if (x_32 == 0) { -lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_85; uint8_t x_86; +lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_89; uint8_t x_90; x_33 = lean_ctor_get(x_31, 2); -x_85 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_31, 2, x_85); -x_86 = !lean_is_exclusive(x_7); -if (x_86 == 0) +x_89 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_31, 2, x_89); +x_90 = !lean_is_exclusive(x_7); +if (x_90 == 0) { -lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; -x_87 = lean_ctor_get(x_7, 2); -x_88 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_88, 0, x_27); -lean_ctor_set(x_88, 1, x_14); -x_89 = lean_array_push(x_87, x_88); -lean_ctor_set(x_7, 2, x_89); -x_90 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_7, x_25); -if (lean_obj_tag(x_90) == 0) +lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; +x_91 = lean_ctor_get(x_7, 2); +x_92 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_92, 0, x_27); +lean_ctor_set(x_92, 1, x_14); +x_93 = lean_array_push(x_91, x_92); +lean_ctor_set(x_7, 2, x_93); +x_94 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_7, x_25); +if (lean_obj_tag(x_94) == 0) { -lean_object* x_91; lean_object* x_92; lean_object* x_93; -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_alloc_ctor(1, 1, 0); -lean_ctor_set(x_93, 0, x_91); -x_34 = x_93; -x_35 = x_92; -goto block_84; -} -else -{ -lean_object* x_94; lean_object* x_95; lean_object* x_96; -x_94 = lean_ctor_get(x_90, 0); -lean_inc(x_94); -x_95 = lean_ctor_get(x_90, 1); +lean_object* x_95; lean_object* x_96; lean_object* x_97; +x_95 = lean_ctor_get(x_94, 0); lean_inc(x_95); -lean_dec(x_90); -x_96 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_96, 0, x_94); -x_34 = x_96; -x_35 = x_95; -goto block_84; -} +x_96 = lean_ctor_get(x_94, 1); +lean_inc(x_96); +lean_dec(x_94); +x_97 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_97, 0, x_95); +x_34 = x_97; +x_35 = x_96; +goto block_88; } else { -lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; -x_97 = lean_ctor_get(x_7, 0); -x_98 = lean_ctor_get(x_7, 1); -x_99 = lean_ctor_get(x_7, 2); -x_100 = lean_ctor_get(x_7, 3); -x_101 = lean_ctor_get(x_7, 4); -lean_inc(x_101); -lean_inc(x_100); -lean_inc(x_99); +lean_object* x_98; lean_object* x_99; lean_object* x_100; +x_98 = lean_ctor_get(x_94, 0); lean_inc(x_98); -lean_inc(x_97); -lean_dec(x_7); -x_102 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_102, 0, x_27); -lean_ctor_set(x_102, 1, x_14); -x_103 = lean_array_push(x_99, x_102); -x_104 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_104, 0, x_97); -lean_ctor_set(x_104, 1, x_98); -lean_ctor_set(x_104, 2, x_103); -lean_ctor_set(x_104, 3, x_100); -lean_ctor_set(x_104, 4, x_101); -x_105 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_104, x_25); -if (lean_obj_tag(x_105) == 0) -{ -lean_object* x_106; lean_object* x_107; lean_object* x_108; -x_106 = lean_ctor_get(x_105, 0); -lean_inc(x_106); -x_107 = lean_ctor_get(x_105, 1); -lean_inc(x_107); -lean_dec(x_105); -x_108 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_108, 0, x_106); -x_34 = x_108; -x_35 = x_107; -goto block_84; +x_99 = lean_ctor_get(x_94, 1); +lean_inc(x_99); +lean_dec(x_94); +x_100 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_100, 0, x_98); +x_34 = x_100; +x_35 = x_99; +goto block_88; +} } else { -lean_object* x_109; lean_object* x_110; lean_object* x_111; -x_109 = lean_ctor_get(x_105, 0); -lean_inc(x_109); -x_110 = lean_ctor_get(x_105, 1); +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; +x_101 = lean_ctor_get(x_7, 0); +x_102 = lean_ctor_get(x_7, 1); +x_103 = lean_ctor_get(x_7, 2); +x_104 = lean_ctor_get(x_7, 3); +x_105 = lean_ctor_get(x_7, 4); +lean_inc(x_105); +lean_inc(x_104); +lean_inc(x_103); +lean_inc(x_102); +lean_inc(x_101); +lean_dec(x_7); +x_106 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_106, 0, x_27); +lean_ctor_set(x_106, 1, x_14); +x_107 = lean_array_push(x_103, x_106); +x_108 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_108, 0, x_101); +lean_ctor_set(x_108, 1, x_102); +lean_ctor_set(x_108, 2, x_107); +lean_ctor_set(x_108, 3, x_104); +lean_ctor_set(x_108, 4, x_105); +x_109 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_108, x_25); +if (lean_obj_tag(x_109) == 0) +{ +lean_object* x_110; lean_object* x_111; lean_object* x_112; +x_110 = lean_ctor_get(x_109, 0); lean_inc(x_110); -lean_dec(x_105); -x_111 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_111, 0, x_109); -x_34 = x_111; -x_35 = x_110; -goto block_84; +x_111 = lean_ctor_get(x_109, 1); +lean_inc(x_111); +lean_dec(x_109); +x_112 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_112, 0, x_110); +x_34 = x_112; +x_35 = x_111; +goto block_88; +} +else +{ +lean_object* x_113; lean_object* x_114; lean_object* x_115; +x_113 = lean_ctor_get(x_109, 0); +lean_inc(x_113); +x_114 = lean_ctor_get(x_109, 1); +lean_inc(x_114); +lean_dec(x_109); +x_115 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_115, 0, x_113); +x_34 = x_115; +x_35 = x_114; +goto block_88; } } -block_84: +block_88: { if (lean_obj_tag(x_34) == 0) { @@ -27519,1284 +28365,1262 @@ return x_42; } else { -lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; +lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; x_43 = lean_ctor_get(x_36, 0); x_44 = lean_ctor_get(x_36, 1); x_45 = lean_ctor_get(x_36, 3); +x_46 = lean_ctor_get(x_36, 4); +lean_inc(x_46); lean_inc(x_45); lean_inc(x_44); lean_inc(x_43); lean_dec(x_36); -x_46 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_46, 0, x_43); -lean_ctor_set(x_46, 1, x_44); -lean_ctor_set(x_46, 2, x_33); -lean_ctor_set(x_46, 3, x_45); -lean_ctor_set(x_35, 2, x_46); +x_47 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_47, 0, x_43); +lean_ctor_set(x_47, 1, x_44); +lean_ctor_set(x_47, 2, x_33); +lean_ctor_set(x_47, 3, x_45); +lean_ctor_set(x_47, 4, x_46); +lean_ctor_set(x_35, 2, x_47); if (lean_is_scalar(x_26)) { - x_47 = lean_alloc_ctor(1, 2, 0); + x_48 = lean_alloc_ctor(1, 2, 0); } else { - x_47 = x_26; - lean_ctor_set_tag(x_47, 1); + x_48 = x_26; + lean_ctor_set_tag(x_48, 1); } -lean_ctor_set(x_47, 0, x_37); -lean_ctor_set(x_47, 1, x_35); -return x_47; +lean_ctor_set(x_48, 0, x_37); +lean_ctor_set(x_48, 1, x_35); +return x_48; } } else { -lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; -x_48 = lean_ctor_get(x_35, 0); -x_49 = lean_ctor_get(x_35, 1); -x_50 = lean_ctor_get(x_35, 3); -x_51 = lean_ctor_get(x_35, 4); -x_52 = lean_ctor_get(x_35, 5); +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; +x_49 = lean_ctor_get(x_35, 0); +x_50 = lean_ctor_get(x_35, 1); +x_51 = lean_ctor_get(x_35, 3); +x_52 = lean_ctor_get(x_35, 4); +x_53 = lean_ctor_get(x_35, 5); +lean_inc(x_53); lean_inc(x_52); lean_inc(x_51); lean_inc(x_50); lean_inc(x_49); -lean_inc(x_48); lean_dec(x_35); -x_53 = lean_ctor_get(x_36, 0); -lean_inc(x_53); -x_54 = lean_ctor_get(x_36, 1); +x_54 = lean_ctor_get(x_36, 0); lean_inc(x_54); -x_55 = lean_ctor_get(x_36, 3); +x_55 = lean_ctor_get(x_36, 1); lean_inc(x_55); +x_56 = lean_ctor_get(x_36, 3); +lean_inc(x_56); +x_57 = lean_ctor_get(x_36, 4); +lean_inc(x_57); if (lean_is_exclusive(x_36)) { lean_ctor_release(x_36, 0); lean_ctor_release(x_36, 1); lean_ctor_release(x_36, 2); lean_ctor_release(x_36, 3); - x_56 = x_36; + lean_ctor_release(x_36, 4); + x_58 = x_36; } else { lean_dec_ref(x_36); - x_56 = lean_box(0); + x_58 = lean_box(0); } -if (lean_is_scalar(x_56)) { - x_57 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_58)) { + x_59 = lean_alloc_ctor(0, 5, 0); } else { - x_57 = x_56; + x_59 = x_58; } -lean_ctor_set(x_57, 0, x_53); -lean_ctor_set(x_57, 1, x_54); -lean_ctor_set(x_57, 2, x_33); -lean_ctor_set(x_57, 3, x_55); -x_58 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_58, 0, x_48); -lean_ctor_set(x_58, 1, x_49); -lean_ctor_set(x_58, 2, x_57); -lean_ctor_set(x_58, 3, x_50); -lean_ctor_set(x_58, 4, x_51); -lean_ctor_set(x_58, 5, x_52); +lean_ctor_set(x_59, 0, x_54); +lean_ctor_set(x_59, 1, x_55); +lean_ctor_set(x_59, 2, x_33); +lean_ctor_set(x_59, 3, x_56); +lean_ctor_set(x_59, 4, x_57); +x_60 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_60, 0, x_49); +lean_ctor_set(x_60, 1, x_50); +lean_ctor_set(x_60, 2, x_59); +lean_ctor_set(x_60, 3, x_51); +lean_ctor_set(x_60, 4, x_52); +lean_ctor_set(x_60, 5, x_53); if (lean_is_scalar(x_26)) { - x_59 = lean_alloc_ctor(1, 2, 0); + x_61 = lean_alloc_ctor(1, 2, 0); } else { - x_59 = x_26; - lean_ctor_set_tag(x_59, 1); + x_61 = x_26; + lean_ctor_set_tag(x_61, 1); } -lean_ctor_set(x_59, 0, x_37); -lean_ctor_set(x_59, 1, x_58); -return x_59; +lean_ctor_set(x_61, 0, x_37); +lean_ctor_set(x_61, 1, x_60); +return x_61; } } else { -lean_object* x_60; lean_object* x_61; uint8_t x_62; -x_60 = lean_ctor_get(x_35, 2); -lean_inc(x_60); -x_61 = lean_ctor_get(x_34, 0); -lean_inc(x_61); +lean_object* x_62; lean_object* x_63; uint8_t x_64; +x_62 = lean_ctor_get(x_35, 2); +lean_inc(x_62); +x_63 = lean_ctor_get(x_34, 0); +lean_inc(x_63); lean_dec(x_34); -x_62 = !lean_is_exclusive(x_35); -if (x_62 == 0) -{ -lean_object* x_63; uint8_t x_64; -x_63 = lean_ctor_get(x_35, 2); -lean_dec(x_63); -x_64 = !lean_is_exclusive(x_60); +x_64 = !lean_is_exclusive(x_35); if (x_64 == 0) { -lean_object* x_65; lean_object* x_66; -x_65 = lean_ctor_get(x_60, 2); +lean_object* x_65; uint8_t x_66; +x_65 = lean_ctor_get(x_35, 2); lean_dec(x_65); -lean_ctor_set(x_60, 2, x_33); +x_66 = !lean_is_exclusive(x_62); +if (x_66 == 0) +{ +lean_object* x_67; lean_object* x_68; +x_67 = lean_ctor_get(x_62, 2); +lean_dec(x_67); +lean_ctor_set(x_62, 2, x_33); if (lean_is_scalar(x_26)) { - x_66 = lean_alloc_ctor(0, 2, 0); + x_68 = lean_alloc_ctor(0, 2, 0); } else { - x_66 = x_26; + x_68 = x_26; } -lean_ctor_set(x_66, 0, x_61); -lean_ctor_set(x_66, 1, x_35); -return x_66; +lean_ctor_set(x_68, 0, x_63); +lean_ctor_set(x_68, 1, x_35); +return x_68; } else { -lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; -x_67 = lean_ctor_get(x_60, 0); -x_68 = lean_ctor_get(x_60, 1); -x_69 = lean_ctor_get(x_60, 3); +lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; +x_69 = lean_ctor_get(x_62, 0); +x_70 = lean_ctor_get(x_62, 1); +x_71 = lean_ctor_get(x_62, 3); +x_72 = lean_ctor_get(x_62, 4); +lean_inc(x_72); +lean_inc(x_71); +lean_inc(x_70); lean_inc(x_69); -lean_inc(x_68); -lean_inc(x_67); -lean_dec(x_60); -x_70 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_70, 0, x_67); -lean_ctor_set(x_70, 1, x_68); -lean_ctor_set(x_70, 2, x_33); -lean_ctor_set(x_70, 3, x_69); -lean_ctor_set(x_35, 2, x_70); +lean_dec(x_62); +x_73 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_73, 0, x_69); +lean_ctor_set(x_73, 1, x_70); +lean_ctor_set(x_73, 2, x_33); +lean_ctor_set(x_73, 3, x_71); +lean_ctor_set(x_73, 4, x_72); +lean_ctor_set(x_35, 2, x_73); if (lean_is_scalar(x_26)) { - x_71 = lean_alloc_ctor(0, 2, 0); + x_74 = lean_alloc_ctor(0, 2, 0); } else { - x_71 = x_26; + x_74 = x_26; } -lean_ctor_set(x_71, 0, x_61); -lean_ctor_set(x_71, 1, x_35); -return x_71; +lean_ctor_set(x_74, 0, x_63); +lean_ctor_set(x_74, 1, x_35); +return x_74; } } else { -lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; -x_72 = lean_ctor_get(x_35, 0); -x_73 = lean_ctor_get(x_35, 1); -x_74 = lean_ctor_get(x_35, 3); -x_75 = lean_ctor_get(x_35, 4); -x_76 = lean_ctor_get(x_35, 5); +lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; +x_75 = lean_ctor_get(x_35, 0); +x_76 = lean_ctor_get(x_35, 1); +x_77 = lean_ctor_get(x_35, 3); +x_78 = lean_ctor_get(x_35, 4); +x_79 = lean_ctor_get(x_35, 5); +lean_inc(x_79); +lean_inc(x_78); +lean_inc(x_77); lean_inc(x_76); lean_inc(x_75); -lean_inc(x_74); -lean_inc(x_73); -lean_inc(x_72); lean_dec(x_35); -x_77 = lean_ctor_get(x_60, 0); -lean_inc(x_77); -x_78 = lean_ctor_get(x_60, 1); -lean_inc(x_78); -x_79 = lean_ctor_get(x_60, 3); -lean_inc(x_79); -if (lean_is_exclusive(x_60)) { - lean_ctor_release(x_60, 0); - lean_ctor_release(x_60, 1); - lean_ctor_release(x_60, 2); - lean_ctor_release(x_60, 3); - x_80 = x_60; +x_80 = lean_ctor_get(x_62, 0); +lean_inc(x_80); +x_81 = lean_ctor_get(x_62, 1); +lean_inc(x_81); +x_82 = lean_ctor_get(x_62, 3); +lean_inc(x_82); +x_83 = lean_ctor_get(x_62, 4); +lean_inc(x_83); +if (lean_is_exclusive(x_62)) { + lean_ctor_release(x_62, 0); + lean_ctor_release(x_62, 1); + lean_ctor_release(x_62, 2); + lean_ctor_release(x_62, 3); + lean_ctor_release(x_62, 4); + x_84 = x_62; } else { - lean_dec_ref(x_60); - x_80 = lean_box(0); + lean_dec_ref(x_62); + x_84 = lean_box(0); } -if (lean_is_scalar(x_80)) { - x_81 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_84)) { + x_85 = lean_alloc_ctor(0, 5, 0); } else { - x_81 = x_80; + x_85 = x_84; } -lean_ctor_set(x_81, 0, x_77); -lean_ctor_set(x_81, 1, x_78); -lean_ctor_set(x_81, 2, x_33); -lean_ctor_set(x_81, 3, x_79); -x_82 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_82, 0, x_72); -lean_ctor_set(x_82, 1, x_73); -lean_ctor_set(x_82, 2, x_81); -lean_ctor_set(x_82, 3, x_74); -lean_ctor_set(x_82, 4, x_75); -lean_ctor_set(x_82, 5, x_76); +lean_ctor_set(x_85, 0, x_80); +lean_ctor_set(x_85, 1, x_81); +lean_ctor_set(x_85, 2, x_33); +lean_ctor_set(x_85, 3, x_82); +lean_ctor_set(x_85, 4, x_83); +x_86 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_86, 0, x_75); +lean_ctor_set(x_86, 1, x_76); +lean_ctor_set(x_86, 2, x_85); +lean_ctor_set(x_86, 3, x_77); +lean_ctor_set(x_86, 4, x_78); +lean_ctor_set(x_86, 5, x_79); if (lean_is_scalar(x_26)) { - x_83 = lean_alloc_ctor(0, 2, 0); + x_87 = lean_alloc_ctor(0, 2, 0); } else { - x_83 = x_26; + x_87 = x_26; } -lean_ctor_set(x_83, 0, x_61); -lean_ctor_set(x_83, 1, x_82); -return x_83; +lean_ctor_set(x_87, 0, x_63); +lean_ctor_set(x_87, 1, x_86); +return x_87; } } } } else { -lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_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; -x_112 = lean_ctor_get(x_31, 0); -x_113 = lean_ctor_get(x_31, 1); -x_114 = lean_ctor_get(x_31, 2); -x_115 = lean_ctor_get(x_31, 3); -lean_inc(x_115); -lean_inc(x_114); -lean_inc(x_113); -lean_inc(x_112); -lean_dec(x_31); -x_149 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_150 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_150, 0, x_112); -lean_ctor_set(x_150, 1, x_113); -lean_ctor_set(x_150, 2, x_149); -lean_ctor_set(x_150, 3, x_115); -lean_ctor_set(x_25, 2, x_150); -x_151 = lean_ctor_get(x_7, 0); -lean_inc(x_151); -x_152 = lean_ctor_get(x_7, 1); -lean_inc(x_152); -x_153 = lean_ctor_get(x_7, 2); -lean_inc(x_153); -x_154 = lean_ctor_get(x_7, 3); -lean_inc(x_154); -x_155 = lean_ctor_get(x_7, 4); -lean_inc(x_155); -if (lean_is_exclusive(x_7)) { - lean_ctor_release(x_7, 0); - lean_ctor_release(x_7, 1); - lean_ctor_release(x_7, 2); - lean_ctor_release(x_7, 3); - lean_ctor_release(x_7, 4); - x_156 = x_7; -} else { - lean_dec_ref(x_7); - x_156 = lean_box(0); -} -x_157 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_157, 0, x_27); -lean_ctor_set(x_157, 1, x_14); -x_158 = lean_array_push(x_153, x_157); -if (lean_is_scalar(x_156)) { - x_159 = lean_alloc_ctor(0, 5, 0); -} else { - x_159 = x_156; -} -lean_ctor_set(x_159, 0, x_151); -lean_ctor_set(x_159, 1, x_152); -lean_ctor_set(x_159, 2, x_158); -lean_ctor_set(x_159, 3, x_154); -lean_ctor_set(x_159, 4, x_155); -x_160 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_159, x_25); -if (lean_obj_tag(x_160) == 0) -{ -lean_object* x_161; lean_object* x_162; lean_object* x_163; -x_161 = lean_ctor_get(x_160, 0); -lean_inc(x_161); -x_162 = lean_ctor_get(x_160, 1); -lean_inc(x_162); -lean_dec(x_160); -x_163 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_163, 0, x_161); -x_116 = x_163; -x_117 = x_162; -goto block_148; -} -else -{ -lean_object* x_164; lean_object* x_165; lean_object* x_166; -x_164 = lean_ctor_get(x_160, 0); -lean_inc(x_164); -x_165 = lean_ctor_get(x_160, 1); -lean_inc(x_165); -lean_dec(x_160); -x_166 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_166, 0, x_164); -x_116 = x_166; -x_117 = x_165; -goto block_148; -} -block_148: -{ -if (lean_obj_tag(x_116) == 0) -{ -lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; -x_118 = lean_ctor_get(x_117, 2); -lean_inc(x_118); -x_119 = lean_ctor_get(x_116, 0); -lean_inc(x_119); -lean_dec(x_116); -x_120 = lean_ctor_get(x_117, 0); +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_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; +x_116 = lean_ctor_get(x_31, 0); +x_117 = lean_ctor_get(x_31, 1); +x_118 = lean_ctor_get(x_31, 2); +x_119 = lean_ctor_get(x_31, 3); +x_120 = lean_ctor_get(x_31, 4); lean_inc(x_120); -x_121 = lean_ctor_get(x_117, 1); -lean_inc(x_121); -x_122 = lean_ctor_get(x_117, 3); -lean_inc(x_122); -x_123 = lean_ctor_get(x_117, 4); -lean_inc(x_123); -x_124 = lean_ctor_get(x_117, 5); -lean_inc(x_124); -if (lean_is_exclusive(x_117)) { - lean_ctor_release(x_117, 0); - lean_ctor_release(x_117, 1); - lean_ctor_release(x_117, 2); - lean_ctor_release(x_117, 3); - lean_ctor_release(x_117, 4); - lean_ctor_release(x_117, 5); - x_125 = x_117; -} else { - lean_dec_ref(x_117); - x_125 = lean_box(0); -} -x_126 = lean_ctor_get(x_118, 0); -lean_inc(x_126); -x_127 = lean_ctor_get(x_118, 1); -lean_inc(x_127); -x_128 = lean_ctor_get(x_118, 3); -lean_inc(x_128); -if (lean_is_exclusive(x_118)) { - lean_ctor_release(x_118, 0); - lean_ctor_release(x_118, 1); - lean_ctor_release(x_118, 2); - lean_ctor_release(x_118, 3); - x_129 = x_118; -} else { - lean_dec_ref(x_118); - x_129 = lean_box(0); -} -if (lean_is_scalar(x_129)) { - x_130 = lean_alloc_ctor(0, 4, 0); -} else { - x_130 = x_129; -} -lean_ctor_set(x_130, 0, x_126); -lean_ctor_set(x_130, 1, x_127); -lean_ctor_set(x_130, 2, x_114); -lean_ctor_set(x_130, 3, x_128); -if (lean_is_scalar(x_125)) { - x_131 = lean_alloc_ctor(0, 6, 0); -} else { - x_131 = x_125; -} -lean_ctor_set(x_131, 0, x_120); -lean_ctor_set(x_131, 1, x_121); -lean_ctor_set(x_131, 2, x_130); -lean_ctor_set(x_131, 3, x_122); -lean_ctor_set(x_131, 4, x_123); -lean_ctor_set(x_131, 5, x_124); -if (lean_is_scalar(x_26)) { - x_132 = lean_alloc_ctor(1, 2, 0); -} else { - x_132 = x_26; - lean_ctor_set_tag(x_132, 1); -} -lean_ctor_set(x_132, 0, x_119); -lean_ctor_set(x_132, 1, x_131); -return x_132; -} -else -{ -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; -x_133 = lean_ctor_get(x_117, 2); -lean_inc(x_133); -x_134 = lean_ctor_get(x_116, 0); -lean_inc(x_134); -lean_dec(x_116); -x_135 = lean_ctor_get(x_117, 0); -lean_inc(x_135); -x_136 = lean_ctor_get(x_117, 1); -lean_inc(x_136); -x_137 = lean_ctor_get(x_117, 3); -lean_inc(x_137); -x_138 = lean_ctor_get(x_117, 4); -lean_inc(x_138); -x_139 = lean_ctor_get(x_117, 5); -lean_inc(x_139); -if (lean_is_exclusive(x_117)) { - lean_ctor_release(x_117, 0); - lean_ctor_release(x_117, 1); - lean_ctor_release(x_117, 2); - lean_ctor_release(x_117, 3); - lean_ctor_release(x_117, 4); - lean_ctor_release(x_117, 5); - x_140 = x_117; -} else { - lean_dec_ref(x_117); - x_140 = lean_box(0); -} -x_141 = lean_ctor_get(x_133, 0); -lean_inc(x_141); -x_142 = lean_ctor_get(x_133, 1); -lean_inc(x_142); -x_143 = lean_ctor_get(x_133, 3); -lean_inc(x_143); -if (lean_is_exclusive(x_133)) { - lean_ctor_release(x_133, 0); - lean_ctor_release(x_133, 1); - lean_ctor_release(x_133, 2); - lean_ctor_release(x_133, 3); - x_144 = x_133; -} else { - lean_dec_ref(x_133); - x_144 = lean_box(0); -} -if (lean_is_scalar(x_144)) { - x_145 = lean_alloc_ctor(0, 4, 0); -} else { - x_145 = x_144; -} -lean_ctor_set(x_145, 0, x_141); -lean_ctor_set(x_145, 1, x_142); -lean_ctor_set(x_145, 2, x_114); -lean_ctor_set(x_145, 3, x_143); -if (lean_is_scalar(x_140)) { - x_146 = lean_alloc_ctor(0, 6, 0); -} else { - x_146 = x_140; -} -lean_ctor_set(x_146, 0, x_135); -lean_ctor_set(x_146, 1, x_136); -lean_ctor_set(x_146, 2, x_145); -lean_ctor_set(x_146, 3, x_137); -lean_ctor_set(x_146, 4, x_138); -lean_ctor_set(x_146, 5, x_139); -if (lean_is_scalar(x_26)) { - x_147 = lean_alloc_ctor(0, 2, 0); -} else { - x_147 = x_26; -} -lean_ctor_set(x_147, 0, x_134); -lean_ctor_set(x_147, 1, x_146); -return x_147; -} -} -} -} -else -{ -lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; 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; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; -x_167 = lean_ctor_get(x_25, 2); -x_168 = lean_ctor_get(x_25, 0); -x_169 = lean_ctor_get(x_25, 1); -x_170 = lean_ctor_get(x_25, 3); -x_171 = lean_ctor_get(x_25, 4); -x_172 = lean_ctor_get(x_25, 5); -lean_inc(x_172); -lean_inc(x_171); -lean_inc(x_170); -lean_inc(x_167); -lean_inc(x_169); -lean_inc(x_168); -lean_dec(x_25); -x_173 = lean_ctor_get(x_167, 0); -lean_inc(x_173); -x_174 = lean_ctor_get(x_167, 1); -lean_inc(x_174); -x_175 = lean_ctor_get(x_167, 2); -lean_inc(x_175); -x_176 = lean_ctor_get(x_167, 3); -lean_inc(x_176); -if (lean_is_exclusive(x_167)) { - lean_ctor_release(x_167, 0); - lean_ctor_release(x_167, 1); - lean_ctor_release(x_167, 2); - lean_ctor_release(x_167, 3); - x_177 = x_167; -} else { - lean_dec_ref(x_167); - x_177 = lean_box(0); -} -x_211 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_177)) { - x_212 = lean_alloc_ctor(0, 4, 0); -} else { - x_212 = x_177; -} -lean_ctor_set(x_212, 0, x_173); -lean_ctor_set(x_212, 1, x_174); -lean_ctor_set(x_212, 2, x_211); -lean_ctor_set(x_212, 3, x_176); -x_213 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_213, 0, x_168); -lean_ctor_set(x_213, 1, x_169); -lean_ctor_set(x_213, 2, x_212); -lean_ctor_set(x_213, 3, x_170); -lean_ctor_set(x_213, 4, x_171); -lean_ctor_set(x_213, 5, x_172); -x_214 = lean_ctor_get(x_7, 0); -lean_inc(x_214); -x_215 = lean_ctor_get(x_7, 1); -lean_inc(x_215); -x_216 = lean_ctor_get(x_7, 2); -lean_inc(x_216); -x_217 = lean_ctor_get(x_7, 3); -lean_inc(x_217); -x_218 = lean_ctor_get(x_7, 4); -lean_inc(x_218); +lean_inc(x_119); +lean_inc(x_118); +lean_inc(x_117); +lean_inc(x_116); +lean_dec(x_31); +x_156 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_157 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_157, 0, x_116); +lean_ctor_set(x_157, 1, x_117); +lean_ctor_set(x_157, 2, x_156); +lean_ctor_set(x_157, 3, x_119); +lean_ctor_set(x_157, 4, x_120); +lean_ctor_set(x_25, 2, x_157); +x_158 = lean_ctor_get(x_7, 0); +lean_inc(x_158); +x_159 = lean_ctor_get(x_7, 1); +lean_inc(x_159); +x_160 = lean_ctor_get(x_7, 2); +lean_inc(x_160); +x_161 = lean_ctor_get(x_7, 3); +lean_inc(x_161); +x_162 = lean_ctor_get(x_7, 4); +lean_inc(x_162); if (lean_is_exclusive(x_7)) { lean_ctor_release(x_7, 0); lean_ctor_release(x_7, 1); lean_ctor_release(x_7, 2); lean_ctor_release(x_7, 3); lean_ctor_release(x_7, 4); - x_219 = x_7; + x_163 = x_7; } else { lean_dec_ref(x_7); - x_219 = lean_box(0); + x_163 = lean_box(0); } -x_220 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_220, 0, x_27); -lean_ctor_set(x_220, 1, x_14); -x_221 = lean_array_push(x_216, x_220); -if (lean_is_scalar(x_219)) { +x_164 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_164, 0, x_27); +lean_ctor_set(x_164, 1, x_14); +x_165 = lean_array_push(x_160, x_164); +if (lean_is_scalar(x_163)) { + x_166 = lean_alloc_ctor(0, 5, 0); +} else { + x_166 = x_163; +} +lean_ctor_set(x_166, 0, x_158); +lean_ctor_set(x_166, 1, x_159); +lean_ctor_set(x_166, 2, x_165); +lean_ctor_set(x_166, 3, x_161); +lean_ctor_set(x_166, 4, x_162); +x_167 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_166, x_25); +if (lean_obj_tag(x_167) == 0) +{ +lean_object* x_168; lean_object* x_169; lean_object* x_170; +x_168 = lean_ctor_get(x_167, 0); +lean_inc(x_168); +x_169 = lean_ctor_get(x_167, 1); +lean_inc(x_169); +lean_dec(x_167); +x_170 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_170, 0, x_168); +x_121 = x_170; +x_122 = x_169; +goto block_155; +} +else +{ +lean_object* x_171; lean_object* x_172; lean_object* x_173; +x_171 = lean_ctor_get(x_167, 0); +lean_inc(x_171); +x_172 = lean_ctor_get(x_167, 1); +lean_inc(x_172); +lean_dec(x_167); +x_173 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_173, 0, x_171); +x_121 = x_173; +x_122 = x_172; +goto block_155; +} +block_155: +{ +if (lean_obj_tag(x_121) == 0) +{ +lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; +x_123 = lean_ctor_get(x_122, 2); +lean_inc(x_123); +x_124 = lean_ctor_get(x_121, 0); +lean_inc(x_124); +lean_dec(x_121); +x_125 = lean_ctor_get(x_122, 0); +lean_inc(x_125); +x_126 = lean_ctor_get(x_122, 1); +lean_inc(x_126); +x_127 = lean_ctor_get(x_122, 3); +lean_inc(x_127); +x_128 = lean_ctor_get(x_122, 4); +lean_inc(x_128); +x_129 = lean_ctor_get(x_122, 5); +lean_inc(x_129); +if (lean_is_exclusive(x_122)) { + lean_ctor_release(x_122, 0); + lean_ctor_release(x_122, 1); + lean_ctor_release(x_122, 2); + lean_ctor_release(x_122, 3); + lean_ctor_release(x_122, 4); + lean_ctor_release(x_122, 5); + x_130 = x_122; +} else { + lean_dec_ref(x_122); + x_130 = lean_box(0); +} +x_131 = lean_ctor_get(x_123, 0); +lean_inc(x_131); +x_132 = lean_ctor_get(x_123, 1); +lean_inc(x_132); +x_133 = lean_ctor_get(x_123, 3); +lean_inc(x_133); +x_134 = lean_ctor_get(x_123, 4); +lean_inc(x_134); +if (lean_is_exclusive(x_123)) { + lean_ctor_release(x_123, 0); + lean_ctor_release(x_123, 1); + lean_ctor_release(x_123, 2); + lean_ctor_release(x_123, 3); + lean_ctor_release(x_123, 4); + x_135 = x_123; +} else { + lean_dec_ref(x_123); + x_135 = lean_box(0); +} +if (lean_is_scalar(x_135)) { + x_136 = lean_alloc_ctor(0, 5, 0); +} else { + x_136 = x_135; +} +lean_ctor_set(x_136, 0, x_131); +lean_ctor_set(x_136, 1, x_132); +lean_ctor_set(x_136, 2, x_118); +lean_ctor_set(x_136, 3, x_133); +lean_ctor_set(x_136, 4, x_134); +if (lean_is_scalar(x_130)) { + x_137 = lean_alloc_ctor(0, 6, 0); +} else { + x_137 = x_130; +} +lean_ctor_set(x_137, 0, x_125); +lean_ctor_set(x_137, 1, x_126); +lean_ctor_set(x_137, 2, x_136); +lean_ctor_set(x_137, 3, x_127); +lean_ctor_set(x_137, 4, x_128); +lean_ctor_set(x_137, 5, x_129); +if (lean_is_scalar(x_26)) { + x_138 = lean_alloc_ctor(1, 2, 0); +} else { + x_138 = x_26; + lean_ctor_set_tag(x_138, 1); +} +lean_ctor_set(x_138, 0, x_124); +lean_ctor_set(x_138, 1, x_137); +return x_138; +} +else +{ +lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_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; +x_139 = lean_ctor_get(x_122, 2); +lean_inc(x_139); +x_140 = lean_ctor_get(x_121, 0); +lean_inc(x_140); +lean_dec(x_121); +x_141 = lean_ctor_get(x_122, 0); +lean_inc(x_141); +x_142 = lean_ctor_get(x_122, 1); +lean_inc(x_142); +x_143 = lean_ctor_get(x_122, 3); +lean_inc(x_143); +x_144 = lean_ctor_get(x_122, 4); +lean_inc(x_144); +x_145 = lean_ctor_get(x_122, 5); +lean_inc(x_145); +if (lean_is_exclusive(x_122)) { + lean_ctor_release(x_122, 0); + lean_ctor_release(x_122, 1); + lean_ctor_release(x_122, 2); + lean_ctor_release(x_122, 3); + lean_ctor_release(x_122, 4); + lean_ctor_release(x_122, 5); + x_146 = x_122; +} else { + lean_dec_ref(x_122); + x_146 = lean_box(0); +} +x_147 = lean_ctor_get(x_139, 0); +lean_inc(x_147); +x_148 = lean_ctor_get(x_139, 1); +lean_inc(x_148); +x_149 = lean_ctor_get(x_139, 3); +lean_inc(x_149); +x_150 = lean_ctor_get(x_139, 4); +lean_inc(x_150); +if (lean_is_exclusive(x_139)) { + lean_ctor_release(x_139, 0); + lean_ctor_release(x_139, 1); + lean_ctor_release(x_139, 2); + lean_ctor_release(x_139, 3); + lean_ctor_release(x_139, 4); + x_151 = x_139; +} else { + lean_dec_ref(x_139); + x_151 = lean_box(0); +} +if (lean_is_scalar(x_151)) { + x_152 = lean_alloc_ctor(0, 5, 0); +} else { + x_152 = x_151; +} +lean_ctor_set(x_152, 0, x_147); +lean_ctor_set(x_152, 1, x_148); +lean_ctor_set(x_152, 2, x_118); +lean_ctor_set(x_152, 3, x_149); +lean_ctor_set(x_152, 4, x_150); +if (lean_is_scalar(x_146)) { + x_153 = lean_alloc_ctor(0, 6, 0); +} else { + x_153 = x_146; +} +lean_ctor_set(x_153, 0, x_141); +lean_ctor_set(x_153, 1, x_142); +lean_ctor_set(x_153, 2, x_152); +lean_ctor_set(x_153, 3, x_143); +lean_ctor_set(x_153, 4, x_144); +lean_ctor_set(x_153, 5, x_145); +if (lean_is_scalar(x_26)) { + x_154 = lean_alloc_ctor(0, 2, 0); +} else { + x_154 = x_26; +} +lean_ctor_set(x_154, 0, x_140); +lean_ctor_set(x_154, 1, x_153); +return x_154; +} +} +} +} +else +{ +lean_object* x_174; lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_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; lean_object* x_231; lean_object* x_232; lean_object* x_233; +x_174 = lean_ctor_get(x_25, 2); +x_175 = lean_ctor_get(x_25, 0); +x_176 = lean_ctor_get(x_25, 1); +x_177 = lean_ctor_get(x_25, 3); +x_178 = lean_ctor_get(x_25, 4); +x_179 = lean_ctor_get(x_25, 5); +lean_inc(x_179); +lean_inc(x_178); +lean_inc(x_177); +lean_inc(x_174); +lean_inc(x_176); +lean_inc(x_175); +lean_dec(x_25); +x_180 = lean_ctor_get(x_174, 0); +lean_inc(x_180); +x_181 = lean_ctor_get(x_174, 1); +lean_inc(x_181); +x_182 = lean_ctor_get(x_174, 2); +lean_inc(x_182); +x_183 = lean_ctor_get(x_174, 3); +lean_inc(x_183); +x_184 = lean_ctor_get(x_174, 4); +lean_inc(x_184); +if (lean_is_exclusive(x_174)) { + lean_ctor_release(x_174, 0); + lean_ctor_release(x_174, 1); + lean_ctor_release(x_174, 2); + lean_ctor_release(x_174, 3); + lean_ctor_release(x_174, 4); + x_185 = x_174; +} else { + lean_dec_ref(x_174); + x_185 = lean_box(0); +} +x_221 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_185)) { x_222 = lean_alloc_ctor(0, 5, 0); } else { - x_222 = x_219; + x_222 = x_185; } -lean_ctor_set(x_222, 0, x_214); -lean_ctor_set(x_222, 1, x_215); +lean_ctor_set(x_222, 0, x_180); +lean_ctor_set(x_222, 1, x_181); lean_ctor_set(x_222, 2, x_221); -lean_ctor_set(x_222, 3, x_217); -lean_ctor_set(x_222, 4, x_218); -x_223 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_222, x_213); -if (lean_obj_tag(x_223) == 0) -{ -lean_object* x_224; lean_object* x_225; lean_object* x_226; -x_224 = lean_ctor_get(x_223, 0); +lean_ctor_set(x_222, 3, x_183); +lean_ctor_set(x_222, 4, x_184); +x_223 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_223, 0, x_175); +lean_ctor_set(x_223, 1, x_176); +lean_ctor_set(x_223, 2, x_222); +lean_ctor_set(x_223, 3, x_177); +lean_ctor_set(x_223, 4, x_178); +lean_ctor_set(x_223, 5, x_179); +x_224 = lean_ctor_get(x_7, 0); lean_inc(x_224); -x_225 = lean_ctor_get(x_223, 1); +x_225 = lean_ctor_get(x_7, 1); lean_inc(x_225); -lean_dec(x_223); -x_226 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_226, 0, x_224); -x_178 = x_226; -x_179 = x_225; -goto block_210; -} -else -{ -lean_object* x_227; lean_object* x_228; lean_object* x_229; -x_227 = lean_ctor_get(x_223, 0); +x_226 = lean_ctor_get(x_7, 2); +lean_inc(x_226); +x_227 = lean_ctor_get(x_7, 3); lean_inc(x_227); -x_228 = lean_ctor_get(x_223, 1); +x_228 = lean_ctor_get(x_7, 4); lean_inc(x_228); -lean_dec(x_223); -x_229 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_229, 0, x_227); -x_178 = x_229; -x_179 = x_228; -goto block_210; +if (lean_is_exclusive(x_7)) { + lean_ctor_release(x_7, 0); + lean_ctor_release(x_7, 1); + lean_ctor_release(x_7, 2); + lean_ctor_release(x_7, 3); + lean_ctor_release(x_7, 4); + x_229 = x_7; +} else { + lean_dec_ref(x_7); + x_229 = lean_box(0); } -block_210: +x_230 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_230, 0, x_27); +lean_ctor_set(x_230, 1, x_14); +x_231 = lean_array_push(x_226, x_230); +if (lean_is_scalar(x_229)) { + x_232 = lean_alloc_ctor(0, 5, 0); +} else { + x_232 = x_229; +} +lean_ctor_set(x_232, 0, x_224); +lean_ctor_set(x_232, 1, x_225); +lean_ctor_set(x_232, 2, x_231); +lean_ctor_set(x_232, 3, x_227); +lean_ctor_set(x_232, 4, x_228); +x_233 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_232, x_223); +if (lean_obj_tag(x_233) == 0) { -if (lean_obj_tag(x_178) == 0) -{ -lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; -x_180 = lean_ctor_get(x_179, 2); -lean_inc(x_180); -x_181 = lean_ctor_get(x_178, 0); -lean_inc(x_181); -lean_dec(x_178); -x_182 = lean_ctor_get(x_179, 0); -lean_inc(x_182); -x_183 = lean_ctor_get(x_179, 1); -lean_inc(x_183); -x_184 = lean_ctor_get(x_179, 3); -lean_inc(x_184); -x_185 = lean_ctor_get(x_179, 4); -lean_inc(x_185); -x_186 = lean_ctor_get(x_179, 5); -lean_inc(x_186); -if (lean_is_exclusive(x_179)) { - lean_ctor_release(x_179, 0); - lean_ctor_release(x_179, 1); - lean_ctor_release(x_179, 2); - lean_ctor_release(x_179, 3); - lean_ctor_release(x_179, 4); - lean_ctor_release(x_179, 5); - x_187 = x_179; -} else { - lean_dec_ref(x_179); - x_187 = lean_box(0); -} -x_188 = lean_ctor_get(x_180, 0); -lean_inc(x_188); -x_189 = lean_ctor_get(x_180, 1); -lean_inc(x_189); -x_190 = lean_ctor_get(x_180, 3); -lean_inc(x_190); -if (lean_is_exclusive(x_180)) { - lean_ctor_release(x_180, 0); - lean_ctor_release(x_180, 1); - lean_ctor_release(x_180, 2); - lean_ctor_release(x_180, 3); - x_191 = x_180; -} else { - lean_dec_ref(x_180); - x_191 = lean_box(0); -} -if (lean_is_scalar(x_191)) { - x_192 = lean_alloc_ctor(0, 4, 0); -} else { - x_192 = x_191; -} -lean_ctor_set(x_192, 0, x_188); -lean_ctor_set(x_192, 1, x_189); -lean_ctor_set(x_192, 2, x_175); -lean_ctor_set(x_192, 3, x_190); -if (lean_is_scalar(x_187)) { - x_193 = lean_alloc_ctor(0, 6, 0); -} else { - x_193 = x_187; -} -lean_ctor_set(x_193, 0, x_182); -lean_ctor_set(x_193, 1, x_183); -lean_ctor_set(x_193, 2, x_192); -lean_ctor_set(x_193, 3, x_184); -lean_ctor_set(x_193, 4, x_185); -lean_ctor_set(x_193, 5, x_186); -if (lean_is_scalar(x_26)) { - x_194 = lean_alloc_ctor(1, 2, 0); -} else { - x_194 = x_26; - lean_ctor_set_tag(x_194, 1); -} -lean_ctor_set(x_194, 0, x_181); -lean_ctor_set(x_194, 1, x_193); -return x_194; +lean_object* x_234; lean_object* x_235; lean_object* x_236; +x_234 = lean_ctor_get(x_233, 0); +lean_inc(x_234); +x_235 = lean_ctor_get(x_233, 1); +lean_inc(x_235); +lean_dec(x_233); +x_236 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_236, 0, x_234); +x_186 = x_236; +x_187 = x_235; +goto block_220; } else { -lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; -x_195 = lean_ctor_get(x_179, 2); -lean_inc(x_195); -x_196 = lean_ctor_get(x_178, 0); +lean_object* x_237; lean_object* x_238; lean_object* x_239; +x_237 = lean_ctor_get(x_233, 0); +lean_inc(x_237); +x_238 = lean_ctor_get(x_233, 1); +lean_inc(x_238); +lean_dec(x_233); +x_239 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_239, 0, x_237); +x_186 = x_239; +x_187 = x_238; +goto block_220; +} +block_220: +{ +if (lean_obj_tag(x_186) == 0) +{ +lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; +x_188 = lean_ctor_get(x_187, 2); +lean_inc(x_188); +x_189 = lean_ctor_get(x_186, 0); +lean_inc(x_189); +lean_dec(x_186); +x_190 = lean_ctor_get(x_187, 0); +lean_inc(x_190); +x_191 = lean_ctor_get(x_187, 1); +lean_inc(x_191); +x_192 = lean_ctor_get(x_187, 3); +lean_inc(x_192); +x_193 = lean_ctor_get(x_187, 4); +lean_inc(x_193); +x_194 = lean_ctor_get(x_187, 5); +lean_inc(x_194); +if (lean_is_exclusive(x_187)) { + lean_ctor_release(x_187, 0); + lean_ctor_release(x_187, 1); + lean_ctor_release(x_187, 2); + lean_ctor_release(x_187, 3); + lean_ctor_release(x_187, 4); + lean_ctor_release(x_187, 5); + x_195 = x_187; +} else { + lean_dec_ref(x_187); + x_195 = lean_box(0); +} +x_196 = lean_ctor_get(x_188, 0); lean_inc(x_196); -lean_dec(x_178); -x_197 = lean_ctor_get(x_179, 0); +x_197 = lean_ctor_get(x_188, 1); lean_inc(x_197); -x_198 = lean_ctor_get(x_179, 1); +x_198 = lean_ctor_get(x_188, 3); lean_inc(x_198); -x_199 = lean_ctor_get(x_179, 3); +x_199 = lean_ctor_get(x_188, 4); lean_inc(x_199); -x_200 = lean_ctor_get(x_179, 4); -lean_inc(x_200); -x_201 = lean_ctor_get(x_179, 5); -lean_inc(x_201); -if (lean_is_exclusive(x_179)) { - lean_ctor_release(x_179, 0); - lean_ctor_release(x_179, 1); - lean_ctor_release(x_179, 2); - lean_ctor_release(x_179, 3); - lean_ctor_release(x_179, 4); - lean_ctor_release(x_179, 5); - x_202 = x_179; +if (lean_is_exclusive(x_188)) { + lean_ctor_release(x_188, 0); + lean_ctor_release(x_188, 1); + lean_ctor_release(x_188, 2); + lean_ctor_release(x_188, 3); + lean_ctor_release(x_188, 4); + x_200 = x_188; } else { - lean_dec_ref(x_179); - x_202 = lean_box(0); + lean_dec_ref(x_188); + x_200 = lean_box(0); } -x_203 = lean_ctor_get(x_195, 0); -lean_inc(x_203); -x_204 = lean_ctor_get(x_195, 1); -lean_inc(x_204); -x_205 = lean_ctor_get(x_195, 3); -lean_inc(x_205); -if (lean_is_exclusive(x_195)) { - lean_ctor_release(x_195, 0); - lean_ctor_release(x_195, 1); - lean_ctor_release(x_195, 2); - lean_ctor_release(x_195, 3); - x_206 = x_195; +if (lean_is_scalar(x_200)) { + x_201 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_195); - x_206 = lean_box(0); + x_201 = x_200; } -if (lean_is_scalar(x_206)) { - x_207 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_201, 0, x_196); +lean_ctor_set(x_201, 1, x_197); +lean_ctor_set(x_201, 2, x_182); +lean_ctor_set(x_201, 3, x_198); +lean_ctor_set(x_201, 4, x_199); +if (lean_is_scalar(x_195)) { + x_202 = lean_alloc_ctor(0, 6, 0); } else { - x_207 = x_206; + x_202 = x_195; } -lean_ctor_set(x_207, 0, x_203); -lean_ctor_set(x_207, 1, x_204); -lean_ctor_set(x_207, 2, x_175); -lean_ctor_set(x_207, 3, x_205); -if (lean_is_scalar(x_202)) { - x_208 = lean_alloc_ctor(0, 6, 0); -} else { - x_208 = x_202; -} -lean_ctor_set(x_208, 0, x_197); -lean_ctor_set(x_208, 1, x_198); -lean_ctor_set(x_208, 2, x_207); -lean_ctor_set(x_208, 3, x_199); -lean_ctor_set(x_208, 4, x_200); -lean_ctor_set(x_208, 5, x_201); +lean_ctor_set(x_202, 0, x_190); +lean_ctor_set(x_202, 1, x_191); +lean_ctor_set(x_202, 2, x_201); +lean_ctor_set(x_202, 3, x_192); +lean_ctor_set(x_202, 4, x_193); +lean_ctor_set(x_202, 5, x_194); if (lean_is_scalar(x_26)) { - x_209 = lean_alloc_ctor(0, 2, 0); + x_203 = lean_alloc_ctor(1, 2, 0); } else { - x_209 = x_26; + x_203 = x_26; + lean_ctor_set_tag(x_203, 1); } -lean_ctor_set(x_209, 0, x_196); -lean_ctor_set(x_209, 1, x_208); -return x_209; +lean_ctor_set(x_203, 0, x_189); +lean_ctor_set(x_203, 1, x_202); +return x_203; +} +else +{ +lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; +x_204 = lean_ctor_get(x_187, 2); +lean_inc(x_204); +x_205 = lean_ctor_get(x_186, 0); +lean_inc(x_205); +lean_dec(x_186); +x_206 = lean_ctor_get(x_187, 0); +lean_inc(x_206); +x_207 = lean_ctor_get(x_187, 1); +lean_inc(x_207); +x_208 = lean_ctor_get(x_187, 3); +lean_inc(x_208); +x_209 = lean_ctor_get(x_187, 4); +lean_inc(x_209); +x_210 = lean_ctor_get(x_187, 5); +lean_inc(x_210); +if (lean_is_exclusive(x_187)) { + lean_ctor_release(x_187, 0); + lean_ctor_release(x_187, 1); + lean_ctor_release(x_187, 2); + lean_ctor_release(x_187, 3); + lean_ctor_release(x_187, 4); + lean_ctor_release(x_187, 5); + x_211 = x_187; +} else { + lean_dec_ref(x_187); + x_211 = lean_box(0); +} +x_212 = lean_ctor_get(x_204, 0); +lean_inc(x_212); +x_213 = lean_ctor_get(x_204, 1); +lean_inc(x_213); +x_214 = lean_ctor_get(x_204, 3); +lean_inc(x_214); +x_215 = lean_ctor_get(x_204, 4); +lean_inc(x_215); +if (lean_is_exclusive(x_204)) { + lean_ctor_release(x_204, 0); + lean_ctor_release(x_204, 1); + lean_ctor_release(x_204, 2); + lean_ctor_release(x_204, 3); + lean_ctor_release(x_204, 4); + x_216 = x_204; +} else { + lean_dec_ref(x_204); + x_216 = lean_box(0); +} +if (lean_is_scalar(x_216)) { + x_217 = lean_alloc_ctor(0, 5, 0); +} else { + x_217 = x_216; +} +lean_ctor_set(x_217, 0, x_212); +lean_ctor_set(x_217, 1, x_213); +lean_ctor_set(x_217, 2, x_182); +lean_ctor_set(x_217, 3, x_214); +lean_ctor_set(x_217, 4, x_215); +if (lean_is_scalar(x_211)) { + x_218 = lean_alloc_ctor(0, 6, 0); +} else { + x_218 = x_211; +} +lean_ctor_set(x_218, 0, x_206); +lean_ctor_set(x_218, 1, x_207); +lean_ctor_set(x_218, 2, x_217); +lean_ctor_set(x_218, 3, x_208); +lean_ctor_set(x_218, 4, x_209); +lean_ctor_set(x_218, 5, x_210); +if (lean_is_scalar(x_26)) { + x_219 = lean_alloc_ctor(0, 2, 0); +} else { + x_219 = x_26; +} +lean_ctor_set(x_219, 0, x_205); +lean_ctor_set(x_219, 1, x_218); +return x_219; } } } } default: { -lean_object* x_230; lean_object* x_231; -x_230 = lean_ctor_get(x_19, 1); -lean_inc(x_230); +lean_object* x_240; lean_object* x_241; +x_240 = lean_ctor_get(x_19, 1); +lean_inc(x_240); lean_dec(x_19); lean_inc(x_7); -x_231 = l_Lean_Meta_isClassExpensive___main(x_18, x_7, x_230); -if (lean_obj_tag(x_231) == 0) +x_241 = l_Lean_Meta_isClassExpensive___main(x_18, x_7, x_240); +if (lean_obj_tag(x_241) == 0) { -lean_object* x_232; -x_232 = lean_ctor_get(x_231, 0); -lean_inc(x_232); -if (lean_obj_tag(x_232) == 0) +lean_object* x_242; +x_242 = lean_ctor_get(x_241, 0); +lean_inc(x_242); +if (lean_obj_tag(x_242) == 0) { -lean_object* x_233; lean_object* x_234; lean_object* x_235; +lean_object* x_243; lean_object* x_244; lean_object* x_245; lean_dec(x_14); -x_233 = lean_ctor_get(x_231, 1); -lean_inc(x_233); -lean_dec(x_231); -x_234 = lean_unsigned_to_nat(1u); -x_235 = lean_nat_add(x_6, x_234); +x_243 = lean_ctor_get(x_241, 1); +lean_inc(x_243); +lean_dec(x_241); +x_244 = lean_unsigned_to_nat(1u); +x_245 = lean_nat_add(x_6, x_244); lean_dec(x_6); -x_6 = x_235; -x_8 = x_233; +x_6 = x_245; +x_8 = x_243; goto _start; } else { -lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; uint8_t x_242; -x_237 = lean_ctor_get(x_231, 1); -lean_inc(x_237); -if (lean_is_exclusive(x_231)) { - lean_ctor_release(x_231, 0); - lean_ctor_release(x_231, 1); - x_238 = x_231; +lean_object* x_247; lean_object* x_248; lean_object* x_249; lean_object* x_250; lean_object* x_251; uint8_t x_252; +x_247 = lean_ctor_get(x_241, 1); +lean_inc(x_247); +if (lean_is_exclusive(x_241)) { + lean_ctor_release(x_241, 0); + lean_ctor_release(x_241, 1); + x_248 = x_241; } else { - lean_dec_ref(x_231); - x_238 = lean_box(0); + lean_dec_ref(x_241); + x_248 = lean_box(0); } -x_239 = lean_ctor_get(x_232, 0); -lean_inc(x_239); -lean_dec(x_232); -x_240 = lean_unsigned_to_nat(1u); -x_241 = lean_nat_add(x_6, x_240); -lean_dec(x_6); -x_242 = !lean_is_exclusive(x_237); -if (x_242 == 0) -{ -lean_object* x_243; uint8_t x_244; -x_243 = lean_ctor_get(x_237, 2); -x_244 = !lean_is_exclusive(x_243); -if (x_244 == 0) -{ -lean_object* x_245; lean_object* x_246; lean_object* x_247; lean_object* x_297; uint8_t x_298; -x_245 = lean_ctor_get(x_243, 2); -x_297 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_243, 2, x_297); -x_298 = !lean_is_exclusive(x_7); -if (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_7, 2); -x_300 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_300, 0, x_239); -lean_ctor_set(x_300, 1, x_14); -x_301 = lean_array_push(x_299, x_300); -lean_ctor_set(x_7, 2, x_301); -x_302 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_241, x_7, x_237); -if (lean_obj_tag(x_302) == 0) -{ -lean_object* x_303; lean_object* x_304; lean_object* x_305; -x_303 = lean_ctor_get(x_302, 0); -lean_inc(x_303); -x_304 = lean_ctor_get(x_302, 1); -lean_inc(x_304); -lean_dec(x_302); -x_305 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_305, 0, x_303); -x_246 = x_305; -x_247 = x_304; -goto block_296; -} -else -{ -lean_object* x_306; lean_object* x_307; lean_object* x_308; -x_306 = lean_ctor_get(x_302, 0); -lean_inc(x_306); -x_307 = lean_ctor_get(x_302, 1); -lean_inc(x_307); -lean_dec(x_302); -x_308 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_308, 0, x_306); -x_246 = x_308; -x_247 = x_307; -goto block_296; -} -} -else -{ -lean_object* x_309; lean_object* x_310; lean_object* x_311; lean_object* x_312; lean_object* x_313; lean_object* x_314; lean_object* x_315; lean_object* x_316; lean_object* x_317; -x_309 = lean_ctor_get(x_7, 0); -x_310 = lean_ctor_get(x_7, 1); -x_311 = lean_ctor_get(x_7, 2); -x_312 = lean_ctor_get(x_7, 3); -x_313 = lean_ctor_get(x_7, 4); -lean_inc(x_313); -lean_inc(x_312); -lean_inc(x_311); -lean_inc(x_310); -lean_inc(x_309); -lean_dec(x_7); -x_314 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_314, 0, x_239); -lean_ctor_set(x_314, 1, x_14); -x_315 = lean_array_push(x_311, x_314); -x_316 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_316, 0, x_309); -lean_ctor_set(x_316, 1, x_310); -lean_ctor_set(x_316, 2, x_315); -lean_ctor_set(x_316, 3, x_312); -lean_ctor_set(x_316, 4, x_313); -x_317 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_241, x_316, x_237); -if (lean_obj_tag(x_317) == 0) -{ -lean_object* x_318; lean_object* x_319; lean_object* x_320; -x_318 = lean_ctor_get(x_317, 0); -lean_inc(x_318); -x_319 = lean_ctor_get(x_317, 1); -lean_inc(x_319); -lean_dec(x_317); -x_320 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_320, 0, x_318); -x_246 = x_320; -x_247 = x_319; -goto block_296; -} -else -{ -lean_object* x_321; lean_object* x_322; lean_object* x_323; -x_321 = lean_ctor_get(x_317, 0); -lean_inc(x_321); -x_322 = lean_ctor_get(x_317, 1); -lean_inc(x_322); -lean_dec(x_317); -x_323 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_323, 0, x_321); -x_246 = x_323; -x_247 = x_322; -goto block_296; -} -} -block_296: -{ -if (lean_obj_tag(x_246) == 0) -{ -lean_object* x_248; lean_object* x_249; uint8_t x_250; -x_248 = lean_ctor_get(x_247, 2); -lean_inc(x_248); -x_249 = lean_ctor_get(x_246, 0); +x_249 = lean_ctor_get(x_242, 0); lean_inc(x_249); -lean_dec(x_246); -x_250 = !lean_is_exclusive(x_247); -if (x_250 == 0) -{ -lean_object* x_251; uint8_t x_252; -x_251 = lean_ctor_get(x_247, 2); -lean_dec(x_251); -x_252 = !lean_is_exclusive(x_248); +lean_dec(x_242); +x_250 = lean_unsigned_to_nat(1u); +x_251 = lean_nat_add(x_6, x_250); +lean_dec(x_6); +x_252 = !lean_is_exclusive(x_247); if (x_252 == 0) { -lean_object* x_253; lean_object* x_254; -x_253 = lean_ctor_get(x_248, 2); -lean_dec(x_253); -lean_ctor_set(x_248, 2, x_245); -if (lean_is_scalar(x_238)) { - x_254 = lean_alloc_ctor(1, 2, 0); -} else { - x_254 = x_238; - lean_ctor_set_tag(x_254, 1); -} -lean_ctor_set(x_254, 0, x_249); -lean_ctor_set(x_254, 1, x_247); -return x_254; +lean_object* x_253; uint8_t x_254; +x_253 = lean_ctor_get(x_247, 2); +x_254 = !lean_is_exclusive(x_253); +if (x_254 == 0) +{ +lean_object* x_255; lean_object* x_256; lean_object* x_257; lean_object* x_311; uint8_t x_312; +x_255 = lean_ctor_get(x_253, 2); +x_311 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_253, 2, x_311); +x_312 = !lean_is_exclusive(x_7); +if (x_312 == 0) +{ +lean_object* x_313; lean_object* x_314; lean_object* x_315; lean_object* x_316; +x_313 = lean_ctor_get(x_7, 2); +x_314 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_314, 0, x_249); +lean_ctor_set(x_314, 1, x_14); +x_315 = lean_array_push(x_313, x_314); +lean_ctor_set(x_7, 2, x_315); +x_316 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_251, x_7, x_247); +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); +x_319 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_319, 0, x_317); +x_256 = x_319; +x_257 = x_318; +goto block_310; } else { -lean_object* x_255; lean_object* x_256; lean_object* x_257; lean_object* x_258; lean_object* x_259; -x_255 = lean_ctor_get(x_248, 0); -x_256 = lean_ctor_get(x_248, 1); -x_257 = lean_ctor_get(x_248, 3); -lean_inc(x_257); -lean_inc(x_256); -lean_inc(x_255); -lean_dec(x_248); -x_258 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_258, 0, x_255); -lean_ctor_set(x_258, 1, x_256); -lean_ctor_set(x_258, 2, x_245); -lean_ctor_set(x_258, 3, x_257); -lean_ctor_set(x_247, 2, x_258); -if (lean_is_scalar(x_238)) { - x_259 = lean_alloc_ctor(1, 2, 0); -} else { - x_259 = x_238; - lean_ctor_set_tag(x_259, 1); -} -lean_ctor_set(x_259, 0, x_249); -lean_ctor_set(x_259, 1, x_247); -return x_259; +lean_object* x_320; lean_object* x_321; lean_object* x_322; +x_320 = lean_ctor_get(x_316, 0); +lean_inc(x_320); +x_321 = lean_ctor_get(x_316, 1); +lean_inc(x_321); +lean_dec(x_316); +x_322 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_322, 0, x_320); +x_256 = x_322; +x_257 = x_321; +goto block_310; } } else { -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_260 = lean_ctor_get(x_247, 0); -x_261 = lean_ctor_get(x_247, 1); -x_262 = lean_ctor_get(x_247, 3); -x_263 = lean_ctor_get(x_247, 4); -x_264 = lean_ctor_get(x_247, 5); -lean_inc(x_264); -lean_inc(x_263); -lean_inc(x_262); -lean_inc(x_261); -lean_inc(x_260); -lean_dec(x_247); -x_265 = lean_ctor_get(x_248, 0); -lean_inc(x_265); -x_266 = lean_ctor_get(x_248, 1); -lean_inc(x_266); -x_267 = lean_ctor_get(x_248, 3); +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; +x_323 = lean_ctor_get(x_7, 0); +x_324 = lean_ctor_get(x_7, 1); +x_325 = lean_ctor_get(x_7, 2); +x_326 = lean_ctor_get(x_7, 3); +x_327 = lean_ctor_get(x_7, 4); +lean_inc(x_327); +lean_inc(x_326); +lean_inc(x_325); +lean_inc(x_324); +lean_inc(x_323); +lean_dec(x_7); +x_328 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_328, 0, x_249); +lean_ctor_set(x_328, 1, x_14); +x_329 = lean_array_push(x_325, x_328); +x_330 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_330, 0, x_323); +lean_ctor_set(x_330, 1, x_324); +lean_ctor_set(x_330, 2, x_329); +lean_ctor_set(x_330, 3, x_326); +lean_ctor_set(x_330, 4, x_327); +x_331 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_251, x_330, x_247); +if (lean_obj_tag(x_331) == 0) +{ +lean_object* x_332; lean_object* x_333; lean_object* x_334; +x_332 = lean_ctor_get(x_331, 0); +lean_inc(x_332); +x_333 = lean_ctor_get(x_331, 1); +lean_inc(x_333); +lean_dec(x_331); +x_334 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_334, 0, x_332); +x_256 = x_334; +x_257 = x_333; +goto block_310; +} +else +{ +lean_object* x_335; lean_object* x_336; lean_object* x_337; +x_335 = lean_ctor_get(x_331, 0); +lean_inc(x_335); +x_336 = lean_ctor_get(x_331, 1); +lean_inc(x_336); +lean_dec(x_331); +x_337 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_337, 0, x_335); +x_256 = x_337; +x_257 = x_336; +goto block_310; +} +} +block_310: +{ +if (lean_obj_tag(x_256) == 0) +{ +lean_object* x_258; lean_object* x_259; uint8_t x_260; +x_258 = lean_ctor_get(x_257, 2); +lean_inc(x_258); +x_259 = lean_ctor_get(x_256, 0); +lean_inc(x_259); +lean_dec(x_256); +x_260 = !lean_is_exclusive(x_257); +if (x_260 == 0) +{ +lean_object* x_261; uint8_t x_262; +x_261 = lean_ctor_get(x_257, 2); +lean_dec(x_261); +x_262 = !lean_is_exclusive(x_258); +if (x_262 == 0) +{ +lean_object* x_263; lean_object* x_264; +x_263 = lean_ctor_get(x_258, 2); +lean_dec(x_263); +lean_ctor_set(x_258, 2, x_255); +if (lean_is_scalar(x_248)) { + x_264 = lean_alloc_ctor(1, 2, 0); +} else { + x_264 = x_248; + lean_ctor_set_tag(x_264, 1); +} +lean_ctor_set(x_264, 0, x_259); +lean_ctor_set(x_264, 1, x_257); +return x_264; +} +else +{ +lean_object* x_265; lean_object* x_266; lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_object* x_270; +x_265 = lean_ctor_get(x_258, 0); +x_266 = lean_ctor_get(x_258, 1); +x_267 = lean_ctor_get(x_258, 3); +x_268 = lean_ctor_get(x_258, 4); +lean_inc(x_268); lean_inc(x_267); -if (lean_is_exclusive(x_248)) { - lean_ctor_release(x_248, 0); - lean_ctor_release(x_248, 1); - lean_ctor_release(x_248, 2); - lean_ctor_release(x_248, 3); - x_268 = x_248; -} else { - lean_dec_ref(x_248); - x_268 = lean_box(0); -} -if (lean_is_scalar(x_268)) { - x_269 = lean_alloc_ctor(0, 4, 0); -} else { - x_269 = x_268; -} +lean_inc(x_266); +lean_inc(x_265); +lean_dec(x_258); +x_269 = lean_alloc_ctor(0, 5, 0); lean_ctor_set(x_269, 0, x_265); lean_ctor_set(x_269, 1, x_266); -lean_ctor_set(x_269, 2, x_245); +lean_ctor_set(x_269, 2, x_255); lean_ctor_set(x_269, 3, x_267); -x_270 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_270, 0, x_260); -lean_ctor_set(x_270, 1, x_261); -lean_ctor_set(x_270, 2, x_269); -lean_ctor_set(x_270, 3, x_262); -lean_ctor_set(x_270, 4, x_263); -lean_ctor_set(x_270, 5, x_264); -if (lean_is_scalar(x_238)) { - x_271 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_269, 4, x_268); +lean_ctor_set(x_257, 2, x_269); +if (lean_is_scalar(x_248)) { + x_270 = lean_alloc_ctor(1, 2, 0); } else { - x_271 = x_238; - lean_ctor_set_tag(x_271, 1); + x_270 = x_248; + lean_ctor_set_tag(x_270, 1); } -lean_ctor_set(x_271, 0, x_249); -lean_ctor_set(x_271, 1, x_270); -return x_271; +lean_ctor_set(x_270, 0, x_259); +lean_ctor_set(x_270, 1, x_257); +return x_270; } } else { -lean_object* x_272; lean_object* x_273; uint8_t x_274; -x_272 = lean_ctor_get(x_247, 2); -lean_inc(x_272); -x_273 = lean_ctor_get(x_246, 0); +lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_object* x_276; lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; lean_object* x_281; lean_object* x_282; lean_object* x_283; +x_271 = lean_ctor_get(x_257, 0); +x_272 = lean_ctor_get(x_257, 1); +x_273 = lean_ctor_get(x_257, 3); +x_274 = lean_ctor_get(x_257, 4); +x_275 = lean_ctor_get(x_257, 5); +lean_inc(x_275); +lean_inc(x_274); lean_inc(x_273); -lean_dec(x_246); -x_274 = !lean_is_exclusive(x_247); -if (x_274 == 0) -{ -lean_object* x_275; uint8_t x_276; -x_275 = lean_ctor_get(x_247, 2); -lean_dec(x_275); -x_276 = !lean_is_exclusive(x_272); -if (x_276 == 0) -{ -lean_object* x_277; lean_object* x_278; -x_277 = lean_ctor_get(x_272, 2); -lean_dec(x_277); -lean_ctor_set(x_272, 2, x_245); -if (lean_is_scalar(x_238)) { - x_278 = lean_alloc_ctor(0, 2, 0); -} else { - x_278 = x_238; -} -lean_ctor_set(x_278, 0, x_273); -lean_ctor_set(x_278, 1, x_247); -return x_278; -} -else -{ -lean_object* x_279; lean_object* x_280; lean_object* x_281; lean_object* x_282; lean_object* x_283; -x_279 = lean_ctor_get(x_272, 0); -x_280 = lean_ctor_get(x_272, 1); -x_281 = lean_ctor_get(x_272, 3); -lean_inc(x_281); -lean_inc(x_280); +lean_inc(x_272); +lean_inc(x_271); +lean_dec(x_257); +x_276 = lean_ctor_get(x_258, 0); +lean_inc(x_276); +x_277 = lean_ctor_get(x_258, 1); +lean_inc(x_277); +x_278 = lean_ctor_get(x_258, 3); +lean_inc(x_278); +x_279 = lean_ctor_get(x_258, 4); lean_inc(x_279); -lean_dec(x_272); -x_282 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_282, 0, x_279); -lean_ctor_set(x_282, 1, x_280); -lean_ctor_set(x_282, 2, x_245); -lean_ctor_set(x_282, 3, x_281); -lean_ctor_set(x_247, 2, x_282); -if (lean_is_scalar(x_238)) { - x_283 = lean_alloc_ctor(0, 2, 0); +if (lean_is_exclusive(x_258)) { + lean_ctor_release(x_258, 0); + lean_ctor_release(x_258, 1); + lean_ctor_release(x_258, 2); + lean_ctor_release(x_258, 3); + lean_ctor_release(x_258, 4); + x_280 = x_258; } else { - x_283 = x_238; + lean_dec_ref(x_258); + x_280 = lean_box(0); } -lean_ctor_set(x_283, 0, x_273); -lean_ctor_set(x_283, 1, x_247); +if (lean_is_scalar(x_280)) { + x_281 = lean_alloc_ctor(0, 5, 0); +} else { + x_281 = x_280; +} +lean_ctor_set(x_281, 0, x_276); +lean_ctor_set(x_281, 1, x_277); +lean_ctor_set(x_281, 2, x_255); +lean_ctor_set(x_281, 3, x_278); +lean_ctor_set(x_281, 4, x_279); +x_282 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_282, 0, x_271); +lean_ctor_set(x_282, 1, x_272); +lean_ctor_set(x_282, 2, x_281); +lean_ctor_set(x_282, 3, x_273); +lean_ctor_set(x_282, 4, x_274); +lean_ctor_set(x_282, 5, x_275); +if (lean_is_scalar(x_248)) { + x_283 = lean_alloc_ctor(1, 2, 0); +} else { + x_283 = x_248; + lean_ctor_set_tag(x_283, 1); +} +lean_ctor_set(x_283, 0, x_259); +lean_ctor_set(x_283, 1, x_282); return x_283; } } else { -lean_object* x_284; lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; lean_object* x_289; lean_object* x_290; lean_object* x_291; lean_object* x_292; lean_object* x_293; lean_object* x_294; lean_object* x_295; -x_284 = lean_ctor_get(x_247, 0); -x_285 = lean_ctor_get(x_247, 1); -x_286 = lean_ctor_get(x_247, 3); -x_287 = lean_ctor_get(x_247, 4); -x_288 = lean_ctor_get(x_247, 5); -lean_inc(x_288); -lean_inc(x_287); -lean_inc(x_286); -lean_inc(x_285); +lean_object* x_284; lean_object* x_285; uint8_t x_286; +x_284 = lean_ctor_get(x_257, 2); lean_inc(x_284); -lean_dec(x_247); -x_289 = lean_ctor_get(x_272, 0); -lean_inc(x_289); -x_290 = lean_ctor_get(x_272, 1); -lean_inc(x_290); -x_291 = lean_ctor_get(x_272, 3); +x_285 = lean_ctor_get(x_256, 0); +lean_inc(x_285); +lean_dec(x_256); +x_286 = !lean_is_exclusive(x_257); +if (x_286 == 0) +{ +lean_object* x_287; uint8_t x_288; +x_287 = lean_ctor_get(x_257, 2); +lean_dec(x_287); +x_288 = !lean_is_exclusive(x_284); +if (x_288 == 0) +{ +lean_object* x_289; lean_object* x_290; +x_289 = lean_ctor_get(x_284, 2); +lean_dec(x_289); +lean_ctor_set(x_284, 2, x_255); +if (lean_is_scalar(x_248)) { + x_290 = lean_alloc_ctor(0, 2, 0); +} else { + x_290 = x_248; +} +lean_ctor_set(x_290, 0, x_285); +lean_ctor_set(x_290, 1, x_257); +return x_290; +} +else +{ +lean_object* x_291; lean_object* x_292; lean_object* x_293; lean_object* x_294; lean_object* x_295; lean_object* x_296; +x_291 = lean_ctor_get(x_284, 0); +x_292 = lean_ctor_get(x_284, 1); +x_293 = lean_ctor_get(x_284, 3); +x_294 = lean_ctor_get(x_284, 4); +lean_inc(x_294); +lean_inc(x_293); +lean_inc(x_292); lean_inc(x_291); -if (lean_is_exclusive(x_272)) { - lean_ctor_release(x_272, 0); - lean_ctor_release(x_272, 1); - lean_ctor_release(x_272, 2); - lean_ctor_release(x_272, 3); - x_292 = x_272; +lean_dec(x_284); +x_295 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_295, 0, x_291); +lean_ctor_set(x_295, 1, x_292); +lean_ctor_set(x_295, 2, x_255); +lean_ctor_set(x_295, 3, x_293); +lean_ctor_set(x_295, 4, x_294); +lean_ctor_set(x_257, 2, x_295); +if (lean_is_scalar(x_248)) { + x_296 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_272); - x_292 = lean_box(0); + x_296 = x_248; } -if (lean_is_scalar(x_292)) { - x_293 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_296, 0, x_285); +lean_ctor_set(x_296, 1, x_257); +return x_296; +} +} +else +{ +lean_object* x_297; lean_object* x_298; lean_object* x_299; lean_object* x_300; lean_object* x_301; lean_object* x_302; lean_object* x_303; lean_object* x_304; lean_object* x_305; lean_object* x_306; lean_object* x_307; lean_object* x_308; lean_object* x_309; +x_297 = lean_ctor_get(x_257, 0); +x_298 = lean_ctor_get(x_257, 1); +x_299 = lean_ctor_get(x_257, 3); +x_300 = lean_ctor_get(x_257, 4); +x_301 = lean_ctor_get(x_257, 5); +lean_inc(x_301); +lean_inc(x_300); +lean_inc(x_299); +lean_inc(x_298); +lean_inc(x_297); +lean_dec(x_257); +x_302 = lean_ctor_get(x_284, 0); +lean_inc(x_302); +x_303 = lean_ctor_get(x_284, 1); +lean_inc(x_303); +x_304 = lean_ctor_get(x_284, 3); +lean_inc(x_304); +x_305 = lean_ctor_get(x_284, 4); +lean_inc(x_305); +if (lean_is_exclusive(x_284)) { + lean_ctor_release(x_284, 0); + lean_ctor_release(x_284, 1); + lean_ctor_release(x_284, 2); + lean_ctor_release(x_284, 3); + lean_ctor_release(x_284, 4); + x_306 = x_284; } else { - x_293 = x_292; + lean_dec_ref(x_284); + x_306 = lean_box(0); } -lean_ctor_set(x_293, 0, x_289); -lean_ctor_set(x_293, 1, x_290); -lean_ctor_set(x_293, 2, x_245); -lean_ctor_set(x_293, 3, x_291); -x_294 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_294, 0, x_284); -lean_ctor_set(x_294, 1, x_285); -lean_ctor_set(x_294, 2, x_293); -lean_ctor_set(x_294, 3, x_286); -lean_ctor_set(x_294, 4, x_287); -lean_ctor_set(x_294, 5, x_288); -if (lean_is_scalar(x_238)) { - x_295 = lean_alloc_ctor(0, 2, 0); +if (lean_is_scalar(x_306)) { + x_307 = lean_alloc_ctor(0, 5, 0); } else { - x_295 = x_238; + x_307 = x_306; } -lean_ctor_set(x_295, 0, x_273); -lean_ctor_set(x_295, 1, x_294); -return x_295; +lean_ctor_set(x_307, 0, x_302); +lean_ctor_set(x_307, 1, x_303); +lean_ctor_set(x_307, 2, x_255); +lean_ctor_set(x_307, 3, x_304); +lean_ctor_set(x_307, 4, x_305); +x_308 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_308, 0, x_297); +lean_ctor_set(x_308, 1, x_298); +lean_ctor_set(x_308, 2, x_307); +lean_ctor_set(x_308, 3, x_299); +lean_ctor_set(x_308, 4, x_300); +lean_ctor_set(x_308, 5, x_301); +if (lean_is_scalar(x_248)) { + x_309 = lean_alloc_ctor(0, 2, 0); +} else { + x_309 = x_248; +} +lean_ctor_set(x_309, 0, x_285); +lean_ctor_set(x_309, 1, x_308); +return x_309; } } } } else { -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_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; -x_324 = lean_ctor_get(x_243, 0); -x_325 = lean_ctor_get(x_243, 1); -x_326 = lean_ctor_get(x_243, 2); -x_327 = lean_ctor_get(x_243, 3); -lean_inc(x_327); -lean_inc(x_326); -lean_inc(x_325); -lean_inc(x_324); -lean_dec(x_243); -x_361 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_362 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_362, 0, x_324); -lean_ctor_set(x_362, 1, x_325); -lean_ctor_set(x_362, 2, x_361); -lean_ctor_set(x_362, 3, x_327); -lean_ctor_set(x_237, 2, x_362); -x_363 = lean_ctor_get(x_7, 0); -lean_inc(x_363); -x_364 = lean_ctor_get(x_7, 1); -lean_inc(x_364); -x_365 = lean_ctor_get(x_7, 2); -lean_inc(x_365); -x_366 = lean_ctor_get(x_7, 3); -lean_inc(x_366); -x_367 = lean_ctor_get(x_7, 4); -lean_inc(x_367); +lean_object* x_338; lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; lean_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; +x_338 = lean_ctor_get(x_253, 0); +x_339 = lean_ctor_get(x_253, 1); +x_340 = lean_ctor_get(x_253, 2); +x_341 = lean_ctor_get(x_253, 3); +x_342 = lean_ctor_get(x_253, 4); +lean_inc(x_342); +lean_inc(x_341); +lean_inc(x_340); +lean_inc(x_339); +lean_inc(x_338); +lean_dec(x_253); +x_378 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_379 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_379, 0, x_338); +lean_ctor_set(x_379, 1, x_339); +lean_ctor_set(x_379, 2, x_378); +lean_ctor_set(x_379, 3, x_341); +lean_ctor_set(x_379, 4, x_342); +lean_ctor_set(x_247, 2, x_379); +x_380 = lean_ctor_get(x_7, 0); +lean_inc(x_380); +x_381 = lean_ctor_get(x_7, 1); +lean_inc(x_381); +x_382 = lean_ctor_get(x_7, 2); +lean_inc(x_382); +x_383 = lean_ctor_get(x_7, 3); +lean_inc(x_383); +x_384 = lean_ctor_get(x_7, 4); +lean_inc(x_384); if (lean_is_exclusive(x_7)) { lean_ctor_release(x_7, 0); lean_ctor_release(x_7, 1); lean_ctor_release(x_7, 2); lean_ctor_release(x_7, 3); lean_ctor_release(x_7, 4); - x_368 = x_7; + x_385 = x_7; } else { lean_dec_ref(x_7); - x_368 = lean_box(0); + x_385 = lean_box(0); } -x_369 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_369, 0, x_239); -lean_ctor_set(x_369, 1, x_14); -x_370 = lean_array_push(x_365, x_369); -if (lean_is_scalar(x_368)) { - x_371 = lean_alloc_ctor(0, 5, 0); +x_386 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_386, 0, x_249); +lean_ctor_set(x_386, 1, x_14); +x_387 = lean_array_push(x_382, x_386); +if (lean_is_scalar(x_385)) { + x_388 = lean_alloc_ctor(0, 5, 0); } else { - x_371 = x_368; + x_388 = x_385; } -lean_ctor_set(x_371, 0, x_363); -lean_ctor_set(x_371, 1, x_364); -lean_ctor_set(x_371, 2, x_370); -lean_ctor_set(x_371, 3, x_366); -lean_ctor_set(x_371, 4, x_367); -x_372 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_241, x_371, x_237); -if (lean_obj_tag(x_372) == 0) +lean_ctor_set(x_388, 0, x_380); +lean_ctor_set(x_388, 1, x_381); +lean_ctor_set(x_388, 2, x_387); +lean_ctor_set(x_388, 3, x_383); +lean_ctor_set(x_388, 4, x_384); +x_389 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_251, x_388, x_247); +if (lean_obj_tag(x_389) == 0) { -lean_object* x_373; lean_object* x_374; lean_object* x_375; -x_373 = lean_ctor_get(x_372, 0); -lean_inc(x_373); -x_374 = lean_ctor_get(x_372, 1); -lean_inc(x_374); -lean_dec(x_372); -x_375 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_375, 0, x_373); -x_328 = x_375; -x_329 = x_374; -goto block_360; +lean_object* x_390; lean_object* x_391; lean_object* x_392; +x_390 = lean_ctor_get(x_389, 0); +lean_inc(x_390); +x_391 = lean_ctor_get(x_389, 1); +lean_inc(x_391); +lean_dec(x_389); +x_392 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_392, 0, x_390); +x_343 = x_392; +x_344 = x_391; +goto block_377; } else { -lean_object* x_376; lean_object* x_377; lean_object* x_378; -x_376 = lean_ctor_get(x_372, 0); -lean_inc(x_376); -x_377 = lean_ctor_get(x_372, 1); -lean_inc(x_377); -lean_dec(x_372); -x_378 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_378, 0, x_376); -x_328 = x_378; -x_329 = x_377; -goto block_360; +lean_object* x_393; lean_object* x_394; lean_object* x_395; +x_393 = lean_ctor_get(x_389, 0); +lean_inc(x_393); +x_394 = lean_ctor_get(x_389, 1); +lean_inc(x_394); +lean_dec(x_389); +x_395 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_395, 0, x_393); +x_343 = x_395; +x_344 = x_394; +goto block_377; } -block_360: +block_377: { -if (lean_obj_tag(x_328) == 0) +if (lean_obj_tag(x_343) == 0) { -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; lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; -x_330 = lean_ctor_get(x_329, 2); -lean_inc(x_330); -x_331 = lean_ctor_get(x_328, 0); -lean_inc(x_331); -lean_dec(x_328); -x_332 = lean_ctor_get(x_329, 0); -lean_inc(x_332); -x_333 = lean_ctor_get(x_329, 1); -lean_inc(x_333); -x_334 = lean_ctor_get(x_329, 3); -lean_inc(x_334); -x_335 = lean_ctor_get(x_329, 4); -lean_inc(x_335); -x_336 = lean_ctor_get(x_329, 5); -lean_inc(x_336); -if (lean_is_exclusive(x_329)) { - lean_ctor_release(x_329, 0); - lean_ctor_release(x_329, 1); - lean_ctor_release(x_329, 2); - lean_ctor_release(x_329, 3); - lean_ctor_release(x_329, 4); - lean_ctor_release(x_329, 5); - x_337 = x_329; -} else { - lean_dec_ref(x_329); - x_337 = lean_box(0); -} -x_338 = lean_ctor_get(x_330, 0); -lean_inc(x_338); -x_339 = lean_ctor_get(x_330, 1); -lean_inc(x_339); -x_340 = lean_ctor_get(x_330, 3); -lean_inc(x_340); -if (lean_is_exclusive(x_330)) { - lean_ctor_release(x_330, 0); - lean_ctor_release(x_330, 1); - lean_ctor_release(x_330, 2); - lean_ctor_release(x_330, 3); - x_341 = x_330; -} else { - lean_dec_ref(x_330); - x_341 = lean_box(0); -} -if (lean_is_scalar(x_341)) { - x_342 = lean_alloc_ctor(0, 4, 0); -} else { - x_342 = x_341; -} -lean_ctor_set(x_342, 0, x_338); -lean_ctor_set(x_342, 1, x_339); -lean_ctor_set(x_342, 2, x_326); -lean_ctor_set(x_342, 3, x_340); -if (lean_is_scalar(x_337)) { - x_343 = lean_alloc_ctor(0, 6, 0); -} else { - x_343 = x_337; -} -lean_ctor_set(x_343, 0, x_332); -lean_ctor_set(x_343, 1, x_333); -lean_ctor_set(x_343, 2, x_342); -lean_ctor_set(x_343, 3, x_334); -lean_ctor_set(x_343, 4, x_335); -lean_ctor_set(x_343, 5, x_336); -if (lean_is_scalar(x_238)) { - x_344 = lean_alloc_ctor(1, 2, 0); -} else { - x_344 = x_238; - lean_ctor_set_tag(x_344, 1); -} -lean_ctor_set(x_344, 0, x_331); -lean_ctor_set(x_344, 1, x_343); -return x_344; -} -else -{ -lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; lean_object* x_350; lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; lean_object* x_358; lean_object* x_359; -x_345 = lean_ctor_get(x_329, 2); +lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; lean_object* x_350; lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; lean_object* x_358; lean_object* x_359; lean_object* x_360; +x_345 = lean_ctor_get(x_344, 2); lean_inc(x_345); -x_346 = lean_ctor_get(x_328, 0); +x_346 = lean_ctor_get(x_343, 0); lean_inc(x_346); -lean_dec(x_328); -x_347 = lean_ctor_get(x_329, 0); +lean_dec(x_343); +x_347 = lean_ctor_get(x_344, 0); lean_inc(x_347); -x_348 = lean_ctor_get(x_329, 1); +x_348 = lean_ctor_get(x_344, 1); lean_inc(x_348); -x_349 = lean_ctor_get(x_329, 3); +x_349 = lean_ctor_get(x_344, 3); lean_inc(x_349); -x_350 = lean_ctor_get(x_329, 4); +x_350 = lean_ctor_get(x_344, 4); lean_inc(x_350); -x_351 = lean_ctor_get(x_329, 5); +x_351 = lean_ctor_get(x_344, 5); lean_inc(x_351); -if (lean_is_exclusive(x_329)) { - lean_ctor_release(x_329, 0); - lean_ctor_release(x_329, 1); - lean_ctor_release(x_329, 2); - lean_ctor_release(x_329, 3); - lean_ctor_release(x_329, 4); - lean_ctor_release(x_329, 5); - x_352 = x_329; +if (lean_is_exclusive(x_344)) { + lean_ctor_release(x_344, 0); + lean_ctor_release(x_344, 1); + lean_ctor_release(x_344, 2); + lean_ctor_release(x_344, 3); + lean_ctor_release(x_344, 4); + lean_ctor_release(x_344, 5); + x_352 = x_344; } else { - lean_dec_ref(x_329); + lean_dec_ref(x_344); x_352 = lean_box(0); } x_353 = lean_ctor_get(x_345, 0); @@ -28805,315 +29629,411 @@ x_354 = lean_ctor_get(x_345, 1); lean_inc(x_354); x_355 = lean_ctor_get(x_345, 3); lean_inc(x_355); +x_356 = lean_ctor_get(x_345, 4); +lean_inc(x_356); if (lean_is_exclusive(x_345)) { lean_ctor_release(x_345, 0); lean_ctor_release(x_345, 1); lean_ctor_release(x_345, 2); lean_ctor_release(x_345, 3); - x_356 = x_345; + lean_ctor_release(x_345, 4); + x_357 = x_345; } else { lean_dec_ref(x_345); - x_356 = lean_box(0); + x_357 = lean_box(0); } -if (lean_is_scalar(x_356)) { - x_357 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_357)) { + x_358 = lean_alloc_ctor(0, 5, 0); } else { - x_357 = x_356; + x_358 = x_357; } -lean_ctor_set(x_357, 0, x_353); -lean_ctor_set(x_357, 1, x_354); -lean_ctor_set(x_357, 2, x_326); -lean_ctor_set(x_357, 3, x_355); +lean_ctor_set(x_358, 0, x_353); +lean_ctor_set(x_358, 1, x_354); +lean_ctor_set(x_358, 2, x_340); +lean_ctor_set(x_358, 3, x_355); +lean_ctor_set(x_358, 4, x_356); if (lean_is_scalar(x_352)) { - x_358 = lean_alloc_ctor(0, 6, 0); + x_359 = lean_alloc_ctor(0, 6, 0); } else { - x_358 = x_352; + x_359 = x_352; } -lean_ctor_set(x_358, 0, x_347); -lean_ctor_set(x_358, 1, x_348); -lean_ctor_set(x_358, 2, x_357); -lean_ctor_set(x_358, 3, x_349); -lean_ctor_set(x_358, 4, x_350); -lean_ctor_set(x_358, 5, x_351); -if (lean_is_scalar(x_238)) { - x_359 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_359, 0, x_347); +lean_ctor_set(x_359, 1, x_348); +lean_ctor_set(x_359, 2, x_358); +lean_ctor_set(x_359, 3, x_349); +lean_ctor_set(x_359, 4, x_350); +lean_ctor_set(x_359, 5, x_351); +if (lean_is_scalar(x_248)) { + x_360 = lean_alloc_ctor(1, 2, 0); } else { - x_359 = x_238; + x_360 = x_248; + lean_ctor_set_tag(x_360, 1); } -lean_ctor_set(x_359, 0, x_346); -lean_ctor_set(x_359, 1, x_358); -return x_359; +lean_ctor_set(x_360, 0, x_346); +lean_ctor_set(x_360, 1, x_359); +return x_360; +} +else +{ +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; lean_object* x_374; lean_object* x_375; lean_object* x_376; +x_361 = lean_ctor_get(x_344, 2); +lean_inc(x_361); +x_362 = lean_ctor_get(x_343, 0); +lean_inc(x_362); +lean_dec(x_343); +x_363 = lean_ctor_get(x_344, 0); +lean_inc(x_363); +x_364 = lean_ctor_get(x_344, 1); +lean_inc(x_364); +x_365 = lean_ctor_get(x_344, 3); +lean_inc(x_365); +x_366 = lean_ctor_get(x_344, 4); +lean_inc(x_366); +x_367 = lean_ctor_get(x_344, 5); +lean_inc(x_367); +if (lean_is_exclusive(x_344)) { + lean_ctor_release(x_344, 0); + lean_ctor_release(x_344, 1); + lean_ctor_release(x_344, 2); + lean_ctor_release(x_344, 3); + lean_ctor_release(x_344, 4); + lean_ctor_release(x_344, 5); + x_368 = x_344; +} else { + lean_dec_ref(x_344); + x_368 = lean_box(0); +} +x_369 = lean_ctor_get(x_361, 0); +lean_inc(x_369); +x_370 = lean_ctor_get(x_361, 1); +lean_inc(x_370); +x_371 = lean_ctor_get(x_361, 3); +lean_inc(x_371); +x_372 = lean_ctor_get(x_361, 4); +lean_inc(x_372); +if (lean_is_exclusive(x_361)) { + lean_ctor_release(x_361, 0); + lean_ctor_release(x_361, 1); + lean_ctor_release(x_361, 2); + lean_ctor_release(x_361, 3); + lean_ctor_release(x_361, 4); + x_373 = x_361; +} else { + lean_dec_ref(x_361); + x_373 = lean_box(0); +} +if (lean_is_scalar(x_373)) { + x_374 = lean_alloc_ctor(0, 5, 0); +} else { + x_374 = x_373; +} +lean_ctor_set(x_374, 0, x_369); +lean_ctor_set(x_374, 1, x_370); +lean_ctor_set(x_374, 2, x_340); +lean_ctor_set(x_374, 3, x_371); +lean_ctor_set(x_374, 4, x_372); +if (lean_is_scalar(x_368)) { + x_375 = lean_alloc_ctor(0, 6, 0); +} else { + x_375 = x_368; +} +lean_ctor_set(x_375, 0, x_363); +lean_ctor_set(x_375, 1, x_364); +lean_ctor_set(x_375, 2, x_374); +lean_ctor_set(x_375, 3, x_365); +lean_ctor_set(x_375, 4, x_366); +lean_ctor_set(x_375, 5, x_367); +if (lean_is_scalar(x_248)) { + x_376 = lean_alloc_ctor(0, 2, 0); +} else { + x_376 = x_248; +} +lean_ctor_set(x_376, 0, x_362); +lean_ctor_set(x_376, 1, x_375); +return x_376; } } } } else { -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; lean_object* x_391; lean_object* x_423; lean_object* x_424; lean_object* x_425; lean_object* x_426; lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; lean_object* x_432; lean_object* x_433; lean_object* x_434; lean_object* x_435; -x_379 = lean_ctor_get(x_237, 2); -x_380 = lean_ctor_get(x_237, 0); -x_381 = lean_ctor_get(x_237, 1); -x_382 = lean_ctor_get(x_237, 3); -x_383 = lean_ctor_get(x_237, 4); -x_384 = lean_ctor_get(x_237, 5); -lean_inc(x_384); -lean_inc(x_383); -lean_inc(x_382); -lean_inc(x_379); -lean_inc(x_381); -lean_inc(x_380); -lean_dec(x_237); -x_385 = lean_ctor_get(x_379, 0); -lean_inc(x_385); -x_386 = lean_ctor_get(x_379, 1); -lean_inc(x_386); -x_387 = lean_ctor_get(x_379, 2); -lean_inc(x_387); -x_388 = lean_ctor_get(x_379, 3); -lean_inc(x_388); -if (lean_is_exclusive(x_379)) { - lean_ctor_release(x_379, 0); - lean_ctor_release(x_379, 1); - lean_ctor_release(x_379, 2); - lean_ctor_release(x_379, 3); - x_389 = x_379; +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; lean_object* x_408; lean_object* x_409; lean_object* x_443; lean_object* x_444; lean_object* x_445; lean_object* x_446; lean_object* x_447; lean_object* x_448; lean_object* x_449; lean_object* x_450; lean_object* x_451; lean_object* x_452; lean_object* x_453; lean_object* x_454; lean_object* x_455; +x_396 = lean_ctor_get(x_247, 2); +x_397 = lean_ctor_get(x_247, 0); +x_398 = lean_ctor_get(x_247, 1); +x_399 = lean_ctor_get(x_247, 3); +x_400 = lean_ctor_get(x_247, 4); +x_401 = lean_ctor_get(x_247, 5); +lean_inc(x_401); +lean_inc(x_400); +lean_inc(x_399); +lean_inc(x_396); +lean_inc(x_398); +lean_inc(x_397); +lean_dec(x_247); +x_402 = lean_ctor_get(x_396, 0); +lean_inc(x_402); +x_403 = lean_ctor_get(x_396, 1); +lean_inc(x_403); +x_404 = lean_ctor_get(x_396, 2); +lean_inc(x_404); +x_405 = lean_ctor_get(x_396, 3); +lean_inc(x_405); +x_406 = lean_ctor_get(x_396, 4); +lean_inc(x_406); +if (lean_is_exclusive(x_396)) { + lean_ctor_release(x_396, 0); + lean_ctor_release(x_396, 1); + lean_ctor_release(x_396, 2); + lean_ctor_release(x_396, 3); + lean_ctor_release(x_396, 4); + x_407 = x_396; } else { - lean_dec_ref(x_379); - x_389 = lean_box(0); + lean_dec_ref(x_396); + x_407 = lean_box(0); } -x_423 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_389)) { - x_424 = lean_alloc_ctor(0, 4, 0); +x_443 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_407)) { + x_444 = lean_alloc_ctor(0, 5, 0); } else { - x_424 = x_389; + x_444 = x_407; } -lean_ctor_set(x_424, 0, x_385); -lean_ctor_set(x_424, 1, x_386); -lean_ctor_set(x_424, 2, x_423); -lean_ctor_set(x_424, 3, x_388); -x_425 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_425, 0, x_380); -lean_ctor_set(x_425, 1, x_381); -lean_ctor_set(x_425, 2, x_424); -lean_ctor_set(x_425, 3, x_382); -lean_ctor_set(x_425, 4, x_383); -lean_ctor_set(x_425, 5, x_384); -x_426 = lean_ctor_get(x_7, 0); -lean_inc(x_426); -x_427 = lean_ctor_get(x_7, 1); -lean_inc(x_427); -x_428 = lean_ctor_get(x_7, 2); -lean_inc(x_428); -x_429 = lean_ctor_get(x_7, 3); -lean_inc(x_429); -x_430 = lean_ctor_get(x_7, 4); -lean_inc(x_430); +lean_ctor_set(x_444, 0, x_402); +lean_ctor_set(x_444, 1, x_403); +lean_ctor_set(x_444, 2, x_443); +lean_ctor_set(x_444, 3, x_405); +lean_ctor_set(x_444, 4, x_406); +x_445 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_445, 0, x_397); +lean_ctor_set(x_445, 1, x_398); +lean_ctor_set(x_445, 2, x_444); +lean_ctor_set(x_445, 3, x_399); +lean_ctor_set(x_445, 4, x_400); +lean_ctor_set(x_445, 5, x_401); +x_446 = lean_ctor_get(x_7, 0); +lean_inc(x_446); +x_447 = lean_ctor_get(x_7, 1); +lean_inc(x_447); +x_448 = lean_ctor_get(x_7, 2); +lean_inc(x_448); +x_449 = lean_ctor_get(x_7, 3); +lean_inc(x_449); +x_450 = lean_ctor_get(x_7, 4); +lean_inc(x_450); if (lean_is_exclusive(x_7)) { lean_ctor_release(x_7, 0); lean_ctor_release(x_7, 1); lean_ctor_release(x_7, 2); lean_ctor_release(x_7, 3); lean_ctor_release(x_7, 4); - x_431 = x_7; + x_451 = x_7; } else { lean_dec_ref(x_7); - x_431 = lean_box(0); + x_451 = lean_box(0); } -x_432 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_432, 0, x_239); -lean_ctor_set(x_432, 1, x_14); -x_433 = lean_array_push(x_428, x_432); -if (lean_is_scalar(x_431)) { - x_434 = lean_alloc_ctor(0, 5, 0); +x_452 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_452, 0, x_249); +lean_ctor_set(x_452, 1, x_14); +x_453 = lean_array_push(x_448, x_452); +if (lean_is_scalar(x_451)) { + x_454 = lean_alloc_ctor(0, 5, 0); } else { - x_434 = x_431; + x_454 = x_451; } -lean_ctor_set(x_434, 0, x_426); -lean_ctor_set(x_434, 1, x_427); -lean_ctor_set(x_434, 2, x_433); -lean_ctor_set(x_434, 3, x_429); -lean_ctor_set(x_434, 4, x_430); -x_435 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_241, x_434, x_425); -if (lean_obj_tag(x_435) == 0) +lean_ctor_set(x_454, 0, x_446); +lean_ctor_set(x_454, 1, x_447); +lean_ctor_set(x_454, 2, x_453); +lean_ctor_set(x_454, 3, x_449); +lean_ctor_set(x_454, 4, x_450); +x_455 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_251, x_454, x_445); +if (lean_obj_tag(x_455) == 0) { -lean_object* x_436; lean_object* x_437; lean_object* x_438; -x_436 = lean_ctor_get(x_435, 0); -lean_inc(x_436); -x_437 = lean_ctor_get(x_435, 1); -lean_inc(x_437); -lean_dec(x_435); -x_438 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_438, 0, x_436); -x_390 = x_438; -x_391 = x_437; -goto block_422; +lean_object* x_456; lean_object* x_457; lean_object* x_458; +x_456 = lean_ctor_get(x_455, 0); +lean_inc(x_456); +x_457 = lean_ctor_get(x_455, 1); +lean_inc(x_457); +lean_dec(x_455); +x_458 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_458, 0, x_456); +x_408 = x_458; +x_409 = x_457; +goto block_442; } else { -lean_object* x_439; lean_object* x_440; lean_object* x_441; -x_439 = lean_ctor_get(x_435, 0); -lean_inc(x_439); -x_440 = lean_ctor_get(x_435, 1); -lean_inc(x_440); -lean_dec(x_435); -x_441 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_441, 0, x_439); -x_390 = x_441; -x_391 = x_440; -goto block_422; +lean_object* x_459; lean_object* x_460; lean_object* x_461; +x_459 = lean_ctor_get(x_455, 0); +lean_inc(x_459); +x_460 = lean_ctor_get(x_455, 1); +lean_inc(x_460); +lean_dec(x_455); +x_461 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_461, 0, x_459); +x_408 = x_461; +x_409 = x_460; +goto block_442; } -block_422: +block_442: { -if (lean_obj_tag(x_390) == 0) +if (lean_obj_tag(x_408) == 0) { -lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; lean_object* x_400; lean_object* x_401; lean_object* x_402; lean_object* x_403; lean_object* x_404; lean_object* x_405; lean_object* x_406; -x_392 = lean_ctor_get(x_391, 2); -lean_inc(x_392); -x_393 = lean_ctor_get(x_390, 0); -lean_inc(x_393); -lean_dec(x_390); -x_394 = lean_ctor_get(x_391, 0); -lean_inc(x_394); -x_395 = lean_ctor_get(x_391, 1); -lean_inc(x_395); -x_396 = lean_ctor_get(x_391, 3); -lean_inc(x_396); -x_397 = lean_ctor_get(x_391, 4); -lean_inc(x_397); -x_398 = lean_ctor_get(x_391, 5); -lean_inc(x_398); -if (lean_is_exclusive(x_391)) { - lean_ctor_release(x_391, 0); - lean_ctor_release(x_391, 1); - lean_ctor_release(x_391, 2); - lean_ctor_release(x_391, 3); - lean_ctor_release(x_391, 4); - lean_ctor_release(x_391, 5); - x_399 = x_391; -} else { - lean_dec_ref(x_391); - x_399 = lean_box(0); -} -x_400 = lean_ctor_get(x_392, 0); -lean_inc(x_400); -x_401 = lean_ctor_get(x_392, 1); -lean_inc(x_401); -x_402 = lean_ctor_get(x_392, 3); -lean_inc(x_402); -if (lean_is_exclusive(x_392)) { - lean_ctor_release(x_392, 0); - lean_ctor_release(x_392, 1); - lean_ctor_release(x_392, 2); - lean_ctor_release(x_392, 3); - x_403 = x_392; -} else { - lean_dec_ref(x_392); - x_403 = lean_box(0); -} -if (lean_is_scalar(x_403)) { - x_404 = lean_alloc_ctor(0, 4, 0); -} else { - x_404 = x_403; -} -lean_ctor_set(x_404, 0, x_400); -lean_ctor_set(x_404, 1, x_401); -lean_ctor_set(x_404, 2, x_387); -lean_ctor_set(x_404, 3, x_402); -if (lean_is_scalar(x_399)) { - x_405 = lean_alloc_ctor(0, 6, 0); -} else { - x_405 = x_399; -} -lean_ctor_set(x_405, 0, x_394); -lean_ctor_set(x_405, 1, x_395); -lean_ctor_set(x_405, 2, x_404); -lean_ctor_set(x_405, 3, x_396); -lean_ctor_set(x_405, 4, x_397); -lean_ctor_set(x_405, 5, x_398); -if (lean_is_scalar(x_238)) { - x_406 = lean_alloc_ctor(1, 2, 0); -} else { - x_406 = x_238; - lean_ctor_set_tag(x_406, 1); -} -lean_ctor_set(x_406, 0, x_393); -lean_ctor_set(x_406, 1, x_405); -return x_406; -} -else -{ -lean_object* x_407; lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_object* x_412; lean_object* x_413; lean_object* x_414; lean_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; -x_407 = lean_ctor_get(x_391, 2); -lean_inc(x_407); -x_408 = lean_ctor_get(x_390, 0); -lean_inc(x_408); -lean_dec(x_390); -x_409 = lean_ctor_get(x_391, 0); -lean_inc(x_409); -x_410 = lean_ctor_get(x_391, 1); +lean_object* x_410; 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_410 = lean_ctor_get(x_409, 2); lean_inc(x_410); -x_411 = lean_ctor_get(x_391, 3); +x_411 = lean_ctor_get(x_408, 0); lean_inc(x_411); -x_412 = lean_ctor_get(x_391, 4); +lean_dec(x_408); +x_412 = lean_ctor_get(x_409, 0); lean_inc(x_412); -x_413 = lean_ctor_get(x_391, 5); +x_413 = lean_ctor_get(x_409, 1); lean_inc(x_413); -if (lean_is_exclusive(x_391)) { - lean_ctor_release(x_391, 0); - lean_ctor_release(x_391, 1); - lean_ctor_release(x_391, 2); - lean_ctor_release(x_391, 3); - lean_ctor_release(x_391, 4); - lean_ctor_release(x_391, 5); - x_414 = x_391; -} else { - lean_dec_ref(x_391); - x_414 = lean_box(0); -} -x_415 = lean_ctor_get(x_407, 0); +x_414 = lean_ctor_get(x_409, 3); +lean_inc(x_414); +x_415 = lean_ctor_get(x_409, 4); lean_inc(x_415); -x_416 = lean_ctor_get(x_407, 1); +x_416 = lean_ctor_get(x_409, 5); lean_inc(x_416); -x_417 = lean_ctor_get(x_407, 3); -lean_inc(x_417); -if (lean_is_exclusive(x_407)) { - lean_ctor_release(x_407, 0); - lean_ctor_release(x_407, 1); - lean_ctor_release(x_407, 2); - lean_ctor_release(x_407, 3); - x_418 = x_407; +if (lean_is_exclusive(x_409)) { + lean_ctor_release(x_409, 0); + lean_ctor_release(x_409, 1); + lean_ctor_release(x_409, 2); + lean_ctor_release(x_409, 3); + lean_ctor_release(x_409, 4); + lean_ctor_release(x_409, 5); + x_417 = x_409; } else { - lean_dec_ref(x_407); - x_418 = lean_box(0); + lean_dec_ref(x_409); + x_417 = lean_box(0); } -if (lean_is_scalar(x_418)) { - x_419 = lean_alloc_ctor(0, 4, 0); +x_418 = lean_ctor_get(x_410, 0); +lean_inc(x_418); +x_419 = lean_ctor_get(x_410, 1); +lean_inc(x_419); +x_420 = lean_ctor_get(x_410, 3); +lean_inc(x_420); +x_421 = lean_ctor_get(x_410, 4); +lean_inc(x_421); +if (lean_is_exclusive(x_410)) { + lean_ctor_release(x_410, 0); + lean_ctor_release(x_410, 1); + lean_ctor_release(x_410, 2); + lean_ctor_release(x_410, 3); + lean_ctor_release(x_410, 4); + x_422 = x_410; } else { - x_419 = x_418; + lean_dec_ref(x_410); + x_422 = lean_box(0); } -lean_ctor_set(x_419, 0, x_415); -lean_ctor_set(x_419, 1, x_416); -lean_ctor_set(x_419, 2, x_387); -lean_ctor_set(x_419, 3, x_417); -if (lean_is_scalar(x_414)) { - x_420 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_422)) { + x_423 = lean_alloc_ctor(0, 5, 0); } else { - x_420 = x_414; + x_423 = x_422; } -lean_ctor_set(x_420, 0, x_409); -lean_ctor_set(x_420, 1, x_410); -lean_ctor_set(x_420, 2, x_419); -lean_ctor_set(x_420, 3, x_411); -lean_ctor_set(x_420, 4, x_412); -lean_ctor_set(x_420, 5, x_413); -if (lean_is_scalar(x_238)) { - x_421 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_423, 0, x_418); +lean_ctor_set(x_423, 1, x_419); +lean_ctor_set(x_423, 2, x_404); +lean_ctor_set(x_423, 3, x_420); +lean_ctor_set(x_423, 4, x_421); +if (lean_is_scalar(x_417)) { + x_424 = lean_alloc_ctor(0, 6, 0); } else { - x_421 = x_238; + x_424 = x_417; } -lean_ctor_set(x_421, 0, x_408); -lean_ctor_set(x_421, 1, x_420); -return x_421; +lean_ctor_set(x_424, 0, x_412); +lean_ctor_set(x_424, 1, x_413); +lean_ctor_set(x_424, 2, x_423); +lean_ctor_set(x_424, 3, x_414); +lean_ctor_set(x_424, 4, x_415); +lean_ctor_set(x_424, 5, x_416); +if (lean_is_scalar(x_248)) { + x_425 = lean_alloc_ctor(1, 2, 0); +} else { + x_425 = x_248; + lean_ctor_set_tag(x_425, 1); +} +lean_ctor_set(x_425, 0, x_411); +lean_ctor_set(x_425, 1, x_424); +return x_425; +} +else +{ +lean_object* x_426; lean_object* x_427; 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; +x_426 = lean_ctor_get(x_409, 2); +lean_inc(x_426); +x_427 = lean_ctor_get(x_408, 0); +lean_inc(x_427); +lean_dec(x_408); +x_428 = lean_ctor_get(x_409, 0); +lean_inc(x_428); +x_429 = lean_ctor_get(x_409, 1); +lean_inc(x_429); +x_430 = lean_ctor_get(x_409, 3); +lean_inc(x_430); +x_431 = lean_ctor_get(x_409, 4); +lean_inc(x_431); +x_432 = lean_ctor_get(x_409, 5); +lean_inc(x_432); +if (lean_is_exclusive(x_409)) { + lean_ctor_release(x_409, 0); + lean_ctor_release(x_409, 1); + lean_ctor_release(x_409, 2); + lean_ctor_release(x_409, 3); + lean_ctor_release(x_409, 4); + lean_ctor_release(x_409, 5); + x_433 = x_409; +} else { + lean_dec_ref(x_409); + x_433 = lean_box(0); +} +x_434 = lean_ctor_get(x_426, 0); +lean_inc(x_434); +x_435 = lean_ctor_get(x_426, 1); +lean_inc(x_435); +x_436 = lean_ctor_get(x_426, 3); +lean_inc(x_436); +x_437 = lean_ctor_get(x_426, 4); +lean_inc(x_437); +if (lean_is_exclusive(x_426)) { + lean_ctor_release(x_426, 0); + lean_ctor_release(x_426, 1); + lean_ctor_release(x_426, 2); + lean_ctor_release(x_426, 3); + lean_ctor_release(x_426, 4); + x_438 = x_426; +} else { + lean_dec_ref(x_426); + x_438 = lean_box(0); +} +if (lean_is_scalar(x_438)) { + x_439 = lean_alloc_ctor(0, 5, 0); +} else { + x_439 = x_438; +} +lean_ctor_set(x_439, 0, x_434); +lean_ctor_set(x_439, 1, x_435); +lean_ctor_set(x_439, 2, x_404); +lean_ctor_set(x_439, 3, x_436); +lean_ctor_set(x_439, 4, x_437); +if (lean_is_scalar(x_433)) { + x_440 = lean_alloc_ctor(0, 6, 0); +} else { + x_440 = x_433; +} +lean_ctor_set(x_440, 0, x_428); +lean_ctor_set(x_440, 1, x_429); +lean_ctor_set(x_440, 2, x_439); +lean_ctor_set(x_440, 3, x_430); +lean_ctor_set(x_440, 4, x_431); +lean_ctor_set(x_440, 5, x_432); +if (lean_is_scalar(x_248)) { + x_441 = lean_alloc_ctor(0, 2, 0); +} else { + x_441 = x_248; +} +lean_ctor_set(x_441, 0, x_427); +lean_ctor_set(x_441, 1, x_440); +return x_441; } } } @@ -29121,29 +30041,29 @@ return x_421; } else { -uint8_t x_442; +uint8_t x_462; lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_442 = !lean_is_exclusive(x_231); -if (x_442 == 0) +x_462 = !lean_is_exclusive(x_241); +if (x_462 == 0) { -return x_231; +return x_241; } else { -lean_object* x_443; lean_object* x_444; lean_object* x_445; -x_443 = lean_ctor_get(x_231, 0); -x_444 = lean_ctor_get(x_231, 1); -lean_inc(x_444); -lean_inc(x_443); -lean_dec(x_231); -x_445 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_445, 0, x_443); -lean_ctor_set(x_445, 1, x_444); -return x_445; +lean_object* x_463; lean_object* x_464; lean_object* x_465; +x_463 = lean_ctor_get(x_241, 0); +x_464 = lean_ctor_get(x_241, 1); +lean_inc(x_464); +lean_inc(x_463); +lean_dec(x_241); +x_465 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_465, 0, x_463); +lean_ctor_set(x_465, 1, x_464); +return x_465; } } } @@ -29151,58 +30071,58 @@ return x_445; } else { -uint8_t x_446; +uint8_t x_466; lean_dec(x_18); lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_446 = !lean_is_exclusive(x_19); -if (x_446 == 0) +x_466 = !lean_is_exclusive(x_19); +if (x_466 == 0) { return x_19; } else { -lean_object* x_447; lean_object* x_448; lean_object* x_449; -x_447 = lean_ctor_get(x_19, 0); -x_448 = lean_ctor_get(x_19, 1); -lean_inc(x_448); -lean_inc(x_447); +lean_object* x_467; lean_object* x_468; lean_object* x_469; +x_467 = lean_ctor_get(x_19, 0); +x_468 = lean_ctor_get(x_19, 1); +lean_inc(x_468); +lean_inc(x_467); lean_dec(x_19); -x_449 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_449, 0, x_447); -lean_ctor_set(x_449, 1, x_448); -return x_449; +x_469 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_469, 0, x_467); +lean_ctor_set(x_469, 1, x_468); +return x_469; } } } else { -uint8_t x_450; +uint8_t x_470; lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_450 = !lean_is_exclusive(x_15); -if (x_450 == 0) +x_470 = !lean_is_exclusive(x_15); +if (x_470 == 0) { return x_15; } else { -lean_object* x_451; lean_object* x_452; lean_object* x_453; -x_451 = lean_ctor_get(x_15, 0); -x_452 = lean_ctor_get(x_15, 1); -lean_inc(x_452); -lean_inc(x_451); +lean_object* x_471; lean_object* x_472; lean_object* x_473; +x_471 = lean_ctor_get(x_15, 0); +x_472 = lean_ctor_get(x_15, 1); +lean_inc(x_472); +lean_inc(x_471); lean_dec(x_15); -x_453 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_453, 0, x_451); -lean_ctor_set(x_453, 1, x_452); -return x_453; +x_473 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_473, 0, x_471); +lean_ctor_set(x_473, 1, x_472); +return x_473; } } } @@ -29682,105 +30602,105 @@ x_31 = lean_ctor_get(x_25, 2); x_32 = !lean_is_exclusive(x_31); if (x_32 == 0) { -lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_85; uint8_t x_86; +lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_89; uint8_t x_90; x_33 = lean_ctor_get(x_31, 2); -x_85 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_31, 2, x_85); -x_86 = !lean_is_exclusive(x_7); -if (x_86 == 0) +x_89 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_31, 2, x_89); +x_90 = !lean_is_exclusive(x_7); +if (x_90 == 0) { -lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; -x_87 = lean_ctor_get(x_7, 2); -x_88 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_88, 0, x_27); -lean_ctor_set(x_88, 1, x_14); -x_89 = lean_array_push(x_87, x_88); -lean_ctor_set(x_7, 2, x_89); -x_90 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_7, x_25); -if (lean_obj_tag(x_90) == 0) +lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; +x_91 = lean_ctor_get(x_7, 2); +x_92 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_92, 0, x_27); +lean_ctor_set(x_92, 1, x_14); +x_93 = lean_array_push(x_91, x_92); +lean_ctor_set(x_7, 2, x_93); +x_94 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_7, x_25); +if (lean_obj_tag(x_94) == 0) { -lean_object* x_91; lean_object* x_92; lean_object* x_93; -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_alloc_ctor(1, 1, 0); -lean_ctor_set(x_93, 0, x_91); -x_34 = x_93; -x_35 = x_92; -goto block_84; -} -else -{ -lean_object* x_94; lean_object* x_95; lean_object* x_96; -x_94 = lean_ctor_get(x_90, 0); -lean_inc(x_94); -x_95 = lean_ctor_get(x_90, 1); +lean_object* x_95; lean_object* x_96; lean_object* x_97; +x_95 = lean_ctor_get(x_94, 0); lean_inc(x_95); -lean_dec(x_90); -x_96 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_96, 0, x_94); -x_34 = x_96; -x_35 = x_95; -goto block_84; -} +x_96 = lean_ctor_get(x_94, 1); +lean_inc(x_96); +lean_dec(x_94); +x_97 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_97, 0, x_95); +x_34 = x_97; +x_35 = x_96; +goto block_88; } else { -lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; -x_97 = lean_ctor_get(x_7, 0); -x_98 = lean_ctor_get(x_7, 1); -x_99 = lean_ctor_get(x_7, 2); -x_100 = lean_ctor_get(x_7, 3); -x_101 = lean_ctor_get(x_7, 4); -lean_inc(x_101); -lean_inc(x_100); -lean_inc(x_99); +lean_object* x_98; lean_object* x_99; lean_object* x_100; +x_98 = lean_ctor_get(x_94, 0); lean_inc(x_98); -lean_inc(x_97); -lean_dec(x_7); -x_102 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_102, 0, x_27); -lean_ctor_set(x_102, 1, x_14); -x_103 = lean_array_push(x_99, x_102); -x_104 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_104, 0, x_97); -lean_ctor_set(x_104, 1, x_98); -lean_ctor_set(x_104, 2, x_103); -lean_ctor_set(x_104, 3, x_100); -lean_ctor_set(x_104, 4, x_101); -x_105 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_104, x_25); -if (lean_obj_tag(x_105) == 0) -{ -lean_object* x_106; lean_object* x_107; lean_object* x_108; -x_106 = lean_ctor_get(x_105, 0); -lean_inc(x_106); -x_107 = lean_ctor_get(x_105, 1); -lean_inc(x_107); -lean_dec(x_105); -x_108 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_108, 0, x_106); -x_34 = x_108; -x_35 = x_107; -goto block_84; +x_99 = lean_ctor_get(x_94, 1); +lean_inc(x_99); +lean_dec(x_94); +x_100 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_100, 0, x_98); +x_34 = x_100; +x_35 = x_99; +goto block_88; +} } else { -lean_object* x_109; lean_object* x_110; lean_object* x_111; -x_109 = lean_ctor_get(x_105, 0); -lean_inc(x_109); -x_110 = lean_ctor_get(x_105, 1); +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; +x_101 = lean_ctor_get(x_7, 0); +x_102 = lean_ctor_get(x_7, 1); +x_103 = lean_ctor_get(x_7, 2); +x_104 = lean_ctor_get(x_7, 3); +x_105 = lean_ctor_get(x_7, 4); +lean_inc(x_105); +lean_inc(x_104); +lean_inc(x_103); +lean_inc(x_102); +lean_inc(x_101); +lean_dec(x_7); +x_106 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_106, 0, x_27); +lean_ctor_set(x_106, 1, x_14); +x_107 = lean_array_push(x_103, x_106); +x_108 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_108, 0, x_101); +lean_ctor_set(x_108, 1, x_102); +lean_ctor_set(x_108, 2, x_107); +lean_ctor_set(x_108, 3, x_104); +lean_ctor_set(x_108, 4, x_105); +x_109 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_108, x_25); +if (lean_obj_tag(x_109) == 0) +{ +lean_object* x_110; lean_object* x_111; lean_object* x_112; +x_110 = lean_ctor_get(x_109, 0); lean_inc(x_110); -lean_dec(x_105); -x_111 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_111, 0, x_109); -x_34 = x_111; -x_35 = x_110; -goto block_84; +x_111 = lean_ctor_get(x_109, 1); +lean_inc(x_111); +lean_dec(x_109); +x_112 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_112, 0, x_110); +x_34 = x_112; +x_35 = x_111; +goto block_88; +} +else +{ +lean_object* x_113; lean_object* x_114; lean_object* x_115; +x_113 = lean_ctor_get(x_109, 0); +lean_inc(x_113); +x_114 = lean_ctor_get(x_109, 1); +lean_inc(x_114); +lean_dec(x_109); +x_115 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_115, 0, x_113); +x_34 = x_115; +x_35 = x_114; +goto block_88; } } -block_84: +block_88: { if (lean_obj_tag(x_34) == 0) { @@ -29815,1284 +30735,1262 @@ return x_42; } else { -lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; +lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; x_43 = lean_ctor_get(x_36, 0); x_44 = lean_ctor_get(x_36, 1); x_45 = lean_ctor_get(x_36, 3); +x_46 = lean_ctor_get(x_36, 4); +lean_inc(x_46); lean_inc(x_45); lean_inc(x_44); lean_inc(x_43); lean_dec(x_36); -x_46 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_46, 0, x_43); -lean_ctor_set(x_46, 1, x_44); -lean_ctor_set(x_46, 2, x_33); -lean_ctor_set(x_46, 3, x_45); -lean_ctor_set(x_35, 2, x_46); +x_47 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_47, 0, x_43); +lean_ctor_set(x_47, 1, x_44); +lean_ctor_set(x_47, 2, x_33); +lean_ctor_set(x_47, 3, x_45); +lean_ctor_set(x_47, 4, x_46); +lean_ctor_set(x_35, 2, x_47); if (lean_is_scalar(x_26)) { - x_47 = lean_alloc_ctor(1, 2, 0); + x_48 = lean_alloc_ctor(1, 2, 0); } else { - x_47 = x_26; - lean_ctor_set_tag(x_47, 1); + x_48 = x_26; + lean_ctor_set_tag(x_48, 1); } -lean_ctor_set(x_47, 0, x_37); -lean_ctor_set(x_47, 1, x_35); -return x_47; +lean_ctor_set(x_48, 0, x_37); +lean_ctor_set(x_48, 1, x_35); +return x_48; } } else { -lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; -x_48 = lean_ctor_get(x_35, 0); -x_49 = lean_ctor_get(x_35, 1); -x_50 = lean_ctor_get(x_35, 3); -x_51 = lean_ctor_get(x_35, 4); -x_52 = lean_ctor_get(x_35, 5); +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; +x_49 = lean_ctor_get(x_35, 0); +x_50 = lean_ctor_get(x_35, 1); +x_51 = lean_ctor_get(x_35, 3); +x_52 = lean_ctor_get(x_35, 4); +x_53 = lean_ctor_get(x_35, 5); +lean_inc(x_53); lean_inc(x_52); lean_inc(x_51); lean_inc(x_50); lean_inc(x_49); -lean_inc(x_48); lean_dec(x_35); -x_53 = lean_ctor_get(x_36, 0); -lean_inc(x_53); -x_54 = lean_ctor_get(x_36, 1); +x_54 = lean_ctor_get(x_36, 0); lean_inc(x_54); -x_55 = lean_ctor_get(x_36, 3); +x_55 = lean_ctor_get(x_36, 1); lean_inc(x_55); +x_56 = lean_ctor_get(x_36, 3); +lean_inc(x_56); +x_57 = lean_ctor_get(x_36, 4); +lean_inc(x_57); if (lean_is_exclusive(x_36)) { lean_ctor_release(x_36, 0); lean_ctor_release(x_36, 1); lean_ctor_release(x_36, 2); lean_ctor_release(x_36, 3); - x_56 = x_36; + lean_ctor_release(x_36, 4); + x_58 = x_36; } else { lean_dec_ref(x_36); - x_56 = lean_box(0); + x_58 = lean_box(0); } -if (lean_is_scalar(x_56)) { - x_57 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_58)) { + x_59 = lean_alloc_ctor(0, 5, 0); } else { - x_57 = x_56; + x_59 = x_58; } -lean_ctor_set(x_57, 0, x_53); -lean_ctor_set(x_57, 1, x_54); -lean_ctor_set(x_57, 2, x_33); -lean_ctor_set(x_57, 3, x_55); -x_58 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_58, 0, x_48); -lean_ctor_set(x_58, 1, x_49); -lean_ctor_set(x_58, 2, x_57); -lean_ctor_set(x_58, 3, x_50); -lean_ctor_set(x_58, 4, x_51); -lean_ctor_set(x_58, 5, x_52); +lean_ctor_set(x_59, 0, x_54); +lean_ctor_set(x_59, 1, x_55); +lean_ctor_set(x_59, 2, x_33); +lean_ctor_set(x_59, 3, x_56); +lean_ctor_set(x_59, 4, x_57); +x_60 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_60, 0, x_49); +lean_ctor_set(x_60, 1, x_50); +lean_ctor_set(x_60, 2, x_59); +lean_ctor_set(x_60, 3, x_51); +lean_ctor_set(x_60, 4, x_52); +lean_ctor_set(x_60, 5, x_53); if (lean_is_scalar(x_26)) { - x_59 = lean_alloc_ctor(1, 2, 0); + x_61 = lean_alloc_ctor(1, 2, 0); } else { - x_59 = x_26; - lean_ctor_set_tag(x_59, 1); + x_61 = x_26; + lean_ctor_set_tag(x_61, 1); } -lean_ctor_set(x_59, 0, x_37); -lean_ctor_set(x_59, 1, x_58); -return x_59; +lean_ctor_set(x_61, 0, x_37); +lean_ctor_set(x_61, 1, x_60); +return x_61; } } else { -lean_object* x_60; lean_object* x_61; uint8_t x_62; -x_60 = lean_ctor_get(x_35, 2); -lean_inc(x_60); -x_61 = lean_ctor_get(x_34, 0); -lean_inc(x_61); +lean_object* x_62; lean_object* x_63; uint8_t x_64; +x_62 = lean_ctor_get(x_35, 2); +lean_inc(x_62); +x_63 = lean_ctor_get(x_34, 0); +lean_inc(x_63); lean_dec(x_34); -x_62 = !lean_is_exclusive(x_35); -if (x_62 == 0) -{ -lean_object* x_63; uint8_t x_64; -x_63 = lean_ctor_get(x_35, 2); -lean_dec(x_63); -x_64 = !lean_is_exclusive(x_60); +x_64 = !lean_is_exclusive(x_35); if (x_64 == 0) { -lean_object* x_65; lean_object* x_66; -x_65 = lean_ctor_get(x_60, 2); +lean_object* x_65; uint8_t x_66; +x_65 = lean_ctor_get(x_35, 2); lean_dec(x_65); -lean_ctor_set(x_60, 2, x_33); +x_66 = !lean_is_exclusive(x_62); +if (x_66 == 0) +{ +lean_object* x_67; lean_object* x_68; +x_67 = lean_ctor_get(x_62, 2); +lean_dec(x_67); +lean_ctor_set(x_62, 2, x_33); if (lean_is_scalar(x_26)) { - x_66 = lean_alloc_ctor(0, 2, 0); + x_68 = lean_alloc_ctor(0, 2, 0); } else { - x_66 = x_26; + x_68 = x_26; } -lean_ctor_set(x_66, 0, x_61); -lean_ctor_set(x_66, 1, x_35); -return x_66; +lean_ctor_set(x_68, 0, x_63); +lean_ctor_set(x_68, 1, x_35); +return x_68; } else { -lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; -x_67 = lean_ctor_get(x_60, 0); -x_68 = lean_ctor_get(x_60, 1); -x_69 = lean_ctor_get(x_60, 3); +lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; +x_69 = lean_ctor_get(x_62, 0); +x_70 = lean_ctor_get(x_62, 1); +x_71 = lean_ctor_get(x_62, 3); +x_72 = lean_ctor_get(x_62, 4); +lean_inc(x_72); +lean_inc(x_71); +lean_inc(x_70); lean_inc(x_69); -lean_inc(x_68); -lean_inc(x_67); -lean_dec(x_60); -x_70 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_70, 0, x_67); -lean_ctor_set(x_70, 1, x_68); -lean_ctor_set(x_70, 2, x_33); -lean_ctor_set(x_70, 3, x_69); -lean_ctor_set(x_35, 2, x_70); +lean_dec(x_62); +x_73 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_73, 0, x_69); +lean_ctor_set(x_73, 1, x_70); +lean_ctor_set(x_73, 2, x_33); +lean_ctor_set(x_73, 3, x_71); +lean_ctor_set(x_73, 4, x_72); +lean_ctor_set(x_35, 2, x_73); if (lean_is_scalar(x_26)) { - x_71 = lean_alloc_ctor(0, 2, 0); + x_74 = lean_alloc_ctor(0, 2, 0); } else { - x_71 = x_26; + x_74 = x_26; } -lean_ctor_set(x_71, 0, x_61); -lean_ctor_set(x_71, 1, x_35); -return x_71; +lean_ctor_set(x_74, 0, x_63); +lean_ctor_set(x_74, 1, x_35); +return x_74; } } else { -lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; -x_72 = lean_ctor_get(x_35, 0); -x_73 = lean_ctor_get(x_35, 1); -x_74 = lean_ctor_get(x_35, 3); -x_75 = lean_ctor_get(x_35, 4); -x_76 = lean_ctor_get(x_35, 5); +lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; +x_75 = lean_ctor_get(x_35, 0); +x_76 = lean_ctor_get(x_35, 1); +x_77 = lean_ctor_get(x_35, 3); +x_78 = lean_ctor_get(x_35, 4); +x_79 = lean_ctor_get(x_35, 5); +lean_inc(x_79); +lean_inc(x_78); +lean_inc(x_77); lean_inc(x_76); lean_inc(x_75); -lean_inc(x_74); -lean_inc(x_73); -lean_inc(x_72); lean_dec(x_35); -x_77 = lean_ctor_get(x_60, 0); -lean_inc(x_77); -x_78 = lean_ctor_get(x_60, 1); -lean_inc(x_78); -x_79 = lean_ctor_get(x_60, 3); -lean_inc(x_79); -if (lean_is_exclusive(x_60)) { - lean_ctor_release(x_60, 0); - lean_ctor_release(x_60, 1); - lean_ctor_release(x_60, 2); - lean_ctor_release(x_60, 3); - x_80 = x_60; +x_80 = lean_ctor_get(x_62, 0); +lean_inc(x_80); +x_81 = lean_ctor_get(x_62, 1); +lean_inc(x_81); +x_82 = lean_ctor_get(x_62, 3); +lean_inc(x_82); +x_83 = lean_ctor_get(x_62, 4); +lean_inc(x_83); +if (lean_is_exclusive(x_62)) { + lean_ctor_release(x_62, 0); + lean_ctor_release(x_62, 1); + lean_ctor_release(x_62, 2); + lean_ctor_release(x_62, 3); + lean_ctor_release(x_62, 4); + x_84 = x_62; } else { - lean_dec_ref(x_60); - x_80 = lean_box(0); + lean_dec_ref(x_62); + x_84 = lean_box(0); } -if (lean_is_scalar(x_80)) { - x_81 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_84)) { + x_85 = lean_alloc_ctor(0, 5, 0); } else { - x_81 = x_80; + x_85 = x_84; } -lean_ctor_set(x_81, 0, x_77); -lean_ctor_set(x_81, 1, x_78); -lean_ctor_set(x_81, 2, x_33); -lean_ctor_set(x_81, 3, x_79); -x_82 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_82, 0, x_72); -lean_ctor_set(x_82, 1, x_73); -lean_ctor_set(x_82, 2, x_81); -lean_ctor_set(x_82, 3, x_74); -lean_ctor_set(x_82, 4, x_75); -lean_ctor_set(x_82, 5, x_76); +lean_ctor_set(x_85, 0, x_80); +lean_ctor_set(x_85, 1, x_81); +lean_ctor_set(x_85, 2, x_33); +lean_ctor_set(x_85, 3, x_82); +lean_ctor_set(x_85, 4, x_83); +x_86 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_86, 0, x_75); +lean_ctor_set(x_86, 1, x_76); +lean_ctor_set(x_86, 2, x_85); +lean_ctor_set(x_86, 3, x_77); +lean_ctor_set(x_86, 4, x_78); +lean_ctor_set(x_86, 5, x_79); if (lean_is_scalar(x_26)) { - x_83 = lean_alloc_ctor(0, 2, 0); + x_87 = lean_alloc_ctor(0, 2, 0); } else { - x_83 = x_26; + x_87 = x_26; } -lean_ctor_set(x_83, 0, x_61); -lean_ctor_set(x_83, 1, x_82); -return x_83; +lean_ctor_set(x_87, 0, x_63); +lean_ctor_set(x_87, 1, x_86); +return x_87; } } } } else { -lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_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; -x_112 = lean_ctor_get(x_31, 0); -x_113 = lean_ctor_get(x_31, 1); -x_114 = lean_ctor_get(x_31, 2); -x_115 = lean_ctor_get(x_31, 3); -lean_inc(x_115); -lean_inc(x_114); -lean_inc(x_113); -lean_inc(x_112); -lean_dec(x_31); -x_149 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_150 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_150, 0, x_112); -lean_ctor_set(x_150, 1, x_113); -lean_ctor_set(x_150, 2, x_149); -lean_ctor_set(x_150, 3, x_115); -lean_ctor_set(x_25, 2, x_150); -x_151 = lean_ctor_get(x_7, 0); -lean_inc(x_151); -x_152 = lean_ctor_get(x_7, 1); -lean_inc(x_152); -x_153 = lean_ctor_get(x_7, 2); -lean_inc(x_153); -x_154 = lean_ctor_get(x_7, 3); -lean_inc(x_154); -x_155 = lean_ctor_get(x_7, 4); -lean_inc(x_155); -if (lean_is_exclusive(x_7)) { - lean_ctor_release(x_7, 0); - lean_ctor_release(x_7, 1); - lean_ctor_release(x_7, 2); - lean_ctor_release(x_7, 3); - lean_ctor_release(x_7, 4); - x_156 = x_7; -} else { - lean_dec_ref(x_7); - x_156 = lean_box(0); -} -x_157 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_157, 0, x_27); -lean_ctor_set(x_157, 1, x_14); -x_158 = lean_array_push(x_153, x_157); -if (lean_is_scalar(x_156)) { - x_159 = lean_alloc_ctor(0, 5, 0); -} else { - x_159 = x_156; -} -lean_ctor_set(x_159, 0, x_151); -lean_ctor_set(x_159, 1, x_152); -lean_ctor_set(x_159, 2, x_158); -lean_ctor_set(x_159, 3, x_154); -lean_ctor_set(x_159, 4, x_155); -x_160 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_159, x_25); -if (lean_obj_tag(x_160) == 0) -{ -lean_object* x_161; lean_object* x_162; lean_object* x_163; -x_161 = lean_ctor_get(x_160, 0); -lean_inc(x_161); -x_162 = lean_ctor_get(x_160, 1); -lean_inc(x_162); -lean_dec(x_160); -x_163 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_163, 0, x_161); -x_116 = x_163; -x_117 = x_162; -goto block_148; -} -else -{ -lean_object* x_164; lean_object* x_165; lean_object* x_166; -x_164 = lean_ctor_get(x_160, 0); -lean_inc(x_164); -x_165 = lean_ctor_get(x_160, 1); -lean_inc(x_165); -lean_dec(x_160); -x_166 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_166, 0, x_164); -x_116 = x_166; -x_117 = x_165; -goto block_148; -} -block_148: -{ -if (lean_obj_tag(x_116) == 0) -{ -lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; -x_118 = lean_ctor_get(x_117, 2); -lean_inc(x_118); -x_119 = lean_ctor_get(x_116, 0); -lean_inc(x_119); -lean_dec(x_116); -x_120 = lean_ctor_get(x_117, 0); +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_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; +x_116 = lean_ctor_get(x_31, 0); +x_117 = lean_ctor_get(x_31, 1); +x_118 = lean_ctor_get(x_31, 2); +x_119 = lean_ctor_get(x_31, 3); +x_120 = lean_ctor_get(x_31, 4); lean_inc(x_120); -x_121 = lean_ctor_get(x_117, 1); -lean_inc(x_121); -x_122 = lean_ctor_get(x_117, 3); -lean_inc(x_122); -x_123 = lean_ctor_get(x_117, 4); -lean_inc(x_123); -x_124 = lean_ctor_get(x_117, 5); -lean_inc(x_124); -if (lean_is_exclusive(x_117)) { - lean_ctor_release(x_117, 0); - lean_ctor_release(x_117, 1); - lean_ctor_release(x_117, 2); - lean_ctor_release(x_117, 3); - lean_ctor_release(x_117, 4); - lean_ctor_release(x_117, 5); - x_125 = x_117; -} else { - lean_dec_ref(x_117); - x_125 = lean_box(0); -} -x_126 = lean_ctor_get(x_118, 0); -lean_inc(x_126); -x_127 = lean_ctor_get(x_118, 1); -lean_inc(x_127); -x_128 = lean_ctor_get(x_118, 3); -lean_inc(x_128); -if (lean_is_exclusive(x_118)) { - lean_ctor_release(x_118, 0); - lean_ctor_release(x_118, 1); - lean_ctor_release(x_118, 2); - lean_ctor_release(x_118, 3); - x_129 = x_118; -} else { - lean_dec_ref(x_118); - x_129 = lean_box(0); -} -if (lean_is_scalar(x_129)) { - x_130 = lean_alloc_ctor(0, 4, 0); -} else { - x_130 = x_129; -} -lean_ctor_set(x_130, 0, x_126); -lean_ctor_set(x_130, 1, x_127); -lean_ctor_set(x_130, 2, x_114); -lean_ctor_set(x_130, 3, x_128); -if (lean_is_scalar(x_125)) { - x_131 = lean_alloc_ctor(0, 6, 0); -} else { - x_131 = x_125; -} -lean_ctor_set(x_131, 0, x_120); -lean_ctor_set(x_131, 1, x_121); -lean_ctor_set(x_131, 2, x_130); -lean_ctor_set(x_131, 3, x_122); -lean_ctor_set(x_131, 4, x_123); -lean_ctor_set(x_131, 5, x_124); -if (lean_is_scalar(x_26)) { - x_132 = lean_alloc_ctor(1, 2, 0); -} else { - x_132 = x_26; - lean_ctor_set_tag(x_132, 1); -} -lean_ctor_set(x_132, 0, x_119); -lean_ctor_set(x_132, 1, x_131); -return x_132; -} -else -{ -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; -x_133 = lean_ctor_get(x_117, 2); -lean_inc(x_133); -x_134 = lean_ctor_get(x_116, 0); -lean_inc(x_134); -lean_dec(x_116); -x_135 = lean_ctor_get(x_117, 0); -lean_inc(x_135); -x_136 = lean_ctor_get(x_117, 1); -lean_inc(x_136); -x_137 = lean_ctor_get(x_117, 3); -lean_inc(x_137); -x_138 = lean_ctor_get(x_117, 4); -lean_inc(x_138); -x_139 = lean_ctor_get(x_117, 5); -lean_inc(x_139); -if (lean_is_exclusive(x_117)) { - lean_ctor_release(x_117, 0); - lean_ctor_release(x_117, 1); - lean_ctor_release(x_117, 2); - lean_ctor_release(x_117, 3); - lean_ctor_release(x_117, 4); - lean_ctor_release(x_117, 5); - x_140 = x_117; -} else { - lean_dec_ref(x_117); - x_140 = lean_box(0); -} -x_141 = lean_ctor_get(x_133, 0); -lean_inc(x_141); -x_142 = lean_ctor_get(x_133, 1); -lean_inc(x_142); -x_143 = lean_ctor_get(x_133, 3); -lean_inc(x_143); -if (lean_is_exclusive(x_133)) { - lean_ctor_release(x_133, 0); - lean_ctor_release(x_133, 1); - lean_ctor_release(x_133, 2); - lean_ctor_release(x_133, 3); - x_144 = x_133; -} else { - lean_dec_ref(x_133); - x_144 = lean_box(0); -} -if (lean_is_scalar(x_144)) { - x_145 = lean_alloc_ctor(0, 4, 0); -} else { - x_145 = x_144; -} -lean_ctor_set(x_145, 0, x_141); -lean_ctor_set(x_145, 1, x_142); -lean_ctor_set(x_145, 2, x_114); -lean_ctor_set(x_145, 3, x_143); -if (lean_is_scalar(x_140)) { - x_146 = lean_alloc_ctor(0, 6, 0); -} else { - x_146 = x_140; -} -lean_ctor_set(x_146, 0, x_135); -lean_ctor_set(x_146, 1, x_136); -lean_ctor_set(x_146, 2, x_145); -lean_ctor_set(x_146, 3, x_137); -lean_ctor_set(x_146, 4, x_138); -lean_ctor_set(x_146, 5, x_139); -if (lean_is_scalar(x_26)) { - x_147 = lean_alloc_ctor(0, 2, 0); -} else { - x_147 = x_26; -} -lean_ctor_set(x_147, 0, x_134); -lean_ctor_set(x_147, 1, x_146); -return x_147; -} -} -} -} -else -{ -lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; 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; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; -x_167 = lean_ctor_get(x_25, 2); -x_168 = lean_ctor_get(x_25, 0); -x_169 = lean_ctor_get(x_25, 1); -x_170 = lean_ctor_get(x_25, 3); -x_171 = lean_ctor_get(x_25, 4); -x_172 = lean_ctor_get(x_25, 5); -lean_inc(x_172); -lean_inc(x_171); -lean_inc(x_170); -lean_inc(x_167); -lean_inc(x_169); -lean_inc(x_168); -lean_dec(x_25); -x_173 = lean_ctor_get(x_167, 0); -lean_inc(x_173); -x_174 = lean_ctor_get(x_167, 1); -lean_inc(x_174); -x_175 = lean_ctor_get(x_167, 2); -lean_inc(x_175); -x_176 = lean_ctor_get(x_167, 3); -lean_inc(x_176); -if (lean_is_exclusive(x_167)) { - lean_ctor_release(x_167, 0); - lean_ctor_release(x_167, 1); - lean_ctor_release(x_167, 2); - lean_ctor_release(x_167, 3); - x_177 = x_167; -} else { - lean_dec_ref(x_167); - x_177 = lean_box(0); -} -x_211 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_177)) { - x_212 = lean_alloc_ctor(0, 4, 0); -} else { - x_212 = x_177; -} -lean_ctor_set(x_212, 0, x_173); -lean_ctor_set(x_212, 1, x_174); -lean_ctor_set(x_212, 2, x_211); -lean_ctor_set(x_212, 3, x_176); -x_213 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_213, 0, x_168); -lean_ctor_set(x_213, 1, x_169); -lean_ctor_set(x_213, 2, x_212); -lean_ctor_set(x_213, 3, x_170); -lean_ctor_set(x_213, 4, x_171); -lean_ctor_set(x_213, 5, x_172); -x_214 = lean_ctor_get(x_7, 0); -lean_inc(x_214); -x_215 = lean_ctor_get(x_7, 1); -lean_inc(x_215); -x_216 = lean_ctor_get(x_7, 2); -lean_inc(x_216); -x_217 = lean_ctor_get(x_7, 3); -lean_inc(x_217); -x_218 = lean_ctor_get(x_7, 4); -lean_inc(x_218); +lean_inc(x_119); +lean_inc(x_118); +lean_inc(x_117); +lean_inc(x_116); +lean_dec(x_31); +x_156 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_157 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_157, 0, x_116); +lean_ctor_set(x_157, 1, x_117); +lean_ctor_set(x_157, 2, x_156); +lean_ctor_set(x_157, 3, x_119); +lean_ctor_set(x_157, 4, x_120); +lean_ctor_set(x_25, 2, x_157); +x_158 = lean_ctor_get(x_7, 0); +lean_inc(x_158); +x_159 = lean_ctor_get(x_7, 1); +lean_inc(x_159); +x_160 = lean_ctor_get(x_7, 2); +lean_inc(x_160); +x_161 = lean_ctor_get(x_7, 3); +lean_inc(x_161); +x_162 = lean_ctor_get(x_7, 4); +lean_inc(x_162); if (lean_is_exclusive(x_7)) { lean_ctor_release(x_7, 0); lean_ctor_release(x_7, 1); lean_ctor_release(x_7, 2); lean_ctor_release(x_7, 3); lean_ctor_release(x_7, 4); - x_219 = x_7; + x_163 = x_7; } else { lean_dec_ref(x_7); - x_219 = lean_box(0); + x_163 = lean_box(0); } -x_220 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_220, 0, x_27); -lean_ctor_set(x_220, 1, x_14); -x_221 = lean_array_push(x_216, x_220); -if (lean_is_scalar(x_219)) { +x_164 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_164, 0, x_27); +lean_ctor_set(x_164, 1, x_14); +x_165 = lean_array_push(x_160, x_164); +if (lean_is_scalar(x_163)) { + x_166 = lean_alloc_ctor(0, 5, 0); +} else { + x_166 = x_163; +} +lean_ctor_set(x_166, 0, x_158); +lean_ctor_set(x_166, 1, x_159); +lean_ctor_set(x_166, 2, x_165); +lean_ctor_set(x_166, 3, x_161); +lean_ctor_set(x_166, 4, x_162); +x_167 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_166, x_25); +if (lean_obj_tag(x_167) == 0) +{ +lean_object* x_168; lean_object* x_169; lean_object* x_170; +x_168 = lean_ctor_get(x_167, 0); +lean_inc(x_168); +x_169 = lean_ctor_get(x_167, 1); +lean_inc(x_169); +lean_dec(x_167); +x_170 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_170, 0, x_168); +x_121 = x_170; +x_122 = x_169; +goto block_155; +} +else +{ +lean_object* x_171; lean_object* x_172; lean_object* x_173; +x_171 = lean_ctor_get(x_167, 0); +lean_inc(x_171); +x_172 = lean_ctor_get(x_167, 1); +lean_inc(x_172); +lean_dec(x_167); +x_173 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_173, 0, x_171); +x_121 = x_173; +x_122 = x_172; +goto block_155; +} +block_155: +{ +if (lean_obj_tag(x_121) == 0) +{ +lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; +x_123 = lean_ctor_get(x_122, 2); +lean_inc(x_123); +x_124 = lean_ctor_get(x_121, 0); +lean_inc(x_124); +lean_dec(x_121); +x_125 = lean_ctor_get(x_122, 0); +lean_inc(x_125); +x_126 = lean_ctor_get(x_122, 1); +lean_inc(x_126); +x_127 = lean_ctor_get(x_122, 3); +lean_inc(x_127); +x_128 = lean_ctor_get(x_122, 4); +lean_inc(x_128); +x_129 = lean_ctor_get(x_122, 5); +lean_inc(x_129); +if (lean_is_exclusive(x_122)) { + lean_ctor_release(x_122, 0); + lean_ctor_release(x_122, 1); + lean_ctor_release(x_122, 2); + lean_ctor_release(x_122, 3); + lean_ctor_release(x_122, 4); + lean_ctor_release(x_122, 5); + x_130 = x_122; +} else { + lean_dec_ref(x_122); + x_130 = lean_box(0); +} +x_131 = lean_ctor_get(x_123, 0); +lean_inc(x_131); +x_132 = lean_ctor_get(x_123, 1); +lean_inc(x_132); +x_133 = lean_ctor_get(x_123, 3); +lean_inc(x_133); +x_134 = lean_ctor_get(x_123, 4); +lean_inc(x_134); +if (lean_is_exclusive(x_123)) { + lean_ctor_release(x_123, 0); + lean_ctor_release(x_123, 1); + lean_ctor_release(x_123, 2); + lean_ctor_release(x_123, 3); + lean_ctor_release(x_123, 4); + x_135 = x_123; +} else { + lean_dec_ref(x_123); + x_135 = lean_box(0); +} +if (lean_is_scalar(x_135)) { + x_136 = lean_alloc_ctor(0, 5, 0); +} else { + x_136 = x_135; +} +lean_ctor_set(x_136, 0, x_131); +lean_ctor_set(x_136, 1, x_132); +lean_ctor_set(x_136, 2, x_118); +lean_ctor_set(x_136, 3, x_133); +lean_ctor_set(x_136, 4, x_134); +if (lean_is_scalar(x_130)) { + x_137 = lean_alloc_ctor(0, 6, 0); +} else { + x_137 = x_130; +} +lean_ctor_set(x_137, 0, x_125); +lean_ctor_set(x_137, 1, x_126); +lean_ctor_set(x_137, 2, x_136); +lean_ctor_set(x_137, 3, x_127); +lean_ctor_set(x_137, 4, x_128); +lean_ctor_set(x_137, 5, x_129); +if (lean_is_scalar(x_26)) { + x_138 = lean_alloc_ctor(1, 2, 0); +} else { + x_138 = x_26; + lean_ctor_set_tag(x_138, 1); +} +lean_ctor_set(x_138, 0, x_124); +lean_ctor_set(x_138, 1, x_137); +return x_138; +} +else +{ +lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_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; +x_139 = lean_ctor_get(x_122, 2); +lean_inc(x_139); +x_140 = lean_ctor_get(x_121, 0); +lean_inc(x_140); +lean_dec(x_121); +x_141 = lean_ctor_get(x_122, 0); +lean_inc(x_141); +x_142 = lean_ctor_get(x_122, 1); +lean_inc(x_142); +x_143 = lean_ctor_get(x_122, 3); +lean_inc(x_143); +x_144 = lean_ctor_get(x_122, 4); +lean_inc(x_144); +x_145 = lean_ctor_get(x_122, 5); +lean_inc(x_145); +if (lean_is_exclusive(x_122)) { + lean_ctor_release(x_122, 0); + lean_ctor_release(x_122, 1); + lean_ctor_release(x_122, 2); + lean_ctor_release(x_122, 3); + lean_ctor_release(x_122, 4); + lean_ctor_release(x_122, 5); + x_146 = x_122; +} else { + lean_dec_ref(x_122); + x_146 = lean_box(0); +} +x_147 = lean_ctor_get(x_139, 0); +lean_inc(x_147); +x_148 = lean_ctor_get(x_139, 1); +lean_inc(x_148); +x_149 = lean_ctor_get(x_139, 3); +lean_inc(x_149); +x_150 = lean_ctor_get(x_139, 4); +lean_inc(x_150); +if (lean_is_exclusive(x_139)) { + lean_ctor_release(x_139, 0); + lean_ctor_release(x_139, 1); + lean_ctor_release(x_139, 2); + lean_ctor_release(x_139, 3); + lean_ctor_release(x_139, 4); + x_151 = x_139; +} else { + lean_dec_ref(x_139); + x_151 = lean_box(0); +} +if (lean_is_scalar(x_151)) { + x_152 = lean_alloc_ctor(0, 5, 0); +} else { + x_152 = x_151; +} +lean_ctor_set(x_152, 0, x_147); +lean_ctor_set(x_152, 1, x_148); +lean_ctor_set(x_152, 2, x_118); +lean_ctor_set(x_152, 3, x_149); +lean_ctor_set(x_152, 4, x_150); +if (lean_is_scalar(x_146)) { + x_153 = lean_alloc_ctor(0, 6, 0); +} else { + x_153 = x_146; +} +lean_ctor_set(x_153, 0, x_141); +lean_ctor_set(x_153, 1, x_142); +lean_ctor_set(x_153, 2, x_152); +lean_ctor_set(x_153, 3, x_143); +lean_ctor_set(x_153, 4, x_144); +lean_ctor_set(x_153, 5, x_145); +if (lean_is_scalar(x_26)) { + x_154 = lean_alloc_ctor(0, 2, 0); +} else { + x_154 = x_26; +} +lean_ctor_set(x_154, 0, x_140); +lean_ctor_set(x_154, 1, x_153); +return x_154; +} +} +} +} +else +{ +lean_object* x_174; lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_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; lean_object* x_231; lean_object* x_232; lean_object* x_233; +x_174 = lean_ctor_get(x_25, 2); +x_175 = lean_ctor_get(x_25, 0); +x_176 = lean_ctor_get(x_25, 1); +x_177 = lean_ctor_get(x_25, 3); +x_178 = lean_ctor_get(x_25, 4); +x_179 = lean_ctor_get(x_25, 5); +lean_inc(x_179); +lean_inc(x_178); +lean_inc(x_177); +lean_inc(x_174); +lean_inc(x_176); +lean_inc(x_175); +lean_dec(x_25); +x_180 = lean_ctor_get(x_174, 0); +lean_inc(x_180); +x_181 = lean_ctor_get(x_174, 1); +lean_inc(x_181); +x_182 = lean_ctor_get(x_174, 2); +lean_inc(x_182); +x_183 = lean_ctor_get(x_174, 3); +lean_inc(x_183); +x_184 = lean_ctor_get(x_174, 4); +lean_inc(x_184); +if (lean_is_exclusive(x_174)) { + lean_ctor_release(x_174, 0); + lean_ctor_release(x_174, 1); + lean_ctor_release(x_174, 2); + lean_ctor_release(x_174, 3); + lean_ctor_release(x_174, 4); + x_185 = x_174; +} else { + lean_dec_ref(x_174); + x_185 = lean_box(0); +} +x_221 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_185)) { x_222 = lean_alloc_ctor(0, 5, 0); } else { - x_222 = x_219; + x_222 = x_185; } -lean_ctor_set(x_222, 0, x_214); -lean_ctor_set(x_222, 1, x_215); +lean_ctor_set(x_222, 0, x_180); +lean_ctor_set(x_222, 1, x_181); lean_ctor_set(x_222, 2, x_221); -lean_ctor_set(x_222, 3, x_217); -lean_ctor_set(x_222, 4, x_218); -x_223 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_222, x_213); -if (lean_obj_tag(x_223) == 0) -{ -lean_object* x_224; lean_object* x_225; lean_object* x_226; -x_224 = lean_ctor_get(x_223, 0); +lean_ctor_set(x_222, 3, x_183); +lean_ctor_set(x_222, 4, x_184); +x_223 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_223, 0, x_175); +lean_ctor_set(x_223, 1, x_176); +lean_ctor_set(x_223, 2, x_222); +lean_ctor_set(x_223, 3, x_177); +lean_ctor_set(x_223, 4, x_178); +lean_ctor_set(x_223, 5, x_179); +x_224 = lean_ctor_get(x_7, 0); lean_inc(x_224); -x_225 = lean_ctor_get(x_223, 1); +x_225 = lean_ctor_get(x_7, 1); lean_inc(x_225); -lean_dec(x_223); -x_226 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_226, 0, x_224); -x_178 = x_226; -x_179 = x_225; -goto block_210; -} -else -{ -lean_object* x_227; lean_object* x_228; lean_object* x_229; -x_227 = lean_ctor_get(x_223, 0); +x_226 = lean_ctor_get(x_7, 2); +lean_inc(x_226); +x_227 = lean_ctor_get(x_7, 3); lean_inc(x_227); -x_228 = lean_ctor_get(x_223, 1); +x_228 = lean_ctor_get(x_7, 4); lean_inc(x_228); -lean_dec(x_223); -x_229 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_229, 0, x_227); -x_178 = x_229; -x_179 = x_228; -goto block_210; +if (lean_is_exclusive(x_7)) { + lean_ctor_release(x_7, 0); + lean_ctor_release(x_7, 1); + lean_ctor_release(x_7, 2); + lean_ctor_release(x_7, 3); + lean_ctor_release(x_7, 4); + x_229 = x_7; +} else { + lean_dec_ref(x_7); + x_229 = lean_box(0); } -block_210: +x_230 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_230, 0, x_27); +lean_ctor_set(x_230, 1, x_14); +x_231 = lean_array_push(x_226, x_230); +if (lean_is_scalar(x_229)) { + x_232 = lean_alloc_ctor(0, 5, 0); +} else { + x_232 = x_229; +} +lean_ctor_set(x_232, 0, x_224); +lean_ctor_set(x_232, 1, x_225); +lean_ctor_set(x_232, 2, x_231); +lean_ctor_set(x_232, 3, x_227); +lean_ctor_set(x_232, 4, x_228); +x_233 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_232, x_223); +if (lean_obj_tag(x_233) == 0) { -if (lean_obj_tag(x_178) == 0) -{ -lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; -x_180 = lean_ctor_get(x_179, 2); -lean_inc(x_180); -x_181 = lean_ctor_get(x_178, 0); -lean_inc(x_181); -lean_dec(x_178); -x_182 = lean_ctor_get(x_179, 0); -lean_inc(x_182); -x_183 = lean_ctor_get(x_179, 1); -lean_inc(x_183); -x_184 = lean_ctor_get(x_179, 3); -lean_inc(x_184); -x_185 = lean_ctor_get(x_179, 4); -lean_inc(x_185); -x_186 = lean_ctor_get(x_179, 5); -lean_inc(x_186); -if (lean_is_exclusive(x_179)) { - lean_ctor_release(x_179, 0); - lean_ctor_release(x_179, 1); - lean_ctor_release(x_179, 2); - lean_ctor_release(x_179, 3); - lean_ctor_release(x_179, 4); - lean_ctor_release(x_179, 5); - x_187 = x_179; -} else { - lean_dec_ref(x_179); - x_187 = lean_box(0); -} -x_188 = lean_ctor_get(x_180, 0); -lean_inc(x_188); -x_189 = lean_ctor_get(x_180, 1); -lean_inc(x_189); -x_190 = lean_ctor_get(x_180, 3); -lean_inc(x_190); -if (lean_is_exclusive(x_180)) { - lean_ctor_release(x_180, 0); - lean_ctor_release(x_180, 1); - lean_ctor_release(x_180, 2); - lean_ctor_release(x_180, 3); - x_191 = x_180; -} else { - lean_dec_ref(x_180); - x_191 = lean_box(0); -} -if (lean_is_scalar(x_191)) { - x_192 = lean_alloc_ctor(0, 4, 0); -} else { - x_192 = x_191; -} -lean_ctor_set(x_192, 0, x_188); -lean_ctor_set(x_192, 1, x_189); -lean_ctor_set(x_192, 2, x_175); -lean_ctor_set(x_192, 3, x_190); -if (lean_is_scalar(x_187)) { - x_193 = lean_alloc_ctor(0, 6, 0); -} else { - x_193 = x_187; -} -lean_ctor_set(x_193, 0, x_182); -lean_ctor_set(x_193, 1, x_183); -lean_ctor_set(x_193, 2, x_192); -lean_ctor_set(x_193, 3, x_184); -lean_ctor_set(x_193, 4, x_185); -lean_ctor_set(x_193, 5, x_186); -if (lean_is_scalar(x_26)) { - x_194 = lean_alloc_ctor(1, 2, 0); -} else { - x_194 = x_26; - lean_ctor_set_tag(x_194, 1); -} -lean_ctor_set(x_194, 0, x_181); -lean_ctor_set(x_194, 1, x_193); -return x_194; +lean_object* x_234; lean_object* x_235; lean_object* x_236; +x_234 = lean_ctor_get(x_233, 0); +lean_inc(x_234); +x_235 = lean_ctor_get(x_233, 1); +lean_inc(x_235); +lean_dec(x_233); +x_236 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_236, 0, x_234); +x_186 = x_236; +x_187 = x_235; +goto block_220; } else { -lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; -x_195 = lean_ctor_get(x_179, 2); -lean_inc(x_195); -x_196 = lean_ctor_get(x_178, 0); +lean_object* x_237; lean_object* x_238; lean_object* x_239; +x_237 = lean_ctor_get(x_233, 0); +lean_inc(x_237); +x_238 = lean_ctor_get(x_233, 1); +lean_inc(x_238); +lean_dec(x_233); +x_239 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_239, 0, x_237); +x_186 = x_239; +x_187 = x_238; +goto block_220; +} +block_220: +{ +if (lean_obj_tag(x_186) == 0) +{ +lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; +x_188 = lean_ctor_get(x_187, 2); +lean_inc(x_188); +x_189 = lean_ctor_get(x_186, 0); +lean_inc(x_189); +lean_dec(x_186); +x_190 = lean_ctor_get(x_187, 0); +lean_inc(x_190); +x_191 = lean_ctor_get(x_187, 1); +lean_inc(x_191); +x_192 = lean_ctor_get(x_187, 3); +lean_inc(x_192); +x_193 = lean_ctor_get(x_187, 4); +lean_inc(x_193); +x_194 = lean_ctor_get(x_187, 5); +lean_inc(x_194); +if (lean_is_exclusive(x_187)) { + lean_ctor_release(x_187, 0); + lean_ctor_release(x_187, 1); + lean_ctor_release(x_187, 2); + lean_ctor_release(x_187, 3); + lean_ctor_release(x_187, 4); + lean_ctor_release(x_187, 5); + x_195 = x_187; +} else { + lean_dec_ref(x_187); + x_195 = lean_box(0); +} +x_196 = lean_ctor_get(x_188, 0); lean_inc(x_196); -lean_dec(x_178); -x_197 = lean_ctor_get(x_179, 0); +x_197 = lean_ctor_get(x_188, 1); lean_inc(x_197); -x_198 = lean_ctor_get(x_179, 1); +x_198 = lean_ctor_get(x_188, 3); lean_inc(x_198); -x_199 = lean_ctor_get(x_179, 3); +x_199 = lean_ctor_get(x_188, 4); lean_inc(x_199); -x_200 = lean_ctor_get(x_179, 4); -lean_inc(x_200); -x_201 = lean_ctor_get(x_179, 5); -lean_inc(x_201); -if (lean_is_exclusive(x_179)) { - lean_ctor_release(x_179, 0); - lean_ctor_release(x_179, 1); - lean_ctor_release(x_179, 2); - lean_ctor_release(x_179, 3); - lean_ctor_release(x_179, 4); - lean_ctor_release(x_179, 5); - x_202 = x_179; +if (lean_is_exclusive(x_188)) { + lean_ctor_release(x_188, 0); + lean_ctor_release(x_188, 1); + lean_ctor_release(x_188, 2); + lean_ctor_release(x_188, 3); + lean_ctor_release(x_188, 4); + x_200 = x_188; } else { - lean_dec_ref(x_179); - x_202 = lean_box(0); + lean_dec_ref(x_188); + x_200 = lean_box(0); } -x_203 = lean_ctor_get(x_195, 0); -lean_inc(x_203); -x_204 = lean_ctor_get(x_195, 1); -lean_inc(x_204); -x_205 = lean_ctor_get(x_195, 3); -lean_inc(x_205); -if (lean_is_exclusive(x_195)) { - lean_ctor_release(x_195, 0); - lean_ctor_release(x_195, 1); - lean_ctor_release(x_195, 2); - lean_ctor_release(x_195, 3); - x_206 = x_195; +if (lean_is_scalar(x_200)) { + x_201 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_195); - x_206 = lean_box(0); + x_201 = x_200; } -if (lean_is_scalar(x_206)) { - x_207 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_201, 0, x_196); +lean_ctor_set(x_201, 1, x_197); +lean_ctor_set(x_201, 2, x_182); +lean_ctor_set(x_201, 3, x_198); +lean_ctor_set(x_201, 4, x_199); +if (lean_is_scalar(x_195)) { + x_202 = lean_alloc_ctor(0, 6, 0); } else { - x_207 = x_206; + x_202 = x_195; } -lean_ctor_set(x_207, 0, x_203); -lean_ctor_set(x_207, 1, x_204); -lean_ctor_set(x_207, 2, x_175); -lean_ctor_set(x_207, 3, x_205); -if (lean_is_scalar(x_202)) { - x_208 = lean_alloc_ctor(0, 6, 0); -} else { - x_208 = x_202; -} -lean_ctor_set(x_208, 0, x_197); -lean_ctor_set(x_208, 1, x_198); -lean_ctor_set(x_208, 2, x_207); -lean_ctor_set(x_208, 3, x_199); -lean_ctor_set(x_208, 4, x_200); -lean_ctor_set(x_208, 5, x_201); +lean_ctor_set(x_202, 0, x_190); +lean_ctor_set(x_202, 1, x_191); +lean_ctor_set(x_202, 2, x_201); +lean_ctor_set(x_202, 3, x_192); +lean_ctor_set(x_202, 4, x_193); +lean_ctor_set(x_202, 5, x_194); if (lean_is_scalar(x_26)) { - x_209 = lean_alloc_ctor(0, 2, 0); + x_203 = lean_alloc_ctor(1, 2, 0); } else { - x_209 = x_26; + x_203 = x_26; + lean_ctor_set_tag(x_203, 1); } -lean_ctor_set(x_209, 0, x_196); -lean_ctor_set(x_209, 1, x_208); -return x_209; +lean_ctor_set(x_203, 0, x_189); +lean_ctor_set(x_203, 1, x_202); +return x_203; +} +else +{ +lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; +x_204 = lean_ctor_get(x_187, 2); +lean_inc(x_204); +x_205 = lean_ctor_get(x_186, 0); +lean_inc(x_205); +lean_dec(x_186); +x_206 = lean_ctor_get(x_187, 0); +lean_inc(x_206); +x_207 = lean_ctor_get(x_187, 1); +lean_inc(x_207); +x_208 = lean_ctor_get(x_187, 3); +lean_inc(x_208); +x_209 = lean_ctor_get(x_187, 4); +lean_inc(x_209); +x_210 = lean_ctor_get(x_187, 5); +lean_inc(x_210); +if (lean_is_exclusive(x_187)) { + lean_ctor_release(x_187, 0); + lean_ctor_release(x_187, 1); + lean_ctor_release(x_187, 2); + lean_ctor_release(x_187, 3); + lean_ctor_release(x_187, 4); + lean_ctor_release(x_187, 5); + x_211 = x_187; +} else { + lean_dec_ref(x_187); + x_211 = lean_box(0); +} +x_212 = lean_ctor_get(x_204, 0); +lean_inc(x_212); +x_213 = lean_ctor_get(x_204, 1); +lean_inc(x_213); +x_214 = lean_ctor_get(x_204, 3); +lean_inc(x_214); +x_215 = lean_ctor_get(x_204, 4); +lean_inc(x_215); +if (lean_is_exclusive(x_204)) { + lean_ctor_release(x_204, 0); + lean_ctor_release(x_204, 1); + lean_ctor_release(x_204, 2); + lean_ctor_release(x_204, 3); + lean_ctor_release(x_204, 4); + x_216 = x_204; +} else { + lean_dec_ref(x_204); + x_216 = lean_box(0); +} +if (lean_is_scalar(x_216)) { + x_217 = lean_alloc_ctor(0, 5, 0); +} else { + x_217 = x_216; +} +lean_ctor_set(x_217, 0, x_212); +lean_ctor_set(x_217, 1, x_213); +lean_ctor_set(x_217, 2, x_182); +lean_ctor_set(x_217, 3, x_214); +lean_ctor_set(x_217, 4, x_215); +if (lean_is_scalar(x_211)) { + x_218 = lean_alloc_ctor(0, 6, 0); +} else { + x_218 = x_211; +} +lean_ctor_set(x_218, 0, x_206); +lean_ctor_set(x_218, 1, x_207); +lean_ctor_set(x_218, 2, x_217); +lean_ctor_set(x_218, 3, x_208); +lean_ctor_set(x_218, 4, x_209); +lean_ctor_set(x_218, 5, x_210); +if (lean_is_scalar(x_26)) { + x_219 = lean_alloc_ctor(0, 2, 0); +} else { + x_219 = x_26; +} +lean_ctor_set(x_219, 0, x_205); +lean_ctor_set(x_219, 1, x_218); +return x_219; } } } } default: { -lean_object* x_230; lean_object* x_231; -x_230 = lean_ctor_get(x_19, 1); -lean_inc(x_230); +lean_object* x_240; lean_object* x_241; +x_240 = lean_ctor_get(x_19, 1); +lean_inc(x_240); lean_dec(x_19); lean_inc(x_7); -x_231 = l_Lean_Meta_isClassExpensive___main(x_18, x_7, x_230); -if (lean_obj_tag(x_231) == 0) +x_241 = l_Lean_Meta_isClassExpensive___main(x_18, x_7, x_240); +if (lean_obj_tag(x_241) == 0) { -lean_object* x_232; -x_232 = lean_ctor_get(x_231, 0); -lean_inc(x_232); -if (lean_obj_tag(x_232) == 0) +lean_object* x_242; +x_242 = lean_ctor_get(x_241, 0); +lean_inc(x_242); +if (lean_obj_tag(x_242) == 0) { -lean_object* x_233; lean_object* x_234; lean_object* x_235; +lean_object* x_243; lean_object* x_244; lean_object* x_245; lean_dec(x_14); -x_233 = lean_ctor_get(x_231, 1); -lean_inc(x_233); -lean_dec(x_231); -x_234 = lean_unsigned_to_nat(1u); -x_235 = lean_nat_add(x_6, x_234); +x_243 = lean_ctor_get(x_241, 1); +lean_inc(x_243); +lean_dec(x_241); +x_244 = lean_unsigned_to_nat(1u); +x_245 = lean_nat_add(x_6, x_244); lean_dec(x_6); -x_6 = x_235; -x_8 = x_233; +x_6 = x_245; +x_8 = x_243; goto _start; } else { -lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; uint8_t x_242; -x_237 = lean_ctor_get(x_231, 1); -lean_inc(x_237); -if (lean_is_exclusive(x_231)) { - lean_ctor_release(x_231, 0); - lean_ctor_release(x_231, 1); - x_238 = x_231; +lean_object* x_247; lean_object* x_248; lean_object* x_249; lean_object* x_250; lean_object* x_251; uint8_t x_252; +x_247 = lean_ctor_get(x_241, 1); +lean_inc(x_247); +if (lean_is_exclusive(x_241)) { + lean_ctor_release(x_241, 0); + lean_ctor_release(x_241, 1); + x_248 = x_241; } else { - lean_dec_ref(x_231); - x_238 = lean_box(0); + lean_dec_ref(x_241); + x_248 = lean_box(0); } -x_239 = lean_ctor_get(x_232, 0); -lean_inc(x_239); -lean_dec(x_232); -x_240 = lean_unsigned_to_nat(1u); -x_241 = lean_nat_add(x_6, x_240); -lean_dec(x_6); -x_242 = !lean_is_exclusive(x_237); -if (x_242 == 0) -{ -lean_object* x_243; uint8_t x_244; -x_243 = lean_ctor_get(x_237, 2); -x_244 = !lean_is_exclusive(x_243); -if (x_244 == 0) -{ -lean_object* x_245; lean_object* x_246; lean_object* x_247; lean_object* x_297; uint8_t x_298; -x_245 = lean_ctor_get(x_243, 2); -x_297 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_243, 2, x_297); -x_298 = !lean_is_exclusive(x_7); -if (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_7, 2); -x_300 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_300, 0, x_239); -lean_ctor_set(x_300, 1, x_14); -x_301 = lean_array_push(x_299, x_300); -lean_ctor_set(x_7, 2, x_301); -x_302 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_241, x_7, x_237); -if (lean_obj_tag(x_302) == 0) -{ -lean_object* x_303; lean_object* x_304; lean_object* x_305; -x_303 = lean_ctor_get(x_302, 0); -lean_inc(x_303); -x_304 = lean_ctor_get(x_302, 1); -lean_inc(x_304); -lean_dec(x_302); -x_305 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_305, 0, x_303); -x_246 = x_305; -x_247 = x_304; -goto block_296; -} -else -{ -lean_object* x_306; lean_object* x_307; lean_object* x_308; -x_306 = lean_ctor_get(x_302, 0); -lean_inc(x_306); -x_307 = lean_ctor_get(x_302, 1); -lean_inc(x_307); -lean_dec(x_302); -x_308 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_308, 0, x_306); -x_246 = x_308; -x_247 = x_307; -goto block_296; -} -} -else -{ -lean_object* x_309; lean_object* x_310; lean_object* x_311; lean_object* x_312; lean_object* x_313; lean_object* x_314; lean_object* x_315; lean_object* x_316; lean_object* x_317; -x_309 = lean_ctor_get(x_7, 0); -x_310 = lean_ctor_get(x_7, 1); -x_311 = lean_ctor_get(x_7, 2); -x_312 = lean_ctor_get(x_7, 3); -x_313 = lean_ctor_get(x_7, 4); -lean_inc(x_313); -lean_inc(x_312); -lean_inc(x_311); -lean_inc(x_310); -lean_inc(x_309); -lean_dec(x_7); -x_314 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_314, 0, x_239); -lean_ctor_set(x_314, 1, x_14); -x_315 = lean_array_push(x_311, x_314); -x_316 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_316, 0, x_309); -lean_ctor_set(x_316, 1, x_310); -lean_ctor_set(x_316, 2, x_315); -lean_ctor_set(x_316, 3, x_312); -lean_ctor_set(x_316, 4, x_313); -x_317 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_241, x_316, x_237); -if (lean_obj_tag(x_317) == 0) -{ -lean_object* x_318; lean_object* x_319; lean_object* x_320; -x_318 = lean_ctor_get(x_317, 0); -lean_inc(x_318); -x_319 = lean_ctor_get(x_317, 1); -lean_inc(x_319); -lean_dec(x_317); -x_320 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_320, 0, x_318); -x_246 = x_320; -x_247 = x_319; -goto block_296; -} -else -{ -lean_object* x_321; lean_object* x_322; lean_object* x_323; -x_321 = lean_ctor_get(x_317, 0); -lean_inc(x_321); -x_322 = lean_ctor_get(x_317, 1); -lean_inc(x_322); -lean_dec(x_317); -x_323 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_323, 0, x_321); -x_246 = x_323; -x_247 = x_322; -goto block_296; -} -} -block_296: -{ -if (lean_obj_tag(x_246) == 0) -{ -lean_object* x_248; lean_object* x_249; uint8_t x_250; -x_248 = lean_ctor_get(x_247, 2); -lean_inc(x_248); -x_249 = lean_ctor_get(x_246, 0); +x_249 = lean_ctor_get(x_242, 0); lean_inc(x_249); -lean_dec(x_246); -x_250 = !lean_is_exclusive(x_247); -if (x_250 == 0) -{ -lean_object* x_251; uint8_t x_252; -x_251 = lean_ctor_get(x_247, 2); -lean_dec(x_251); -x_252 = !lean_is_exclusive(x_248); +lean_dec(x_242); +x_250 = lean_unsigned_to_nat(1u); +x_251 = lean_nat_add(x_6, x_250); +lean_dec(x_6); +x_252 = !lean_is_exclusive(x_247); if (x_252 == 0) { -lean_object* x_253; lean_object* x_254; -x_253 = lean_ctor_get(x_248, 2); -lean_dec(x_253); -lean_ctor_set(x_248, 2, x_245); -if (lean_is_scalar(x_238)) { - x_254 = lean_alloc_ctor(1, 2, 0); -} else { - x_254 = x_238; - lean_ctor_set_tag(x_254, 1); -} -lean_ctor_set(x_254, 0, x_249); -lean_ctor_set(x_254, 1, x_247); -return x_254; +lean_object* x_253; uint8_t x_254; +x_253 = lean_ctor_get(x_247, 2); +x_254 = !lean_is_exclusive(x_253); +if (x_254 == 0) +{ +lean_object* x_255; lean_object* x_256; lean_object* x_257; lean_object* x_311; uint8_t x_312; +x_255 = lean_ctor_get(x_253, 2); +x_311 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_253, 2, x_311); +x_312 = !lean_is_exclusive(x_7); +if (x_312 == 0) +{ +lean_object* x_313; lean_object* x_314; lean_object* x_315; lean_object* x_316; +x_313 = lean_ctor_get(x_7, 2); +x_314 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_314, 0, x_249); +lean_ctor_set(x_314, 1, x_14); +x_315 = lean_array_push(x_313, x_314); +lean_ctor_set(x_7, 2, x_315); +x_316 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_251, x_7, x_247); +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); +x_319 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_319, 0, x_317); +x_256 = x_319; +x_257 = x_318; +goto block_310; } else { -lean_object* x_255; lean_object* x_256; lean_object* x_257; lean_object* x_258; lean_object* x_259; -x_255 = lean_ctor_get(x_248, 0); -x_256 = lean_ctor_get(x_248, 1); -x_257 = lean_ctor_get(x_248, 3); -lean_inc(x_257); -lean_inc(x_256); -lean_inc(x_255); -lean_dec(x_248); -x_258 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_258, 0, x_255); -lean_ctor_set(x_258, 1, x_256); -lean_ctor_set(x_258, 2, x_245); -lean_ctor_set(x_258, 3, x_257); -lean_ctor_set(x_247, 2, x_258); -if (lean_is_scalar(x_238)) { - x_259 = lean_alloc_ctor(1, 2, 0); -} else { - x_259 = x_238; - lean_ctor_set_tag(x_259, 1); -} -lean_ctor_set(x_259, 0, x_249); -lean_ctor_set(x_259, 1, x_247); -return x_259; +lean_object* x_320; lean_object* x_321; lean_object* x_322; +x_320 = lean_ctor_get(x_316, 0); +lean_inc(x_320); +x_321 = lean_ctor_get(x_316, 1); +lean_inc(x_321); +lean_dec(x_316); +x_322 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_322, 0, x_320); +x_256 = x_322; +x_257 = x_321; +goto block_310; } } else { -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_260 = lean_ctor_get(x_247, 0); -x_261 = lean_ctor_get(x_247, 1); -x_262 = lean_ctor_get(x_247, 3); -x_263 = lean_ctor_get(x_247, 4); -x_264 = lean_ctor_get(x_247, 5); -lean_inc(x_264); -lean_inc(x_263); -lean_inc(x_262); -lean_inc(x_261); -lean_inc(x_260); -lean_dec(x_247); -x_265 = lean_ctor_get(x_248, 0); -lean_inc(x_265); -x_266 = lean_ctor_get(x_248, 1); -lean_inc(x_266); -x_267 = lean_ctor_get(x_248, 3); +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; +x_323 = lean_ctor_get(x_7, 0); +x_324 = lean_ctor_get(x_7, 1); +x_325 = lean_ctor_get(x_7, 2); +x_326 = lean_ctor_get(x_7, 3); +x_327 = lean_ctor_get(x_7, 4); +lean_inc(x_327); +lean_inc(x_326); +lean_inc(x_325); +lean_inc(x_324); +lean_inc(x_323); +lean_dec(x_7); +x_328 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_328, 0, x_249); +lean_ctor_set(x_328, 1, x_14); +x_329 = lean_array_push(x_325, x_328); +x_330 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_330, 0, x_323); +lean_ctor_set(x_330, 1, x_324); +lean_ctor_set(x_330, 2, x_329); +lean_ctor_set(x_330, 3, x_326); +lean_ctor_set(x_330, 4, x_327); +x_331 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_251, x_330, x_247); +if (lean_obj_tag(x_331) == 0) +{ +lean_object* x_332; lean_object* x_333; lean_object* x_334; +x_332 = lean_ctor_get(x_331, 0); +lean_inc(x_332); +x_333 = lean_ctor_get(x_331, 1); +lean_inc(x_333); +lean_dec(x_331); +x_334 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_334, 0, x_332); +x_256 = x_334; +x_257 = x_333; +goto block_310; +} +else +{ +lean_object* x_335; lean_object* x_336; lean_object* x_337; +x_335 = lean_ctor_get(x_331, 0); +lean_inc(x_335); +x_336 = lean_ctor_get(x_331, 1); +lean_inc(x_336); +lean_dec(x_331); +x_337 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_337, 0, x_335); +x_256 = x_337; +x_257 = x_336; +goto block_310; +} +} +block_310: +{ +if (lean_obj_tag(x_256) == 0) +{ +lean_object* x_258; lean_object* x_259; uint8_t x_260; +x_258 = lean_ctor_get(x_257, 2); +lean_inc(x_258); +x_259 = lean_ctor_get(x_256, 0); +lean_inc(x_259); +lean_dec(x_256); +x_260 = !lean_is_exclusive(x_257); +if (x_260 == 0) +{ +lean_object* x_261; uint8_t x_262; +x_261 = lean_ctor_get(x_257, 2); +lean_dec(x_261); +x_262 = !lean_is_exclusive(x_258); +if (x_262 == 0) +{ +lean_object* x_263; lean_object* x_264; +x_263 = lean_ctor_get(x_258, 2); +lean_dec(x_263); +lean_ctor_set(x_258, 2, x_255); +if (lean_is_scalar(x_248)) { + x_264 = lean_alloc_ctor(1, 2, 0); +} else { + x_264 = x_248; + lean_ctor_set_tag(x_264, 1); +} +lean_ctor_set(x_264, 0, x_259); +lean_ctor_set(x_264, 1, x_257); +return x_264; +} +else +{ +lean_object* x_265; lean_object* x_266; lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_object* x_270; +x_265 = lean_ctor_get(x_258, 0); +x_266 = lean_ctor_get(x_258, 1); +x_267 = lean_ctor_get(x_258, 3); +x_268 = lean_ctor_get(x_258, 4); +lean_inc(x_268); lean_inc(x_267); -if (lean_is_exclusive(x_248)) { - lean_ctor_release(x_248, 0); - lean_ctor_release(x_248, 1); - lean_ctor_release(x_248, 2); - lean_ctor_release(x_248, 3); - x_268 = x_248; -} else { - lean_dec_ref(x_248); - x_268 = lean_box(0); -} -if (lean_is_scalar(x_268)) { - x_269 = lean_alloc_ctor(0, 4, 0); -} else { - x_269 = x_268; -} +lean_inc(x_266); +lean_inc(x_265); +lean_dec(x_258); +x_269 = lean_alloc_ctor(0, 5, 0); lean_ctor_set(x_269, 0, x_265); lean_ctor_set(x_269, 1, x_266); -lean_ctor_set(x_269, 2, x_245); +lean_ctor_set(x_269, 2, x_255); lean_ctor_set(x_269, 3, x_267); -x_270 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_270, 0, x_260); -lean_ctor_set(x_270, 1, x_261); -lean_ctor_set(x_270, 2, x_269); -lean_ctor_set(x_270, 3, x_262); -lean_ctor_set(x_270, 4, x_263); -lean_ctor_set(x_270, 5, x_264); -if (lean_is_scalar(x_238)) { - x_271 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_269, 4, x_268); +lean_ctor_set(x_257, 2, x_269); +if (lean_is_scalar(x_248)) { + x_270 = lean_alloc_ctor(1, 2, 0); } else { - x_271 = x_238; - lean_ctor_set_tag(x_271, 1); + x_270 = x_248; + lean_ctor_set_tag(x_270, 1); } -lean_ctor_set(x_271, 0, x_249); -lean_ctor_set(x_271, 1, x_270); -return x_271; +lean_ctor_set(x_270, 0, x_259); +lean_ctor_set(x_270, 1, x_257); +return x_270; } } else { -lean_object* x_272; lean_object* x_273; uint8_t x_274; -x_272 = lean_ctor_get(x_247, 2); -lean_inc(x_272); -x_273 = lean_ctor_get(x_246, 0); +lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_object* x_276; lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; lean_object* x_281; lean_object* x_282; lean_object* x_283; +x_271 = lean_ctor_get(x_257, 0); +x_272 = lean_ctor_get(x_257, 1); +x_273 = lean_ctor_get(x_257, 3); +x_274 = lean_ctor_get(x_257, 4); +x_275 = lean_ctor_get(x_257, 5); +lean_inc(x_275); +lean_inc(x_274); lean_inc(x_273); -lean_dec(x_246); -x_274 = !lean_is_exclusive(x_247); -if (x_274 == 0) -{ -lean_object* x_275; uint8_t x_276; -x_275 = lean_ctor_get(x_247, 2); -lean_dec(x_275); -x_276 = !lean_is_exclusive(x_272); -if (x_276 == 0) -{ -lean_object* x_277; lean_object* x_278; -x_277 = lean_ctor_get(x_272, 2); -lean_dec(x_277); -lean_ctor_set(x_272, 2, x_245); -if (lean_is_scalar(x_238)) { - x_278 = lean_alloc_ctor(0, 2, 0); -} else { - x_278 = x_238; -} -lean_ctor_set(x_278, 0, x_273); -lean_ctor_set(x_278, 1, x_247); -return x_278; -} -else -{ -lean_object* x_279; lean_object* x_280; lean_object* x_281; lean_object* x_282; lean_object* x_283; -x_279 = lean_ctor_get(x_272, 0); -x_280 = lean_ctor_get(x_272, 1); -x_281 = lean_ctor_get(x_272, 3); -lean_inc(x_281); -lean_inc(x_280); +lean_inc(x_272); +lean_inc(x_271); +lean_dec(x_257); +x_276 = lean_ctor_get(x_258, 0); +lean_inc(x_276); +x_277 = lean_ctor_get(x_258, 1); +lean_inc(x_277); +x_278 = lean_ctor_get(x_258, 3); +lean_inc(x_278); +x_279 = lean_ctor_get(x_258, 4); lean_inc(x_279); -lean_dec(x_272); -x_282 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_282, 0, x_279); -lean_ctor_set(x_282, 1, x_280); -lean_ctor_set(x_282, 2, x_245); -lean_ctor_set(x_282, 3, x_281); -lean_ctor_set(x_247, 2, x_282); -if (lean_is_scalar(x_238)) { - x_283 = lean_alloc_ctor(0, 2, 0); +if (lean_is_exclusive(x_258)) { + lean_ctor_release(x_258, 0); + lean_ctor_release(x_258, 1); + lean_ctor_release(x_258, 2); + lean_ctor_release(x_258, 3); + lean_ctor_release(x_258, 4); + x_280 = x_258; } else { - x_283 = x_238; + lean_dec_ref(x_258); + x_280 = lean_box(0); } -lean_ctor_set(x_283, 0, x_273); -lean_ctor_set(x_283, 1, x_247); +if (lean_is_scalar(x_280)) { + x_281 = lean_alloc_ctor(0, 5, 0); +} else { + x_281 = x_280; +} +lean_ctor_set(x_281, 0, x_276); +lean_ctor_set(x_281, 1, x_277); +lean_ctor_set(x_281, 2, x_255); +lean_ctor_set(x_281, 3, x_278); +lean_ctor_set(x_281, 4, x_279); +x_282 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_282, 0, x_271); +lean_ctor_set(x_282, 1, x_272); +lean_ctor_set(x_282, 2, x_281); +lean_ctor_set(x_282, 3, x_273); +lean_ctor_set(x_282, 4, x_274); +lean_ctor_set(x_282, 5, x_275); +if (lean_is_scalar(x_248)) { + x_283 = lean_alloc_ctor(1, 2, 0); +} else { + x_283 = x_248; + lean_ctor_set_tag(x_283, 1); +} +lean_ctor_set(x_283, 0, x_259); +lean_ctor_set(x_283, 1, x_282); return x_283; } } else { -lean_object* x_284; lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; lean_object* x_289; lean_object* x_290; lean_object* x_291; lean_object* x_292; lean_object* x_293; lean_object* x_294; lean_object* x_295; -x_284 = lean_ctor_get(x_247, 0); -x_285 = lean_ctor_get(x_247, 1); -x_286 = lean_ctor_get(x_247, 3); -x_287 = lean_ctor_get(x_247, 4); -x_288 = lean_ctor_get(x_247, 5); -lean_inc(x_288); -lean_inc(x_287); -lean_inc(x_286); -lean_inc(x_285); +lean_object* x_284; lean_object* x_285; uint8_t x_286; +x_284 = lean_ctor_get(x_257, 2); lean_inc(x_284); -lean_dec(x_247); -x_289 = lean_ctor_get(x_272, 0); -lean_inc(x_289); -x_290 = lean_ctor_get(x_272, 1); -lean_inc(x_290); -x_291 = lean_ctor_get(x_272, 3); +x_285 = lean_ctor_get(x_256, 0); +lean_inc(x_285); +lean_dec(x_256); +x_286 = !lean_is_exclusive(x_257); +if (x_286 == 0) +{ +lean_object* x_287; uint8_t x_288; +x_287 = lean_ctor_get(x_257, 2); +lean_dec(x_287); +x_288 = !lean_is_exclusive(x_284); +if (x_288 == 0) +{ +lean_object* x_289; lean_object* x_290; +x_289 = lean_ctor_get(x_284, 2); +lean_dec(x_289); +lean_ctor_set(x_284, 2, x_255); +if (lean_is_scalar(x_248)) { + x_290 = lean_alloc_ctor(0, 2, 0); +} else { + x_290 = x_248; +} +lean_ctor_set(x_290, 0, x_285); +lean_ctor_set(x_290, 1, x_257); +return x_290; +} +else +{ +lean_object* x_291; lean_object* x_292; lean_object* x_293; lean_object* x_294; lean_object* x_295; lean_object* x_296; +x_291 = lean_ctor_get(x_284, 0); +x_292 = lean_ctor_get(x_284, 1); +x_293 = lean_ctor_get(x_284, 3); +x_294 = lean_ctor_get(x_284, 4); +lean_inc(x_294); +lean_inc(x_293); +lean_inc(x_292); lean_inc(x_291); -if (lean_is_exclusive(x_272)) { - lean_ctor_release(x_272, 0); - lean_ctor_release(x_272, 1); - lean_ctor_release(x_272, 2); - lean_ctor_release(x_272, 3); - x_292 = x_272; +lean_dec(x_284); +x_295 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_295, 0, x_291); +lean_ctor_set(x_295, 1, x_292); +lean_ctor_set(x_295, 2, x_255); +lean_ctor_set(x_295, 3, x_293); +lean_ctor_set(x_295, 4, x_294); +lean_ctor_set(x_257, 2, x_295); +if (lean_is_scalar(x_248)) { + x_296 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_272); - x_292 = lean_box(0); + x_296 = x_248; } -if (lean_is_scalar(x_292)) { - x_293 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_296, 0, x_285); +lean_ctor_set(x_296, 1, x_257); +return x_296; +} +} +else +{ +lean_object* x_297; lean_object* x_298; lean_object* x_299; lean_object* x_300; lean_object* x_301; lean_object* x_302; lean_object* x_303; lean_object* x_304; lean_object* x_305; lean_object* x_306; lean_object* x_307; lean_object* x_308; lean_object* x_309; +x_297 = lean_ctor_get(x_257, 0); +x_298 = lean_ctor_get(x_257, 1); +x_299 = lean_ctor_get(x_257, 3); +x_300 = lean_ctor_get(x_257, 4); +x_301 = lean_ctor_get(x_257, 5); +lean_inc(x_301); +lean_inc(x_300); +lean_inc(x_299); +lean_inc(x_298); +lean_inc(x_297); +lean_dec(x_257); +x_302 = lean_ctor_get(x_284, 0); +lean_inc(x_302); +x_303 = lean_ctor_get(x_284, 1); +lean_inc(x_303); +x_304 = lean_ctor_get(x_284, 3); +lean_inc(x_304); +x_305 = lean_ctor_get(x_284, 4); +lean_inc(x_305); +if (lean_is_exclusive(x_284)) { + lean_ctor_release(x_284, 0); + lean_ctor_release(x_284, 1); + lean_ctor_release(x_284, 2); + lean_ctor_release(x_284, 3); + lean_ctor_release(x_284, 4); + x_306 = x_284; } else { - x_293 = x_292; + lean_dec_ref(x_284); + x_306 = lean_box(0); } -lean_ctor_set(x_293, 0, x_289); -lean_ctor_set(x_293, 1, x_290); -lean_ctor_set(x_293, 2, x_245); -lean_ctor_set(x_293, 3, x_291); -x_294 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_294, 0, x_284); -lean_ctor_set(x_294, 1, x_285); -lean_ctor_set(x_294, 2, x_293); -lean_ctor_set(x_294, 3, x_286); -lean_ctor_set(x_294, 4, x_287); -lean_ctor_set(x_294, 5, x_288); -if (lean_is_scalar(x_238)) { - x_295 = lean_alloc_ctor(0, 2, 0); +if (lean_is_scalar(x_306)) { + x_307 = lean_alloc_ctor(0, 5, 0); } else { - x_295 = x_238; + x_307 = x_306; } -lean_ctor_set(x_295, 0, x_273); -lean_ctor_set(x_295, 1, x_294); -return x_295; +lean_ctor_set(x_307, 0, x_302); +lean_ctor_set(x_307, 1, x_303); +lean_ctor_set(x_307, 2, x_255); +lean_ctor_set(x_307, 3, x_304); +lean_ctor_set(x_307, 4, x_305); +x_308 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_308, 0, x_297); +lean_ctor_set(x_308, 1, x_298); +lean_ctor_set(x_308, 2, x_307); +lean_ctor_set(x_308, 3, x_299); +lean_ctor_set(x_308, 4, x_300); +lean_ctor_set(x_308, 5, x_301); +if (lean_is_scalar(x_248)) { + x_309 = lean_alloc_ctor(0, 2, 0); +} else { + x_309 = x_248; +} +lean_ctor_set(x_309, 0, x_285); +lean_ctor_set(x_309, 1, x_308); +return x_309; } } } } else { -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_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; -x_324 = lean_ctor_get(x_243, 0); -x_325 = lean_ctor_get(x_243, 1); -x_326 = lean_ctor_get(x_243, 2); -x_327 = lean_ctor_get(x_243, 3); -lean_inc(x_327); -lean_inc(x_326); -lean_inc(x_325); -lean_inc(x_324); -lean_dec(x_243); -x_361 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_362 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_362, 0, x_324); -lean_ctor_set(x_362, 1, x_325); -lean_ctor_set(x_362, 2, x_361); -lean_ctor_set(x_362, 3, x_327); -lean_ctor_set(x_237, 2, x_362); -x_363 = lean_ctor_get(x_7, 0); -lean_inc(x_363); -x_364 = lean_ctor_get(x_7, 1); -lean_inc(x_364); -x_365 = lean_ctor_get(x_7, 2); -lean_inc(x_365); -x_366 = lean_ctor_get(x_7, 3); -lean_inc(x_366); -x_367 = lean_ctor_get(x_7, 4); -lean_inc(x_367); +lean_object* x_338; lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; lean_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; +x_338 = lean_ctor_get(x_253, 0); +x_339 = lean_ctor_get(x_253, 1); +x_340 = lean_ctor_get(x_253, 2); +x_341 = lean_ctor_get(x_253, 3); +x_342 = lean_ctor_get(x_253, 4); +lean_inc(x_342); +lean_inc(x_341); +lean_inc(x_340); +lean_inc(x_339); +lean_inc(x_338); +lean_dec(x_253); +x_378 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_379 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_379, 0, x_338); +lean_ctor_set(x_379, 1, x_339); +lean_ctor_set(x_379, 2, x_378); +lean_ctor_set(x_379, 3, x_341); +lean_ctor_set(x_379, 4, x_342); +lean_ctor_set(x_247, 2, x_379); +x_380 = lean_ctor_get(x_7, 0); +lean_inc(x_380); +x_381 = lean_ctor_get(x_7, 1); +lean_inc(x_381); +x_382 = lean_ctor_get(x_7, 2); +lean_inc(x_382); +x_383 = lean_ctor_get(x_7, 3); +lean_inc(x_383); +x_384 = lean_ctor_get(x_7, 4); +lean_inc(x_384); if (lean_is_exclusive(x_7)) { lean_ctor_release(x_7, 0); lean_ctor_release(x_7, 1); lean_ctor_release(x_7, 2); lean_ctor_release(x_7, 3); lean_ctor_release(x_7, 4); - x_368 = x_7; + x_385 = x_7; } else { lean_dec_ref(x_7); - x_368 = lean_box(0); + x_385 = lean_box(0); } -x_369 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_369, 0, x_239); -lean_ctor_set(x_369, 1, x_14); -x_370 = lean_array_push(x_365, x_369); -if (lean_is_scalar(x_368)) { - x_371 = lean_alloc_ctor(0, 5, 0); +x_386 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_386, 0, x_249); +lean_ctor_set(x_386, 1, x_14); +x_387 = lean_array_push(x_382, x_386); +if (lean_is_scalar(x_385)) { + x_388 = lean_alloc_ctor(0, 5, 0); } else { - x_371 = x_368; + x_388 = x_385; } -lean_ctor_set(x_371, 0, x_363); -lean_ctor_set(x_371, 1, x_364); -lean_ctor_set(x_371, 2, x_370); -lean_ctor_set(x_371, 3, x_366); -lean_ctor_set(x_371, 4, x_367); -x_372 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_241, x_371, x_237); -if (lean_obj_tag(x_372) == 0) +lean_ctor_set(x_388, 0, x_380); +lean_ctor_set(x_388, 1, x_381); +lean_ctor_set(x_388, 2, x_387); +lean_ctor_set(x_388, 3, x_383); +lean_ctor_set(x_388, 4, x_384); +x_389 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_251, x_388, x_247); +if (lean_obj_tag(x_389) == 0) { -lean_object* x_373; lean_object* x_374; lean_object* x_375; -x_373 = lean_ctor_get(x_372, 0); -lean_inc(x_373); -x_374 = lean_ctor_get(x_372, 1); -lean_inc(x_374); -lean_dec(x_372); -x_375 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_375, 0, x_373); -x_328 = x_375; -x_329 = x_374; -goto block_360; +lean_object* x_390; lean_object* x_391; lean_object* x_392; +x_390 = lean_ctor_get(x_389, 0); +lean_inc(x_390); +x_391 = lean_ctor_get(x_389, 1); +lean_inc(x_391); +lean_dec(x_389); +x_392 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_392, 0, x_390); +x_343 = x_392; +x_344 = x_391; +goto block_377; } else { -lean_object* x_376; lean_object* x_377; lean_object* x_378; -x_376 = lean_ctor_get(x_372, 0); -lean_inc(x_376); -x_377 = lean_ctor_get(x_372, 1); -lean_inc(x_377); -lean_dec(x_372); -x_378 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_378, 0, x_376); -x_328 = x_378; -x_329 = x_377; -goto block_360; +lean_object* x_393; lean_object* x_394; lean_object* x_395; +x_393 = lean_ctor_get(x_389, 0); +lean_inc(x_393); +x_394 = lean_ctor_get(x_389, 1); +lean_inc(x_394); +lean_dec(x_389); +x_395 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_395, 0, x_393); +x_343 = x_395; +x_344 = x_394; +goto block_377; } -block_360: +block_377: { -if (lean_obj_tag(x_328) == 0) +if (lean_obj_tag(x_343) == 0) { -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; lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; -x_330 = lean_ctor_get(x_329, 2); -lean_inc(x_330); -x_331 = lean_ctor_get(x_328, 0); -lean_inc(x_331); -lean_dec(x_328); -x_332 = lean_ctor_get(x_329, 0); -lean_inc(x_332); -x_333 = lean_ctor_get(x_329, 1); -lean_inc(x_333); -x_334 = lean_ctor_get(x_329, 3); -lean_inc(x_334); -x_335 = lean_ctor_get(x_329, 4); -lean_inc(x_335); -x_336 = lean_ctor_get(x_329, 5); -lean_inc(x_336); -if (lean_is_exclusive(x_329)) { - lean_ctor_release(x_329, 0); - lean_ctor_release(x_329, 1); - lean_ctor_release(x_329, 2); - lean_ctor_release(x_329, 3); - lean_ctor_release(x_329, 4); - lean_ctor_release(x_329, 5); - x_337 = x_329; -} else { - lean_dec_ref(x_329); - x_337 = lean_box(0); -} -x_338 = lean_ctor_get(x_330, 0); -lean_inc(x_338); -x_339 = lean_ctor_get(x_330, 1); -lean_inc(x_339); -x_340 = lean_ctor_get(x_330, 3); -lean_inc(x_340); -if (lean_is_exclusive(x_330)) { - lean_ctor_release(x_330, 0); - lean_ctor_release(x_330, 1); - lean_ctor_release(x_330, 2); - lean_ctor_release(x_330, 3); - x_341 = x_330; -} else { - lean_dec_ref(x_330); - x_341 = lean_box(0); -} -if (lean_is_scalar(x_341)) { - x_342 = lean_alloc_ctor(0, 4, 0); -} else { - x_342 = x_341; -} -lean_ctor_set(x_342, 0, x_338); -lean_ctor_set(x_342, 1, x_339); -lean_ctor_set(x_342, 2, x_326); -lean_ctor_set(x_342, 3, x_340); -if (lean_is_scalar(x_337)) { - x_343 = lean_alloc_ctor(0, 6, 0); -} else { - x_343 = x_337; -} -lean_ctor_set(x_343, 0, x_332); -lean_ctor_set(x_343, 1, x_333); -lean_ctor_set(x_343, 2, x_342); -lean_ctor_set(x_343, 3, x_334); -lean_ctor_set(x_343, 4, x_335); -lean_ctor_set(x_343, 5, x_336); -if (lean_is_scalar(x_238)) { - x_344 = lean_alloc_ctor(1, 2, 0); -} else { - x_344 = x_238; - lean_ctor_set_tag(x_344, 1); -} -lean_ctor_set(x_344, 0, x_331); -lean_ctor_set(x_344, 1, x_343); -return x_344; -} -else -{ -lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; lean_object* x_350; lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; lean_object* x_358; lean_object* x_359; -x_345 = lean_ctor_get(x_329, 2); +lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; lean_object* x_350; lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; lean_object* x_358; lean_object* x_359; lean_object* x_360; +x_345 = lean_ctor_get(x_344, 2); lean_inc(x_345); -x_346 = lean_ctor_get(x_328, 0); +x_346 = lean_ctor_get(x_343, 0); lean_inc(x_346); -lean_dec(x_328); -x_347 = lean_ctor_get(x_329, 0); +lean_dec(x_343); +x_347 = lean_ctor_get(x_344, 0); lean_inc(x_347); -x_348 = lean_ctor_get(x_329, 1); +x_348 = lean_ctor_get(x_344, 1); lean_inc(x_348); -x_349 = lean_ctor_get(x_329, 3); +x_349 = lean_ctor_get(x_344, 3); lean_inc(x_349); -x_350 = lean_ctor_get(x_329, 4); +x_350 = lean_ctor_get(x_344, 4); lean_inc(x_350); -x_351 = lean_ctor_get(x_329, 5); +x_351 = lean_ctor_get(x_344, 5); lean_inc(x_351); -if (lean_is_exclusive(x_329)) { - lean_ctor_release(x_329, 0); - lean_ctor_release(x_329, 1); - lean_ctor_release(x_329, 2); - lean_ctor_release(x_329, 3); - lean_ctor_release(x_329, 4); - lean_ctor_release(x_329, 5); - x_352 = x_329; +if (lean_is_exclusive(x_344)) { + lean_ctor_release(x_344, 0); + lean_ctor_release(x_344, 1); + lean_ctor_release(x_344, 2); + lean_ctor_release(x_344, 3); + lean_ctor_release(x_344, 4); + lean_ctor_release(x_344, 5); + x_352 = x_344; } else { - lean_dec_ref(x_329); + lean_dec_ref(x_344); x_352 = lean_box(0); } x_353 = lean_ctor_get(x_345, 0); @@ -31101,315 +31999,411 @@ x_354 = lean_ctor_get(x_345, 1); lean_inc(x_354); x_355 = lean_ctor_get(x_345, 3); lean_inc(x_355); +x_356 = lean_ctor_get(x_345, 4); +lean_inc(x_356); if (lean_is_exclusive(x_345)) { lean_ctor_release(x_345, 0); lean_ctor_release(x_345, 1); lean_ctor_release(x_345, 2); lean_ctor_release(x_345, 3); - x_356 = x_345; + lean_ctor_release(x_345, 4); + x_357 = x_345; } else { lean_dec_ref(x_345); - x_356 = lean_box(0); + x_357 = lean_box(0); } -if (lean_is_scalar(x_356)) { - x_357 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_357)) { + x_358 = lean_alloc_ctor(0, 5, 0); } else { - x_357 = x_356; + x_358 = x_357; } -lean_ctor_set(x_357, 0, x_353); -lean_ctor_set(x_357, 1, x_354); -lean_ctor_set(x_357, 2, x_326); -lean_ctor_set(x_357, 3, x_355); +lean_ctor_set(x_358, 0, x_353); +lean_ctor_set(x_358, 1, x_354); +lean_ctor_set(x_358, 2, x_340); +lean_ctor_set(x_358, 3, x_355); +lean_ctor_set(x_358, 4, x_356); if (lean_is_scalar(x_352)) { - x_358 = lean_alloc_ctor(0, 6, 0); + x_359 = lean_alloc_ctor(0, 6, 0); } else { - x_358 = x_352; + x_359 = x_352; } -lean_ctor_set(x_358, 0, x_347); -lean_ctor_set(x_358, 1, x_348); -lean_ctor_set(x_358, 2, x_357); -lean_ctor_set(x_358, 3, x_349); -lean_ctor_set(x_358, 4, x_350); -lean_ctor_set(x_358, 5, x_351); -if (lean_is_scalar(x_238)) { - x_359 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_359, 0, x_347); +lean_ctor_set(x_359, 1, x_348); +lean_ctor_set(x_359, 2, x_358); +lean_ctor_set(x_359, 3, x_349); +lean_ctor_set(x_359, 4, x_350); +lean_ctor_set(x_359, 5, x_351); +if (lean_is_scalar(x_248)) { + x_360 = lean_alloc_ctor(1, 2, 0); } else { - x_359 = x_238; + x_360 = x_248; + lean_ctor_set_tag(x_360, 1); } -lean_ctor_set(x_359, 0, x_346); -lean_ctor_set(x_359, 1, x_358); -return x_359; +lean_ctor_set(x_360, 0, x_346); +lean_ctor_set(x_360, 1, x_359); +return x_360; +} +else +{ +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; lean_object* x_374; lean_object* x_375; lean_object* x_376; +x_361 = lean_ctor_get(x_344, 2); +lean_inc(x_361); +x_362 = lean_ctor_get(x_343, 0); +lean_inc(x_362); +lean_dec(x_343); +x_363 = lean_ctor_get(x_344, 0); +lean_inc(x_363); +x_364 = lean_ctor_get(x_344, 1); +lean_inc(x_364); +x_365 = lean_ctor_get(x_344, 3); +lean_inc(x_365); +x_366 = lean_ctor_get(x_344, 4); +lean_inc(x_366); +x_367 = lean_ctor_get(x_344, 5); +lean_inc(x_367); +if (lean_is_exclusive(x_344)) { + lean_ctor_release(x_344, 0); + lean_ctor_release(x_344, 1); + lean_ctor_release(x_344, 2); + lean_ctor_release(x_344, 3); + lean_ctor_release(x_344, 4); + lean_ctor_release(x_344, 5); + x_368 = x_344; +} else { + lean_dec_ref(x_344); + x_368 = lean_box(0); +} +x_369 = lean_ctor_get(x_361, 0); +lean_inc(x_369); +x_370 = lean_ctor_get(x_361, 1); +lean_inc(x_370); +x_371 = lean_ctor_get(x_361, 3); +lean_inc(x_371); +x_372 = lean_ctor_get(x_361, 4); +lean_inc(x_372); +if (lean_is_exclusive(x_361)) { + lean_ctor_release(x_361, 0); + lean_ctor_release(x_361, 1); + lean_ctor_release(x_361, 2); + lean_ctor_release(x_361, 3); + lean_ctor_release(x_361, 4); + x_373 = x_361; +} else { + lean_dec_ref(x_361); + x_373 = lean_box(0); +} +if (lean_is_scalar(x_373)) { + x_374 = lean_alloc_ctor(0, 5, 0); +} else { + x_374 = x_373; +} +lean_ctor_set(x_374, 0, x_369); +lean_ctor_set(x_374, 1, x_370); +lean_ctor_set(x_374, 2, x_340); +lean_ctor_set(x_374, 3, x_371); +lean_ctor_set(x_374, 4, x_372); +if (lean_is_scalar(x_368)) { + x_375 = lean_alloc_ctor(0, 6, 0); +} else { + x_375 = x_368; +} +lean_ctor_set(x_375, 0, x_363); +lean_ctor_set(x_375, 1, x_364); +lean_ctor_set(x_375, 2, x_374); +lean_ctor_set(x_375, 3, x_365); +lean_ctor_set(x_375, 4, x_366); +lean_ctor_set(x_375, 5, x_367); +if (lean_is_scalar(x_248)) { + x_376 = lean_alloc_ctor(0, 2, 0); +} else { + x_376 = x_248; +} +lean_ctor_set(x_376, 0, x_362); +lean_ctor_set(x_376, 1, x_375); +return x_376; } } } } else { -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; lean_object* x_391; lean_object* x_423; lean_object* x_424; lean_object* x_425; lean_object* x_426; lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; lean_object* x_432; lean_object* x_433; lean_object* x_434; lean_object* x_435; -x_379 = lean_ctor_get(x_237, 2); -x_380 = lean_ctor_get(x_237, 0); -x_381 = lean_ctor_get(x_237, 1); -x_382 = lean_ctor_get(x_237, 3); -x_383 = lean_ctor_get(x_237, 4); -x_384 = lean_ctor_get(x_237, 5); -lean_inc(x_384); -lean_inc(x_383); -lean_inc(x_382); -lean_inc(x_379); -lean_inc(x_381); -lean_inc(x_380); -lean_dec(x_237); -x_385 = lean_ctor_get(x_379, 0); -lean_inc(x_385); -x_386 = lean_ctor_get(x_379, 1); -lean_inc(x_386); -x_387 = lean_ctor_get(x_379, 2); -lean_inc(x_387); -x_388 = lean_ctor_get(x_379, 3); -lean_inc(x_388); -if (lean_is_exclusive(x_379)) { - lean_ctor_release(x_379, 0); - lean_ctor_release(x_379, 1); - lean_ctor_release(x_379, 2); - lean_ctor_release(x_379, 3); - x_389 = x_379; +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; lean_object* x_408; lean_object* x_409; lean_object* x_443; lean_object* x_444; lean_object* x_445; lean_object* x_446; lean_object* x_447; lean_object* x_448; lean_object* x_449; lean_object* x_450; lean_object* x_451; lean_object* x_452; lean_object* x_453; lean_object* x_454; lean_object* x_455; +x_396 = lean_ctor_get(x_247, 2); +x_397 = lean_ctor_get(x_247, 0); +x_398 = lean_ctor_get(x_247, 1); +x_399 = lean_ctor_get(x_247, 3); +x_400 = lean_ctor_get(x_247, 4); +x_401 = lean_ctor_get(x_247, 5); +lean_inc(x_401); +lean_inc(x_400); +lean_inc(x_399); +lean_inc(x_396); +lean_inc(x_398); +lean_inc(x_397); +lean_dec(x_247); +x_402 = lean_ctor_get(x_396, 0); +lean_inc(x_402); +x_403 = lean_ctor_get(x_396, 1); +lean_inc(x_403); +x_404 = lean_ctor_get(x_396, 2); +lean_inc(x_404); +x_405 = lean_ctor_get(x_396, 3); +lean_inc(x_405); +x_406 = lean_ctor_get(x_396, 4); +lean_inc(x_406); +if (lean_is_exclusive(x_396)) { + lean_ctor_release(x_396, 0); + lean_ctor_release(x_396, 1); + lean_ctor_release(x_396, 2); + lean_ctor_release(x_396, 3); + lean_ctor_release(x_396, 4); + x_407 = x_396; } else { - lean_dec_ref(x_379); - x_389 = lean_box(0); + lean_dec_ref(x_396); + x_407 = lean_box(0); } -x_423 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_389)) { - x_424 = lean_alloc_ctor(0, 4, 0); +x_443 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_407)) { + x_444 = lean_alloc_ctor(0, 5, 0); } else { - x_424 = x_389; + x_444 = x_407; } -lean_ctor_set(x_424, 0, x_385); -lean_ctor_set(x_424, 1, x_386); -lean_ctor_set(x_424, 2, x_423); -lean_ctor_set(x_424, 3, x_388); -x_425 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_425, 0, x_380); -lean_ctor_set(x_425, 1, x_381); -lean_ctor_set(x_425, 2, x_424); -lean_ctor_set(x_425, 3, x_382); -lean_ctor_set(x_425, 4, x_383); -lean_ctor_set(x_425, 5, x_384); -x_426 = lean_ctor_get(x_7, 0); -lean_inc(x_426); -x_427 = lean_ctor_get(x_7, 1); -lean_inc(x_427); -x_428 = lean_ctor_get(x_7, 2); -lean_inc(x_428); -x_429 = lean_ctor_get(x_7, 3); -lean_inc(x_429); -x_430 = lean_ctor_get(x_7, 4); -lean_inc(x_430); +lean_ctor_set(x_444, 0, x_402); +lean_ctor_set(x_444, 1, x_403); +lean_ctor_set(x_444, 2, x_443); +lean_ctor_set(x_444, 3, x_405); +lean_ctor_set(x_444, 4, x_406); +x_445 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_445, 0, x_397); +lean_ctor_set(x_445, 1, x_398); +lean_ctor_set(x_445, 2, x_444); +lean_ctor_set(x_445, 3, x_399); +lean_ctor_set(x_445, 4, x_400); +lean_ctor_set(x_445, 5, x_401); +x_446 = lean_ctor_get(x_7, 0); +lean_inc(x_446); +x_447 = lean_ctor_get(x_7, 1); +lean_inc(x_447); +x_448 = lean_ctor_get(x_7, 2); +lean_inc(x_448); +x_449 = lean_ctor_get(x_7, 3); +lean_inc(x_449); +x_450 = lean_ctor_get(x_7, 4); +lean_inc(x_450); if (lean_is_exclusive(x_7)) { lean_ctor_release(x_7, 0); lean_ctor_release(x_7, 1); lean_ctor_release(x_7, 2); lean_ctor_release(x_7, 3); lean_ctor_release(x_7, 4); - x_431 = x_7; + x_451 = x_7; } else { lean_dec_ref(x_7); - x_431 = lean_box(0); + x_451 = lean_box(0); } -x_432 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_432, 0, x_239); -lean_ctor_set(x_432, 1, x_14); -x_433 = lean_array_push(x_428, x_432); -if (lean_is_scalar(x_431)) { - x_434 = lean_alloc_ctor(0, 5, 0); +x_452 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_452, 0, x_249); +lean_ctor_set(x_452, 1, x_14); +x_453 = lean_array_push(x_448, x_452); +if (lean_is_scalar(x_451)) { + x_454 = lean_alloc_ctor(0, 5, 0); } else { - x_434 = x_431; + x_454 = x_451; } -lean_ctor_set(x_434, 0, x_426); -lean_ctor_set(x_434, 1, x_427); -lean_ctor_set(x_434, 2, x_433); -lean_ctor_set(x_434, 3, x_429); -lean_ctor_set(x_434, 4, x_430); -x_435 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_241, x_434, x_425); -if (lean_obj_tag(x_435) == 0) +lean_ctor_set(x_454, 0, x_446); +lean_ctor_set(x_454, 1, x_447); +lean_ctor_set(x_454, 2, x_453); +lean_ctor_set(x_454, 3, x_449); +lean_ctor_set(x_454, 4, x_450); +x_455 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_251, x_454, x_445); +if (lean_obj_tag(x_455) == 0) { -lean_object* x_436; lean_object* x_437; lean_object* x_438; -x_436 = lean_ctor_get(x_435, 0); -lean_inc(x_436); -x_437 = lean_ctor_get(x_435, 1); -lean_inc(x_437); -lean_dec(x_435); -x_438 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_438, 0, x_436); -x_390 = x_438; -x_391 = x_437; -goto block_422; +lean_object* x_456; lean_object* x_457; lean_object* x_458; +x_456 = lean_ctor_get(x_455, 0); +lean_inc(x_456); +x_457 = lean_ctor_get(x_455, 1); +lean_inc(x_457); +lean_dec(x_455); +x_458 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_458, 0, x_456); +x_408 = x_458; +x_409 = x_457; +goto block_442; } else { -lean_object* x_439; lean_object* x_440; lean_object* x_441; -x_439 = lean_ctor_get(x_435, 0); -lean_inc(x_439); -x_440 = lean_ctor_get(x_435, 1); -lean_inc(x_440); -lean_dec(x_435); -x_441 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_441, 0, x_439); -x_390 = x_441; -x_391 = x_440; -goto block_422; +lean_object* x_459; lean_object* x_460; lean_object* x_461; +x_459 = lean_ctor_get(x_455, 0); +lean_inc(x_459); +x_460 = lean_ctor_get(x_455, 1); +lean_inc(x_460); +lean_dec(x_455); +x_461 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_461, 0, x_459); +x_408 = x_461; +x_409 = x_460; +goto block_442; } -block_422: +block_442: { -if (lean_obj_tag(x_390) == 0) +if (lean_obj_tag(x_408) == 0) { -lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; lean_object* x_400; lean_object* x_401; lean_object* x_402; lean_object* x_403; lean_object* x_404; lean_object* x_405; lean_object* x_406; -x_392 = lean_ctor_get(x_391, 2); -lean_inc(x_392); -x_393 = lean_ctor_get(x_390, 0); -lean_inc(x_393); -lean_dec(x_390); -x_394 = lean_ctor_get(x_391, 0); -lean_inc(x_394); -x_395 = lean_ctor_get(x_391, 1); -lean_inc(x_395); -x_396 = lean_ctor_get(x_391, 3); -lean_inc(x_396); -x_397 = lean_ctor_get(x_391, 4); -lean_inc(x_397); -x_398 = lean_ctor_get(x_391, 5); -lean_inc(x_398); -if (lean_is_exclusive(x_391)) { - lean_ctor_release(x_391, 0); - lean_ctor_release(x_391, 1); - lean_ctor_release(x_391, 2); - lean_ctor_release(x_391, 3); - lean_ctor_release(x_391, 4); - lean_ctor_release(x_391, 5); - x_399 = x_391; -} else { - lean_dec_ref(x_391); - x_399 = lean_box(0); -} -x_400 = lean_ctor_get(x_392, 0); -lean_inc(x_400); -x_401 = lean_ctor_get(x_392, 1); -lean_inc(x_401); -x_402 = lean_ctor_get(x_392, 3); -lean_inc(x_402); -if (lean_is_exclusive(x_392)) { - lean_ctor_release(x_392, 0); - lean_ctor_release(x_392, 1); - lean_ctor_release(x_392, 2); - lean_ctor_release(x_392, 3); - x_403 = x_392; -} else { - lean_dec_ref(x_392); - x_403 = lean_box(0); -} -if (lean_is_scalar(x_403)) { - x_404 = lean_alloc_ctor(0, 4, 0); -} else { - x_404 = x_403; -} -lean_ctor_set(x_404, 0, x_400); -lean_ctor_set(x_404, 1, x_401); -lean_ctor_set(x_404, 2, x_387); -lean_ctor_set(x_404, 3, x_402); -if (lean_is_scalar(x_399)) { - x_405 = lean_alloc_ctor(0, 6, 0); -} else { - x_405 = x_399; -} -lean_ctor_set(x_405, 0, x_394); -lean_ctor_set(x_405, 1, x_395); -lean_ctor_set(x_405, 2, x_404); -lean_ctor_set(x_405, 3, x_396); -lean_ctor_set(x_405, 4, x_397); -lean_ctor_set(x_405, 5, x_398); -if (lean_is_scalar(x_238)) { - x_406 = lean_alloc_ctor(1, 2, 0); -} else { - x_406 = x_238; - lean_ctor_set_tag(x_406, 1); -} -lean_ctor_set(x_406, 0, x_393); -lean_ctor_set(x_406, 1, x_405); -return x_406; -} -else -{ -lean_object* x_407; lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_object* x_412; lean_object* x_413; lean_object* x_414; lean_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; -x_407 = lean_ctor_get(x_391, 2); -lean_inc(x_407); -x_408 = lean_ctor_get(x_390, 0); -lean_inc(x_408); -lean_dec(x_390); -x_409 = lean_ctor_get(x_391, 0); -lean_inc(x_409); -x_410 = lean_ctor_get(x_391, 1); +lean_object* x_410; 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_410 = lean_ctor_get(x_409, 2); lean_inc(x_410); -x_411 = lean_ctor_get(x_391, 3); +x_411 = lean_ctor_get(x_408, 0); lean_inc(x_411); -x_412 = lean_ctor_get(x_391, 4); +lean_dec(x_408); +x_412 = lean_ctor_get(x_409, 0); lean_inc(x_412); -x_413 = lean_ctor_get(x_391, 5); +x_413 = lean_ctor_get(x_409, 1); lean_inc(x_413); -if (lean_is_exclusive(x_391)) { - lean_ctor_release(x_391, 0); - lean_ctor_release(x_391, 1); - lean_ctor_release(x_391, 2); - lean_ctor_release(x_391, 3); - lean_ctor_release(x_391, 4); - lean_ctor_release(x_391, 5); - x_414 = x_391; -} else { - lean_dec_ref(x_391); - x_414 = lean_box(0); -} -x_415 = lean_ctor_get(x_407, 0); +x_414 = lean_ctor_get(x_409, 3); +lean_inc(x_414); +x_415 = lean_ctor_get(x_409, 4); lean_inc(x_415); -x_416 = lean_ctor_get(x_407, 1); +x_416 = lean_ctor_get(x_409, 5); lean_inc(x_416); -x_417 = lean_ctor_get(x_407, 3); -lean_inc(x_417); -if (lean_is_exclusive(x_407)) { - lean_ctor_release(x_407, 0); - lean_ctor_release(x_407, 1); - lean_ctor_release(x_407, 2); - lean_ctor_release(x_407, 3); - x_418 = x_407; +if (lean_is_exclusive(x_409)) { + lean_ctor_release(x_409, 0); + lean_ctor_release(x_409, 1); + lean_ctor_release(x_409, 2); + lean_ctor_release(x_409, 3); + lean_ctor_release(x_409, 4); + lean_ctor_release(x_409, 5); + x_417 = x_409; } else { - lean_dec_ref(x_407); - x_418 = lean_box(0); + lean_dec_ref(x_409); + x_417 = lean_box(0); } -if (lean_is_scalar(x_418)) { - x_419 = lean_alloc_ctor(0, 4, 0); +x_418 = lean_ctor_get(x_410, 0); +lean_inc(x_418); +x_419 = lean_ctor_get(x_410, 1); +lean_inc(x_419); +x_420 = lean_ctor_get(x_410, 3); +lean_inc(x_420); +x_421 = lean_ctor_get(x_410, 4); +lean_inc(x_421); +if (lean_is_exclusive(x_410)) { + lean_ctor_release(x_410, 0); + lean_ctor_release(x_410, 1); + lean_ctor_release(x_410, 2); + lean_ctor_release(x_410, 3); + lean_ctor_release(x_410, 4); + x_422 = x_410; } else { - x_419 = x_418; + lean_dec_ref(x_410); + x_422 = lean_box(0); } -lean_ctor_set(x_419, 0, x_415); -lean_ctor_set(x_419, 1, x_416); -lean_ctor_set(x_419, 2, x_387); -lean_ctor_set(x_419, 3, x_417); -if (lean_is_scalar(x_414)) { - x_420 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_422)) { + x_423 = lean_alloc_ctor(0, 5, 0); } else { - x_420 = x_414; + x_423 = x_422; } -lean_ctor_set(x_420, 0, x_409); -lean_ctor_set(x_420, 1, x_410); -lean_ctor_set(x_420, 2, x_419); -lean_ctor_set(x_420, 3, x_411); -lean_ctor_set(x_420, 4, x_412); -lean_ctor_set(x_420, 5, x_413); -if (lean_is_scalar(x_238)) { - x_421 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_423, 0, x_418); +lean_ctor_set(x_423, 1, x_419); +lean_ctor_set(x_423, 2, x_404); +lean_ctor_set(x_423, 3, x_420); +lean_ctor_set(x_423, 4, x_421); +if (lean_is_scalar(x_417)) { + x_424 = lean_alloc_ctor(0, 6, 0); } else { - x_421 = x_238; + x_424 = x_417; } -lean_ctor_set(x_421, 0, x_408); -lean_ctor_set(x_421, 1, x_420); -return x_421; +lean_ctor_set(x_424, 0, x_412); +lean_ctor_set(x_424, 1, x_413); +lean_ctor_set(x_424, 2, x_423); +lean_ctor_set(x_424, 3, x_414); +lean_ctor_set(x_424, 4, x_415); +lean_ctor_set(x_424, 5, x_416); +if (lean_is_scalar(x_248)) { + x_425 = lean_alloc_ctor(1, 2, 0); +} else { + x_425 = x_248; + lean_ctor_set_tag(x_425, 1); +} +lean_ctor_set(x_425, 0, x_411); +lean_ctor_set(x_425, 1, x_424); +return x_425; +} +else +{ +lean_object* x_426; lean_object* x_427; 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; +x_426 = lean_ctor_get(x_409, 2); +lean_inc(x_426); +x_427 = lean_ctor_get(x_408, 0); +lean_inc(x_427); +lean_dec(x_408); +x_428 = lean_ctor_get(x_409, 0); +lean_inc(x_428); +x_429 = lean_ctor_get(x_409, 1); +lean_inc(x_429); +x_430 = lean_ctor_get(x_409, 3); +lean_inc(x_430); +x_431 = lean_ctor_get(x_409, 4); +lean_inc(x_431); +x_432 = lean_ctor_get(x_409, 5); +lean_inc(x_432); +if (lean_is_exclusive(x_409)) { + lean_ctor_release(x_409, 0); + lean_ctor_release(x_409, 1); + lean_ctor_release(x_409, 2); + lean_ctor_release(x_409, 3); + lean_ctor_release(x_409, 4); + lean_ctor_release(x_409, 5); + x_433 = x_409; +} else { + lean_dec_ref(x_409); + x_433 = lean_box(0); +} +x_434 = lean_ctor_get(x_426, 0); +lean_inc(x_434); +x_435 = lean_ctor_get(x_426, 1); +lean_inc(x_435); +x_436 = lean_ctor_get(x_426, 3); +lean_inc(x_436); +x_437 = lean_ctor_get(x_426, 4); +lean_inc(x_437); +if (lean_is_exclusive(x_426)) { + lean_ctor_release(x_426, 0); + lean_ctor_release(x_426, 1); + lean_ctor_release(x_426, 2); + lean_ctor_release(x_426, 3); + lean_ctor_release(x_426, 4); + x_438 = x_426; +} else { + lean_dec_ref(x_426); + x_438 = lean_box(0); +} +if (lean_is_scalar(x_438)) { + x_439 = lean_alloc_ctor(0, 5, 0); +} else { + x_439 = x_438; +} +lean_ctor_set(x_439, 0, x_434); +lean_ctor_set(x_439, 1, x_435); +lean_ctor_set(x_439, 2, x_404); +lean_ctor_set(x_439, 3, x_436); +lean_ctor_set(x_439, 4, x_437); +if (lean_is_scalar(x_433)) { + x_440 = lean_alloc_ctor(0, 6, 0); +} else { + x_440 = x_433; +} +lean_ctor_set(x_440, 0, x_428); +lean_ctor_set(x_440, 1, x_429); +lean_ctor_set(x_440, 2, x_439); +lean_ctor_set(x_440, 3, x_430); +lean_ctor_set(x_440, 4, x_431); +lean_ctor_set(x_440, 5, x_432); +if (lean_is_scalar(x_248)) { + x_441 = lean_alloc_ctor(0, 2, 0); +} else { + x_441 = x_248; +} +lean_ctor_set(x_441, 0, x_427); +lean_ctor_set(x_441, 1, x_440); +return x_441; } } } @@ -31417,29 +32411,29 @@ return x_421; } else { -uint8_t x_442; +uint8_t x_462; lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_442 = !lean_is_exclusive(x_231); -if (x_442 == 0) +x_462 = !lean_is_exclusive(x_241); +if (x_462 == 0) { -return x_231; +return x_241; } else { -lean_object* x_443; lean_object* x_444; lean_object* x_445; -x_443 = lean_ctor_get(x_231, 0); -x_444 = lean_ctor_get(x_231, 1); -lean_inc(x_444); -lean_inc(x_443); -lean_dec(x_231); -x_445 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_445, 0, x_443); -lean_ctor_set(x_445, 1, x_444); -return x_445; +lean_object* x_463; lean_object* x_464; lean_object* x_465; +x_463 = lean_ctor_get(x_241, 0); +x_464 = lean_ctor_get(x_241, 1); +lean_inc(x_464); +lean_inc(x_463); +lean_dec(x_241); +x_465 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_465, 0, x_463); +lean_ctor_set(x_465, 1, x_464); +return x_465; } } } @@ -31447,58 +32441,58 @@ return x_445; } else { -uint8_t x_446; +uint8_t x_466; lean_dec(x_18); lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_446 = !lean_is_exclusive(x_19); -if (x_446 == 0) +x_466 = !lean_is_exclusive(x_19); +if (x_466 == 0) { return x_19; } else { -lean_object* x_447; lean_object* x_448; lean_object* x_449; -x_447 = lean_ctor_get(x_19, 0); -x_448 = lean_ctor_get(x_19, 1); -lean_inc(x_448); -lean_inc(x_447); +lean_object* x_467; lean_object* x_468; lean_object* x_469; +x_467 = lean_ctor_get(x_19, 0); +x_468 = lean_ctor_get(x_19, 1); +lean_inc(x_468); +lean_inc(x_467); lean_dec(x_19); -x_449 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_449, 0, x_447); -lean_ctor_set(x_449, 1, x_448); -return x_449; +x_469 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_469, 0, x_467); +lean_ctor_set(x_469, 1, x_468); +return x_469; } } } else { -uint8_t x_450; +uint8_t x_470; lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_450 = !lean_is_exclusive(x_15); -if (x_450 == 0) +x_470 = !lean_is_exclusive(x_15); +if (x_470 == 0) { return x_15; } else { -lean_object* x_451; lean_object* x_452; lean_object* x_453; -x_451 = lean_ctor_get(x_15, 0); -x_452 = lean_ctor_get(x_15, 1); -lean_inc(x_452); -lean_inc(x_451); +lean_object* x_471; lean_object* x_472; lean_object* x_473; +x_471 = lean_ctor_get(x_15, 0); +x_472 = lean_ctor_get(x_15, 1); +lean_inc(x_472); +lean_inc(x_471); lean_dec(x_15); -x_453 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_453, 0, x_451); -lean_ctor_set(x_453, 1, x_452); -return x_453; +x_473 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_473, 0, x_471); +lean_ctor_set(x_473, 1, x_472); +return x_473; } } } @@ -31644,105 +32638,105 @@ x_37 = lean_ctor_get(x_31, 2); x_38 = !lean_is_exclusive(x_37); if (x_38 == 0) { -lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_91; uint8_t x_92; +lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_95; uint8_t x_96; x_39 = lean_ctor_get(x_37, 2); -x_91 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_37, 2, x_91); -x_92 = !lean_is_exclusive(x_12); -if (x_92 == 0) +x_95 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_37, 2, x_95); +x_96 = !lean_is_exclusive(x_12); +if (x_96 == 0) { -lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; -x_93 = lean_ctor_get(x_12, 2); -x_94 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_94, 0, x_33); -lean_ctor_set(x_94, 1, x_20); -x_95 = lean_array_push(x_93, x_94); -lean_ctor_set(x_12, 2, x_95); -x_96 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_35, x_12, x_31); -if (lean_obj_tag(x_96) == 0) +lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; +x_97 = lean_ctor_get(x_12, 2); +x_98 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_98, 0, x_33); +lean_ctor_set(x_98, 1, x_20); +x_99 = lean_array_push(x_97, x_98); +lean_ctor_set(x_12, 2, x_99); +x_100 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_35, x_12, x_31); +if (lean_obj_tag(x_100) == 0) { -lean_object* x_97; lean_object* x_98; lean_object* x_99; -x_97 = lean_ctor_get(x_96, 0); -lean_inc(x_97); -x_98 = lean_ctor_get(x_96, 1); -lean_inc(x_98); -lean_dec(x_96); -x_99 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_99, 0, x_97); -x_40 = x_99; -x_41 = x_98; -goto block_90; -} -else -{ -lean_object* x_100; lean_object* x_101; lean_object* x_102; -x_100 = lean_ctor_get(x_96, 0); -lean_inc(x_100); -x_101 = lean_ctor_get(x_96, 1); +lean_object* x_101; lean_object* x_102; lean_object* x_103; +x_101 = lean_ctor_get(x_100, 0); lean_inc(x_101); -lean_dec(x_96); -x_102 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_102, 0, x_100); -x_40 = x_102; -x_41 = x_101; -goto block_90; -} +x_102 = lean_ctor_get(x_100, 1); +lean_inc(x_102); +lean_dec(x_100); +x_103 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_103, 0, x_101); +x_40 = x_103; +x_41 = x_102; +goto block_94; } else { -lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; -x_103 = lean_ctor_get(x_12, 0); -x_104 = lean_ctor_get(x_12, 1); -x_105 = lean_ctor_get(x_12, 2); -x_106 = lean_ctor_get(x_12, 3); -x_107 = lean_ctor_get(x_12, 4); -lean_inc(x_107); -lean_inc(x_106); -lean_inc(x_105); +lean_object* x_104; lean_object* x_105; lean_object* x_106; +x_104 = lean_ctor_get(x_100, 0); lean_inc(x_104); -lean_inc(x_103); -lean_dec(x_12); -x_108 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_108, 0, x_33); -lean_ctor_set(x_108, 1, x_20); -x_109 = lean_array_push(x_105, x_108); -x_110 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_110, 0, x_103); -lean_ctor_set(x_110, 1, x_104); -lean_ctor_set(x_110, 2, x_109); -lean_ctor_set(x_110, 3, x_106); -lean_ctor_set(x_110, 4, x_107); -x_111 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_35, x_110, x_31); -if (lean_obj_tag(x_111) == 0) -{ -lean_object* x_112; lean_object* x_113; lean_object* x_114; -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_alloc_ctor(1, 1, 0); -lean_ctor_set(x_114, 0, x_112); -x_40 = x_114; -x_41 = x_113; -goto block_90; +x_105 = lean_ctor_get(x_100, 1); +lean_inc(x_105); +lean_dec(x_100); +x_106 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_106, 0, x_104); +x_40 = x_106; +x_41 = x_105; +goto block_94; +} } else { -lean_object* x_115; lean_object* x_116; lean_object* x_117; -x_115 = lean_ctor_get(x_111, 0); -lean_inc(x_115); -x_116 = lean_ctor_get(x_111, 1); +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; +x_107 = lean_ctor_get(x_12, 0); +x_108 = lean_ctor_get(x_12, 1); +x_109 = lean_ctor_get(x_12, 2); +x_110 = lean_ctor_get(x_12, 3); +x_111 = lean_ctor_get(x_12, 4); +lean_inc(x_111); +lean_inc(x_110); +lean_inc(x_109); +lean_inc(x_108); +lean_inc(x_107); +lean_dec(x_12); +x_112 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_112, 0, x_33); +lean_ctor_set(x_112, 1, x_20); +x_113 = lean_array_push(x_109, x_112); +x_114 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_114, 0, x_107); +lean_ctor_set(x_114, 1, x_108); +lean_ctor_set(x_114, 2, x_113); +lean_ctor_set(x_114, 3, x_110); +lean_ctor_set(x_114, 4, x_111); +x_115 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_35, x_114, x_31); +if (lean_obj_tag(x_115) == 0) +{ +lean_object* x_116; lean_object* x_117; lean_object* x_118; +x_116 = lean_ctor_get(x_115, 0); lean_inc(x_116); -lean_dec(x_111); -x_117 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_117, 0, x_115); -x_40 = x_117; -x_41 = x_116; -goto block_90; +x_117 = lean_ctor_get(x_115, 1); +lean_inc(x_117); +lean_dec(x_115); +x_118 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_118, 0, x_116); +x_40 = x_118; +x_41 = x_117; +goto block_94; +} +else +{ +lean_object* x_119; lean_object* x_120; lean_object* x_121; +x_119 = lean_ctor_get(x_115, 0); +lean_inc(x_119); +x_120 = lean_ctor_get(x_115, 1); +lean_inc(x_120); +lean_dec(x_115); +x_121 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_121, 0, x_119); +x_40 = x_121; +x_41 = x_120; +goto block_94; } } -block_90: +block_94: { if (lean_obj_tag(x_40) == 0) { @@ -31777,1284 +32771,1262 @@ return x_48; } else { -lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; +lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; x_49 = lean_ctor_get(x_42, 0); x_50 = lean_ctor_get(x_42, 1); x_51 = lean_ctor_get(x_42, 3); +x_52 = lean_ctor_get(x_42, 4); +lean_inc(x_52); lean_inc(x_51); lean_inc(x_50); lean_inc(x_49); lean_dec(x_42); -x_52 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_52, 0, x_49); -lean_ctor_set(x_52, 1, x_50); -lean_ctor_set(x_52, 2, x_39); -lean_ctor_set(x_52, 3, x_51); -lean_ctor_set(x_41, 2, x_52); +x_53 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_53, 0, x_49); +lean_ctor_set(x_53, 1, x_50); +lean_ctor_set(x_53, 2, x_39); +lean_ctor_set(x_53, 3, x_51); +lean_ctor_set(x_53, 4, x_52); +lean_ctor_set(x_41, 2, x_53); if (lean_is_scalar(x_32)) { - x_53 = lean_alloc_ctor(1, 2, 0); + x_54 = lean_alloc_ctor(1, 2, 0); } else { - x_53 = x_32; - lean_ctor_set_tag(x_53, 1); + x_54 = x_32; + lean_ctor_set_tag(x_54, 1); } -lean_ctor_set(x_53, 0, x_43); -lean_ctor_set(x_53, 1, x_41); -return x_53; +lean_ctor_set(x_54, 0, x_43); +lean_ctor_set(x_54, 1, x_41); +return x_54; } } else { -lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; -x_54 = lean_ctor_get(x_41, 0); -x_55 = lean_ctor_get(x_41, 1); -x_56 = lean_ctor_get(x_41, 3); -x_57 = lean_ctor_get(x_41, 4); -x_58 = lean_ctor_get(x_41, 5); +lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; +x_55 = lean_ctor_get(x_41, 0); +x_56 = lean_ctor_get(x_41, 1); +x_57 = lean_ctor_get(x_41, 3); +x_58 = lean_ctor_get(x_41, 4); +x_59 = lean_ctor_get(x_41, 5); +lean_inc(x_59); lean_inc(x_58); lean_inc(x_57); lean_inc(x_56); lean_inc(x_55); -lean_inc(x_54); lean_dec(x_41); -x_59 = lean_ctor_get(x_42, 0); -lean_inc(x_59); -x_60 = lean_ctor_get(x_42, 1); +x_60 = lean_ctor_get(x_42, 0); lean_inc(x_60); -x_61 = lean_ctor_get(x_42, 3); +x_61 = lean_ctor_get(x_42, 1); lean_inc(x_61); +x_62 = lean_ctor_get(x_42, 3); +lean_inc(x_62); +x_63 = lean_ctor_get(x_42, 4); +lean_inc(x_63); if (lean_is_exclusive(x_42)) { lean_ctor_release(x_42, 0); lean_ctor_release(x_42, 1); lean_ctor_release(x_42, 2); lean_ctor_release(x_42, 3); - x_62 = x_42; + lean_ctor_release(x_42, 4); + x_64 = x_42; } else { lean_dec_ref(x_42); - x_62 = lean_box(0); + x_64 = lean_box(0); } -if (lean_is_scalar(x_62)) { - x_63 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_64)) { + x_65 = lean_alloc_ctor(0, 5, 0); } else { - x_63 = x_62; + x_65 = x_64; } -lean_ctor_set(x_63, 0, x_59); -lean_ctor_set(x_63, 1, x_60); -lean_ctor_set(x_63, 2, x_39); -lean_ctor_set(x_63, 3, x_61); -x_64 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_64, 0, x_54); -lean_ctor_set(x_64, 1, x_55); -lean_ctor_set(x_64, 2, x_63); -lean_ctor_set(x_64, 3, x_56); -lean_ctor_set(x_64, 4, x_57); -lean_ctor_set(x_64, 5, x_58); +lean_ctor_set(x_65, 0, x_60); +lean_ctor_set(x_65, 1, x_61); +lean_ctor_set(x_65, 2, x_39); +lean_ctor_set(x_65, 3, x_62); +lean_ctor_set(x_65, 4, x_63); +x_66 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_66, 0, x_55); +lean_ctor_set(x_66, 1, x_56); +lean_ctor_set(x_66, 2, x_65); +lean_ctor_set(x_66, 3, x_57); +lean_ctor_set(x_66, 4, x_58); +lean_ctor_set(x_66, 5, x_59); if (lean_is_scalar(x_32)) { - x_65 = lean_alloc_ctor(1, 2, 0); + x_67 = lean_alloc_ctor(1, 2, 0); } else { - x_65 = x_32; - lean_ctor_set_tag(x_65, 1); + x_67 = x_32; + lean_ctor_set_tag(x_67, 1); } -lean_ctor_set(x_65, 0, x_43); -lean_ctor_set(x_65, 1, x_64); -return x_65; +lean_ctor_set(x_67, 0, x_43); +lean_ctor_set(x_67, 1, x_66); +return x_67; } } else { -lean_object* x_66; lean_object* x_67; uint8_t x_68; -x_66 = lean_ctor_get(x_41, 2); -lean_inc(x_66); -x_67 = lean_ctor_get(x_40, 0); -lean_inc(x_67); +lean_object* x_68; lean_object* x_69; uint8_t x_70; +x_68 = lean_ctor_get(x_41, 2); +lean_inc(x_68); +x_69 = lean_ctor_get(x_40, 0); +lean_inc(x_69); lean_dec(x_40); -x_68 = !lean_is_exclusive(x_41); -if (x_68 == 0) -{ -lean_object* x_69; uint8_t x_70; -x_69 = lean_ctor_get(x_41, 2); -lean_dec(x_69); -x_70 = !lean_is_exclusive(x_66); +x_70 = !lean_is_exclusive(x_41); if (x_70 == 0) { -lean_object* x_71; lean_object* x_72; -x_71 = lean_ctor_get(x_66, 2); +lean_object* x_71; uint8_t x_72; +x_71 = lean_ctor_get(x_41, 2); lean_dec(x_71); -lean_ctor_set(x_66, 2, x_39); +x_72 = !lean_is_exclusive(x_68); +if (x_72 == 0) +{ +lean_object* x_73; lean_object* x_74; +x_73 = lean_ctor_get(x_68, 2); +lean_dec(x_73); +lean_ctor_set(x_68, 2, x_39); if (lean_is_scalar(x_32)) { - x_72 = lean_alloc_ctor(0, 2, 0); + x_74 = lean_alloc_ctor(0, 2, 0); } else { - x_72 = x_32; + x_74 = x_32; } -lean_ctor_set(x_72, 0, x_67); -lean_ctor_set(x_72, 1, x_41); -return x_72; +lean_ctor_set(x_74, 0, x_69); +lean_ctor_set(x_74, 1, x_41); +return x_74; } else { -lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; -x_73 = lean_ctor_get(x_66, 0); -x_74 = lean_ctor_get(x_66, 1); -x_75 = lean_ctor_get(x_66, 3); +lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; +x_75 = lean_ctor_get(x_68, 0); +x_76 = lean_ctor_get(x_68, 1); +x_77 = lean_ctor_get(x_68, 3); +x_78 = lean_ctor_get(x_68, 4); +lean_inc(x_78); +lean_inc(x_77); +lean_inc(x_76); lean_inc(x_75); -lean_inc(x_74); -lean_inc(x_73); -lean_dec(x_66); -x_76 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_76, 0, x_73); -lean_ctor_set(x_76, 1, x_74); -lean_ctor_set(x_76, 2, x_39); -lean_ctor_set(x_76, 3, x_75); -lean_ctor_set(x_41, 2, x_76); +lean_dec(x_68); +x_79 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_79, 0, x_75); +lean_ctor_set(x_79, 1, x_76); +lean_ctor_set(x_79, 2, x_39); +lean_ctor_set(x_79, 3, x_77); +lean_ctor_set(x_79, 4, x_78); +lean_ctor_set(x_41, 2, x_79); if (lean_is_scalar(x_32)) { - x_77 = lean_alloc_ctor(0, 2, 0); + x_80 = lean_alloc_ctor(0, 2, 0); } else { - x_77 = x_32; + x_80 = x_32; } -lean_ctor_set(x_77, 0, x_67); -lean_ctor_set(x_77, 1, x_41); -return x_77; +lean_ctor_set(x_80, 0, x_69); +lean_ctor_set(x_80, 1, x_41); +return x_80; } } else { -lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; -x_78 = lean_ctor_get(x_41, 0); -x_79 = lean_ctor_get(x_41, 1); -x_80 = lean_ctor_get(x_41, 3); -x_81 = lean_ctor_get(x_41, 4); -x_82 = lean_ctor_get(x_41, 5); +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; +x_81 = lean_ctor_get(x_41, 0); +x_82 = lean_ctor_get(x_41, 1); +x_83 = lean_ctor_get(x_41, 3); +x_84 = lean_ctor_get(x_41, 4); +x_85 = lean_ctor_get(x_41, 5); +lean_inc(x_85); +lean_inc(x_84); +lean_inc(x_83); lean_inc(x_82); lean_inc(x_81); -lean_inc(x_80); -lean_inc(x_79); -lean_inc(x_78); lean_dec(x_41); -x_83 = lean_ctor_get(x_66, 0); -lean_inc(x_83); -x_84 = lean_ctor_get(x_66, 1); -lean_inc(x_84); -x_85 = lean_ctor_get(x_66, 3); -lean_inc(x_85); -if (lean_is_exclusive(x_66)) { - lean_ctor_release(x_66, 0); - lean_ctor_release(x_66, 1); - lean_ctor_release(x_66, 2); - lean_ctor_release(x_66, 3); - x_86 = x_66; +x_86 = lean_ctor_get(x_68, 0); +lean_inc(x_86); +x_87 = lean_ctor_get(x_68, 1); +lean_inc(x_87); +x_88 = lean_ctor_get(x_68, 3); +lean_inc(x_88); +x_89 = lean_ctor_get(x_68, 4); +lean_inc(x_89); +if (lean_is_exclusive(x_68)) { + lean_ctor_release(x_68, 0); + lean_ctor_release(x_68, 1); + lean_ctor_release(x_68, 2); + lean_ctor_release(x_68, 3); + lean_ctor_release(x_68, 4); + x_90 = x_68; } else { - lean_dec_ref(x_66); - x_86 = lean_box(0); + lean_dec_ref(x_68); + x_90 = lean_box(0); } -if (lean_is_scalar(x_86)) { - x_87 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_90)) { + x_91 = lean_alloc_ctor(0, 5, 0); } else { - x_87 = x_86; + x_91 = x_90; } -lean_ctor_set(x_87, 0, x_83); -lean_ctor_set(x_87, 1, x_84); -lean_ctor_set(x_87, 2, x_39); -lean_ctor_set(x_87, 3, x_85); -x_88 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_88, 0, x_78); -lean_ctor_set(x_88, 1, x_79); -lean_ctor_set(x_88, 2, x_87); -lean_ctor_set(x_88, 3, x_80); -lean_ctor_set(x_88, 4, x_81); -lean_ctor_set(x_88, 5, x_82); +lean_ctor_set(x_91, 0, x_86); +lean_ctor_set(x_91, 1, x_87); +lean_ctor_set(x_91, 2, x_39); +lean_ctor_set(x_91, 3, x_88); +lean_ctor_set(x_91, 4, x_89); +x_92 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_92, 0, x_81); +lean_ctor_set(x_92, 1, x_82); +lean_ctor_set(x_92, 2, x_91); +lean_ctor_set(x_92, 3, x_83); +lean_ctor_set(x_92, 4, x_84); +lean_ctor_set(x_92, 5, x_85); if (lean_is_scalar(x_32)) { - x_89 = lean_alloc_ctor(0, 2, 0); + x_93 = lean_alloc_ctor(0, 2, 0); } else { - x_89 = x_32; + x_93 = x_32; } -lean_ctor_set(x_89, 0, x_67); -lean_ctor_set(x_89, 1, x_88); -return x_89; +lean_ctor_set(x_93, 0, x_69); +lean_ctor_set(x_93, 1, x_92); +return x_93; } } } } else { -lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_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; -x_118 = lean_ctor_get(x_37, 0); -x_119 = lean_ctor_get(x_37, 1); -x_120 = lean_ctor_get(x_37, 2); -x_121 = lean_ctor_get(x_37, 3); -lean_inc(x_121); -lean_inc(x_120); -lean_inc(x_119); -lean_inc(x_118); -lean_dec(x_37); -x_155 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_156 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_156, 0, x_118); -lean_ctor_set(x_156, 1, x_119); -lean_ctor_set(x_156, 2, x_155); -lean_ctor_set(x_156, 3, x_121); -lean_ctor_set(x_31, 2, x_156); -x_157 = lean_ctor_get(x_12, 0); -lean_inc(x_157); -x_158 = lean_ctor_get(x_12, 1); -lean_inc(x_158); -x_159 = lean_ctor_get(x_12, 2); -lean_inc(x_159); -x_160 = lean_ctor_get(x_12, 3); -lean_inc(x_160); -x_161 = lean_ctor_get(x_12, 4); -lean_inc(x_161); -if (lean_is_exclusive(x_12)) { - lean_ctor_release(x_12, 0); - lean_ctor_release(x_12, 1); - lean_ctor_release(x_12, 2); - lean_ctor_release(x_12, 3); - lean_ctor_release(x_12, 4); - x_162 = x_12; -} else { - lean_dec_ref(x_12); - x_162 = lean_box(0); -} -x_163 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_163, 0, x_33); -lean_ctor_set(x_163, 1, x_20); -x_164 = lean_array_push(x_159, x_163); -if (lean_is_scalar(x_162)) { - x_165 = lean_alloc_ctor(0, 5, 0); -} else { - x_165 = x_162; -} -lean_ctor_set(x_165, 0, x_157); -lean_ctor_set(x_165, 1, x_158); -lean_ctor_set(x_165, 2, x_164); -lean_ctor_set(x_165, 3, x_160); -lean_ctor_set(x_165, 4, x_161); -x_166 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_35, x_165, x_31); -if (lean_obj_tag(x_166) == 0) -{ -lean_object* x_167; lean_object* x_168; lean_object* x_169; -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, 1, 0); -lean_ctor_set(x_169, 0, x_167); -x_122 = x_169; -x_123 = x_168; -goto block_154; -} -else -{ -lean_object* x_170; lean_object* x_171; lean_object* x_172; -x_170 = lean_ctor_get(x_166, 0); -lean_inc(x_170); -x_171 = lean_ctor_get(x_166, 1); -lean_inc(x_171); -lean_dec(x_166); -x_172 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_172, 0, x_170); -x_122 = x_172; -x_123 = x_171; -goto block_154; -} -block_154: -{ -if (lean_obj_tag(x_122) == 0) -{ -lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; -x_124 = lean_ctor_get(x_123, 2); -lean_inc(x_124); -x_125 = lean_ctor_get(x_122, 0); -lean_inc(x_125); -lean_dec(x_122); -x_126 = lean_ctor_get(x_123, 0); +lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; lean_object* x_173; +x_122 = lean_ctor_get(x_37, 0); +x_123 = lean_ctor_get(x_37, 1); +x_124 = lean_ctor_get(x_37, 2); +x_125 = lean_ctor_get(x_37, 3); +x_126 = lean_ctor_get(x_37, 4); lean_inc(x_126); -x_127 = lean_ctor_get(x_123, 1); -lean_inc(x_127); -x_128 = lean_ctor_get(x_123, 3); -lean_inc(x_128); -x_129 = lean_ctor_get(x_123, 4); -lean_inc(x_129); -x_130 = lean_ctor_get(x_123, 5); -lean_inc(x_130); -if (lean_is_exclusive(x_123)) { - lean_ctor_release(x_123, 0); - lean_ctor_release(x_123, 1); - lean_ctor_release(x_123, 2); - lean_ctor_release(x_123, 3); - lean_ctor_release(x_123, 4); - lean_ctor_release(x_123, 5); - x_131 = x_123; -} else { - lean_dec_ref(x_123); - x_131 = lean_box(0); -} -x_132 = lean_ctor_get(x_124, 0); -lean_inc(x_132); -x_133 = lean_ctor_get(x_124, 1); -lean_inc(x_133); -x_134 = lean_ctor_get(x_124, 3); -lean_inc(x_134); -if (lean_is_exclusive(x_124)) { - lean_ctor_release(x_124, 0); - lean_ctor_release(x_124, 1); - lean_ctor_release(x_124, 2); - lean_ctor_release(x_124, 3); - x_135 = x_124; -} else { - lean_dec_ref(x_124); - x_135 = lean_box(0); -} -if (lean_is_scalar(x_135)) { - x_136 = lean_alloc_ctor(0, 4, 0); -} else { - x_136 = x_135; -} -lean_ctor_set(x_136, 0, x_132); -lean_ctor_set(x_136, 1, x_133); -lean_ctor_set(x_136, 2, x_120); -lean_ctor_set(x_136, 3, x_134); -if (lean_is_scalar(x_131)) { - x_137 = lean_alloc_ctor(0, 6, 0); -} else { - x_137 = x_131; -} -lean_ctor_set(x_137, 0, x_126); -lean_ctor_set(x_137, 1, x_127); -lean_ctor_set(x_137, 2, x_136); -lean_ctor_set(x_137, 3, x_128); -lean_ctor_set(x_137, 4, x_129); -lean_ctor_set(x_137, 5, x_130); -if (lean_is_scalar(x_32)) { - x_138 = lean_alloc_ctor(1, 2, 0); -} else { - x_138 = x_32; - lean_ctor_set_tag(x_138, 1); -} -lean_ctor_set(x_138, 0, x_125); -lean_ctor_set(x_138, 1, x_137); -return x_138; -} -else -{ -lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_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; -x_139 = lean_ctor_get(x_123, 2); -lean_inc(x_139); -x_140 = lean_ctor_get(x_122, 0); -lean_inc(x_140); -lean_dec(x_122); -x_141 = lean_ctor_get(x_123, 0); -lean_inc(x_141); -x_142 = lean_ctor_get(x_123, 1); -lean_inc(x_142); -x_143 = lean_ctor_get(x_123, 3); -lean_inc(x_143); -x_144 = lean_ctor_get(x_123, 4); -lean_inc(x_144); -x_145 = lean_ctor_get(x_123, 5); -lean_inc(x_145); -if (lean_is_exclusive(x_123)) { - lean_ctor_release(x_123, 0); - lean_ctor_release(x_123, 1); - lean_ctor_release(x_123, 2); - lean_ctor_release(x_123, 3); - lean_ctor_release(x_123, 4); - lean_ctor_release(x_123, 5); - x_146 = x_123; -} else { - lean_dec_ref(x_123); - x_146 = lean_box(0); -} -x_147 = lean_ctor_get(x_139, 0); -lean_inc(x_147); -x_148 = lean_ctor_get(x_139, 1); -lean_inc(x_148); -x_149 = lean_ctor_get(x_139, 3); -lean_inc(x_149); -if (lean_is_exclusive(x_139)) { - lean_ctor_release(x_139, 0); - lean_ctor_release(x_139, 1); - lean_ctor_release(x_139, 2); - lean_ctor_release(x_139, 3); - x_150 = x_139; -} else { - lean_dec_ref(x_139); - x_150 = lean_box(0); -} -if (lean_is_scalar(x_150)) { - x_151 = lean_alloc_ctor(0, 4, 0); -} else { - x_151 = x_150; -} -lean_ctor_set(x_151, 0, x_147); -lean_ctor_set(x_151, 1, x_148); -lean_ctor_set(x_151, 2, x_120); -lean_ctor_set(x_151, 3, x_149); -if (lean_is_scalar(x_146)) { - x_152 = lean_alloc_ctor(0, 6, 0); -} else { - x_152 = x_146; -} -lean_ctor_set(x_152, 0, x_141); -lean_ctor_set(x_152, 1, x_142); -lean_ctor_set(x_152, 2, x_151); -lean_ctor_set(x_152, 3, x_143); -lean_ctor_set(x_152, 4, x_144); -lean_ctor_set(x_152, 5, x_145); -if (lean_is_scalar(x_32)) { - x_153 = lean_alloc_ctor(0, 2, 0); -} else { - x_153 = x_32; -} -lean_ctor_set(x_153, 0, x_140); -lean_ctor_set(x_153, 1, x_152); -return x_153; -} -} -} -} -else -{ -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; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; lean_object* x_224; lean_object* x_225; lean_object* x_226; lean_object* x_227; lean_object* x_228; lean_object* x_229; -x_173 = lean_ctor_get(x_31, 2); -x_174 = lean_ctor_get(x_31, 0); -x_175 = lean_ctor_get(x_31, 1); -x_176 = lean_ctor_get(x_31, 3); -x_177 = lean_ctor_get(x_31, 4); -x_178 = lean_ctor_get(x_31, 5); -lean_inc(x_178); -lean_inc(x_177); -lean_inc(x_176); -lean_inc(x_173); -lean_inc(x_175); -lean_inc(x_174); -lean_dec(x_31); -x_179 = lean_ctor_get(x_173, 0); -lean_inc(x_179); -x_180 = lean_ctor_get(x_173, 1); -lean_inc(x_180); -x_181 = lean_ctor_get(x_173, 2); -lean_inc(x_181); -x_182 = lean_ctor_get(x_173, 3); -lean_inc(x_182); -if (lean_is_exclusive(x_173)) { - lean_ctor_release(x_173, 0); - lean_ctor_release(x_173, 1); - lean_ctor_release(x_173, 2); - lean_ctor_release(x_173, 3); - x_183 = x_173; -} else { - lean_dec_ref(x_173); - x_183 = lean_box(0); -} -x_217 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_183)) { - x_218 = lean_alloc_ctor(0, 4, 0); -} else { - x_218 = x_183; -} -lean_ctor_set(x_218, 0, x_179); -lean_ctor_set(x_218, 1, x_180); -lean_ctor_set(x_218, 2, x_217); -lean_ctor_set(x_218, 3, x_182); -x_219 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_219, 0, x_174); -lean_ctor_set(x_219, 1, x_175); -lean_ctor_set(x_219, 2, x_218); -lean_ctor_set(x_219, 3, x_176); -lean_ctor_set(x_219, 4, x_177); -lean_ctor_set(x_219, 5, x_178); -x_220 = lean_ctor_get(x_12, 0); -lean_inc(x_220); -x_221 = lean_ctor_get(x_12, 1); -lean_inc(x_221); -x_222 = lean_ctor_get(x_12, 2); -lean_inc(x_222); -x_223 = lean_ctor_get(x_12, 3); -lean_inc(x_223); -x_224 = lean_ctor_get(x_12, 4); -lean_inc(x_224); +lean_inc(x_125); +lean_inc(x_124); +lean_inc(x_123); +lean_inc(x_122); +lean_dec(x_37); +x_162 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_163 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_163, 0, x_122); +lean_ctor_set(x_163, 1, x_123); +lean_ctor_set(x_163, 2, x_162); +lean_ctor_set(x_163, 3, x_125); +lean_ctor_set(x_163, 4, x_126); +lean_ctor_set(x_31, 2, x_163); +x_164 = lean_ctor_get(x_12, 0); +lean_inc(x_164); +x_165 = lean_ctor_get(x_12, 1); +lean_inc(x_165); +x_166 = lean_ctor_get(x_12, 2); +lean_inc(x_166); +x_167 = lean_ctor_get(x_12, 3); +lean_inc(x_167); +x_168 = lean_ctor_get(x_12, 4); +lean_inc(x_168); if (lean_is_exclusive(x_12)) { lean_ctor_release(x_12, 0); lean_ctor_release(x_12, 1); lean_ctor_release(x_12, 2); lean_ctor_release(x_12, 3); lean_ctor_release(x_12, 4); - x_225 = x_12; + x_169 = x_12; } else { lean_dec_ref(x_12); - x_225 = lean_box(0); + x_169 = lean_box(0); } -x_226 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_226, 0, x_33); -lean_ctor_set(x_226, 1, x_20); -x_227 = lean_array_push(x_222, x_226); -if (lean_is_scalar(x_225)) { +x_170 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_170, 0, x_33); +lean_ctor_set(x_170, 1, x_20); +x_171 = lean_array_push(x_166, x_170); +if (lean_is_scalar(x_169)) { + x_172 = lean_alloc_ctor(0, 5, 0); +} else { + x_172 = x_169; +} +lean_ctor_set(x_172, 0, x_164); +lean_ctor_set(x_172, 1, x_165); +lean_ctor_set(x_172, 2, x_171); +lean_ctor_set(x_172, 3, x_167); +lean_ctor_set(x_172, 4, x_168); +x_173 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_35, x_172, x_31); +if (lean_obj_tag(x_173) == 0) +{ +lean_object* x_174; lean_object* x_175; lean_object* x_176; +x_174 = lean_ctor_get(x_173, 0); +lean_inc(x_174); +x_175 = lean_ctor_get(x_173, 1); +lean_inc(x_175); +lean_dec(x_173); +x_176 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_176, 0, x_174); +x_127 = x_176; +x_128 = x_175; +goto block_161; +} +else +{ +lean_object* x_177; lean_object* x_178; lean_object* x_179; +x_177 = lean_ctor_get(x_173, 0); +lean_inc(x_177); +x_178 = lean_ctor_get(x_173, 1); +lean_inc(x_178); +lean_dec(x_173); +x_179 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_179, 0, x_177); +x_127 = x_179; +x_128 = x_178; +goto block_161; +} +block_161: +{ +if (lean_obj_tag(x_127) == 0) +{ +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; +x_129 = lean_ctor_get(x_128, 2); +lean_inc(x_129); +x_130 = lean_ctor_get(x_127, 0); +lean_inc(x_130); +lean_dec(x_127); +x_131 = lean_ctor_get(x_128, 0); +lean_inc(x_131); +x_132 = lean_ctor_get(x_128, 1); +lean_inc(x_132); +x_133 = lean_ctor_get(x_128, 3); +lean_inc(x_133); +x_134 = lean_ctor_get(x_128, 4); +lean_inc(x_134); +x_135 = lean_ctor_get(x_128, 5); +lean_inc(x_135); +if (lean_is_exclusive(x_128)) { + lean_ctor_release(x_128, 0); + lean_ctor_release(x_128, 1); + lean_ctor_release(x_128, 2); + lean_ctor_release(x_128, 3); + lean_ctor_release(x_128, 4); + lean_ctor_release(x_128, 5); + x_136 = x_128; +} else { + lean_dec_ref(x_128); + x_136 = lean_box(0); +} +x_137 = lean_ctor_get(x_129, 0); +lean_inc(x_137); +x_138 = lean_ctor_get(x_129, 1); +lean_inc(x_138); +x_139 = lean_ctor_get(x_129, 3); +lean_inc(x_139); +x_140 = lean_ctor_get(x_129, 4); +lean_inc(x_140); +if (lean_is_exclusive(x_129)) { + lean_ctor_release(x_129, 0); + lean_ctor_release(x_129, 1); + lean_ctor_release(x_129, 2); + lean_ctor_release(x_129, 3); + lean_ctor_release(x_129, 4); + x_141 = x_129; +} else { + lean_dec_ref(x_129); + x_141 = lean_box(0); +} +if (lean_is_scalar(x_141)) { + x_142 = lean_alloc_ctor(0, 5, 0); +} else { + x_142 = x_141; +} +lean_ctor_set(x_142, 0, x_137); +lean_ctor_set(x_142, 1, x_138); +lean_ctor_set(x_142, 2, x_124); +lean_ctor_set(x_142, 3, x_139); +lean_ctor_set(x_142, 4, x_140); +if (lean_is_scalar(x_136)) { + x_143 = lean_alloc_ctor(0, 6, 0); +} else { + x_143 = x_136; +} +lean_ctor_set(x_143, 0, x_131); +lean_ctor_set(x_143, 1, x_132); +lean_ctor_set(x_143, 2, x_142); +lean_ctor_set(x_143, 3, x_133); +lean_ctor_set(x_143, 4, x_134); +lean_ctor_set(x_143, 5, x_135); +if (lean_is_scalar(x_32)) { + x_144 = lean_alloc_ctor(1, 2, 0); +} else { + x_144 = x_32; + lean_ctor_set_tag(x_144, 1); +} +lean_ctor_set(x_144, 0, x_130); +lean_ctor_set(x_144, 1, x_143); +return x_144; +} +else +{ +lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_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; +x_145 = lean_ctor_get(x_128, 2); +lean_inc(x_145); +x_146 = lean_ctor_get(x_127, 0); +lean_inc(x_146); +lean_dec(x_127); +x_147 = lean_ctor_get(x_128, 0); +lean_inc(x_147); +x_148 = lean_ctor_get(x_128, 1); +lean_inc(x_148); +x_149 = lean_ctor_get(x_128, 3); +lean_inc(x_149); +x_150 = lean_ctor_get(x_128, 4); +lean_inc(x_150); +x_151 = lean_ctor_get(x_128, 5); +lean_inc(x_151); +if (lean_is_exclusive(x_128)) { + lean_ctor_release(x_128, 0); + lean_ctor_release(x_128, 1); + lean_ctor_release(x_128, 2); + lean_ctor_release(x_128, 3); + lean_ctor_release(x_128, 4); + lean_ctor_release(x_128, 5); + x_152 = x_128; +} else { + lean_dec_ref(x_128); + x_152 = lean_box(0); +} +x_153 = lean_ctor_get(x_145, 0); +lean_inc(x_153); +x_154 = lean_ctor_get(x_145, 1); +lean_inc(x_154); +x_155 = lean_ctor_get(x_145, 3); +lean_inc(x_155); +x_156 = lean_ctor_get(x_145, 4); +lean_inc(x_156); +if (lean_is_exclusive(x_145)) { + lean_ctor_release(x_145, 0); + lean_ctor_release(x_145, 1); + lean_ctor_release(x_145, 2); + lean_ctor_release(x_145, 3); + lean_ctor_release(x_145, 4); + x_157 = x_145; +} else { + lean_dec_ref(x_145); + x_157 = lean_box(0); +} +if (lean_is_scalar(x_157)) { + x_158 = lean_alloc_ctor(0, 5, 0); +} else { + x_158 = x_157; +} +lean_ctor_set(x_158, 0, x_153); +lean_ctor_set(x_158, 1, x_154); +lean_ctor_set(x_158, 2, x_124); +lean_ctor_set(x_158, 3, x_155); +lean_ctor_set(x_158, 4, x_156); +if (lean_is_scalar(x_152)) { + x_159 = lean_alloc_ctor(0, 6, 0); +} else { + x_159 = x_152; +} +lean_ctor_set(x_159, 0, x_147); +lean_ctor_set(x_159, 1, x_148); +lean_ctor_set(x_159, 2, x_158); +lean_ctor_set(x_159, 3, x_149); +lean_ctor_set(x_159, 4, x_150); +lean_ctor_set(x_159, 5, x_151); +if (lean_is_scalar(x_32)) { + x_160 = lean_alloc_ctor(0, 2, 0); +} else { + x_160 = x_32; +} +lean_ctor_set(x_160, 0, x_146); +lean_ctor_set(x_160, 1, x_159); +return x_160; +} +} +} +} +else +{ +lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; 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_227; lean_object* x_228; lean_object* x_229; lean_object* x_230; lean_object* x_231; lean_object* x_232; lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_object* x_236; lean_object* x_237; lean_object* x_238; lean_object* x_239; +x_180 = lean_ctor_get(x_31, 2); +x_181 = lean_ctor_get(x_31, 0); +x_182 = lean_ctor_get(x_31, 1); +x_183 = lean_ctor_get(x_31, 3); +x_184 = lean_ctor_get(x_31, 4); +x_185 = lean_ctor_get(x_31, 5); +lean_inc(x_185); +lean_inc(x_184); +lean_inc(x_183); +lean_inc(x_180); +lean_inc(x_182); +lean_inc(x_181); +lean_dec(x_31); +x_186 = lean_ctor_get(x_180, 0); +lean_inc(x_186); +x_187 = lean_ctor_get(x_180, 1); +lean_inc(x_187); +x_188 = lean_ctor_get(x_180, 2); +lean_inc(x_188); +x_189 = lean_ctor_get(x_180, 3); +lean_inc(x_189); +x_190 = lean_ctor_get(x_180, 4); +lean_inc(x_190); +if (lean_is_exclusive(x_180)) { + lean_ctor_release(x_180, 0); + lean_ctor_release(x_180, 1); + lean_ctor_release(x_180, 2); + lean_ctor_release(x_180, 3); + lean_ctor_release(x_180, 4); + x_191 = x_180; +} else { + lean_dec_ref(x_180); + x_191 = lean_box(0); +} +x_227 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_191)) { x_228 = lean_alloc_ctor(0, 5, 0); } else { - x_228 = x_225; + x_228 = x_191; } -lean_ctor_set(x_228, 0, x_220); -lean_ctor_set(x_228, 1, x_221); +lean_ctor_set(x_228, 0, x_186); +lean_ctor_set(x_228, 1, x_187); lean_ctor_set(x_228, 2, x_227); -lean_ctor_set(x_228, 3, x_223); -lean_ctor_set(x_228, 4, x_224); -x_229 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_35, x_228, x_219); -if (lean_obj_tag(x_229) == 0) -{ -lean_object* x_230; lean_object* x_231; lean_object* x_232; -x_230 = lean_ctor_get(x_229, 0); +lean_ctor_set(x_228, 3, x_189); +lean_ctor_set(x_228, 4, x_190); +x_229 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_229, 0, x_181); +lean_ctor_set(x_229, 1, x_182); +lean_ctor_set(x_229, 2, x_228); +lean_ctor_set(x_229, 3, x_183); +lean_ctor_set(x_229, 4, x_184); +lean_ctor_set(x_229, 5, x_185); +x_230 = lean_ctor_get(x_12, 0); lean_inc(x_230); -x_231 = lean_ctor_get(x_229, 1); +x_231 = lean_ctor_get(x_12, 1); lean_inc(x_231); -lean_dec(x_229); -x_232 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_232, 0, x_230); -x_184 = x_232; -x_185 = x_231; -goto block_216; -} -else -{ -lean_object* x_233; lean_object* x_234; lean_object* x_235; -x_233 = lean_ctor_get(x_229, 0); +x_232 = lean_ctor_get(x_12, 2); +lean_inc(x_232); +x_233 = lean_ctor_get(x_12, 3); lean_inc(x_233); -x_234 = lean_ctor_get(x_229, 1); +x_234 = lean_ctor_get(x_12, 4); lean_inc(x_234); -lean_dec(x_229); -x_235 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_235, 0, x_233); -x_184 = x_235; -x_185 = x_234; -goto block_216; +if (lean_is_exclusive(x_12)) { + lean_ctor_release(x_12, 0); + lean_ctor_release(x_12, 1); + lean_ctor_release(x_12, 2); + lean_ctor_release(x_12, 3); + lean_ctor_release(x_12, 4); + x_235 = x_12; +} else { + lean_dec_ref(x_12); + x_235 = lean_box(0); } -block_216: +x_236 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_236, 0, x_33); +lean_ctor_set(x_236, 1, x_20); +x_237 = lean_array_push(x_232, x_236); +if (lean_is_scalar(x_235)) { + x_238 = lean_alloc_ctor(0, 5, 0); +} else { + x_238 = x_235; +} +lean_ctor_set(x_238, 0, x_230); +lean_ctor_set(x_238, 1, x_231); +lean_ctor_set(x_238, 2, x_237); +lean_ctor_set(x_238, 3, x_233); +lean_ctor_set(x_238, 4, x_234); +x_239 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_35, x_238, x_229); +if (lean_obj_tag(x_239) == 0) { -if (lean_obj_tag(x_184) == 0) -{ -lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; -x_186 = lean_ctor_get(x_185, 2); -lean_inc(x_186); -x_187 = lean_ctor_get(x_184, 0); -lean_inc(x_187); -lean_dec(x_184); -x_188 = lean_ctor_get(x_185, 0); -lean_inc(x_188); -x_189 = lean_ctor_get(x_185, 1); -lean_inc(x_189); -x_190 = lean_ctor_get(x_185, 3); -lean_inc(x_190); -x_191 = lean_ctor_get(x_185, 4); -lean_inc(x_191); -x_192 = lean_ctor_get(x_185, 5); -lean_inc(x_192); -if (lean_is_exclusive(x_185)) { - lean_ctor_release(x_185, 0); - lean_ctor_release(x_185, 1); - lean_ctor_release(x_185, 2); - lean_ctor_release(x_185, 3); - lean_ctor_release(x_185, 4); - lean_ctor_release(x_185, 5); - x_193 = x_185; -} else { - lean_dec_ref(x_185); - x_193 = lean_box(0); -} -x_194 = lean_ctor_get(x_186, 0); -lean_inc(x_194); -x_195 = lean_ctor_get(x_186, 1); -lean_inc(x_195); -x_196 = lean_ctor_get(x_186, 3); -lean_inc(x_196); -if (lean_is_exclusive(x_186)) { - lean_ctor_release(x_186, 0); - lean_ctor_release(x_186, 1); - lean_ctor_release(x_186, 2); - lean_ctor_release(x_186, 3); - x_197 = x_186; -} else { - lean_dec_ref(x_186); - x_197 = lean_box(0); -} -if (lean_is_scalar(x_197)) { - x_198 = lean_alloc_ctor(0, 4, 0); -} else { - x_198 = x_197; -} -lean_ctor_set(x_198, 0, x_194); -lean_ctor_set(x_198, 1, x_195); -lean_ctor_set(x_198, 2, x_181); -lean_ctor_set(x_198, 3, x_196); -if (lean_is_scalar(x_193)) { - x_199 = lean_alloc_ctor(0, 6, 0); -} else { - x_199 = x_193; -} -lean_ctor_set(x_199, 0, x_188); -lean_ctor_set(x_199, 1, x_189); -lean_ctor_set(x_199, 2, x_198); -lean_ctor_set(x_199, 3, x_190); -lean_ctor_set(x_199, 4, x_191); -lean_ctor_set(x_199, 5, x_192); -if (lean_is_scalar(x_32)) { - x_200 = lean_alloc_ctor(1, 2, 0); -} else { - x_200 = x_32; - lean_ctor_set_tag(x_200, 1); -} -lean_ctor_set(x_200, 0, x_187); -lean_ctor_set(x_200, 1, x_199); -return x_200; +lean_object* x_240; lean_object* x_241; lean_object* x_242; +x_240 = lean_ctor_get(x_239, 0); +lean_inc(x_240); +x_241 = lean_ctor_get(x_239, 1); +lean_inc(x_241); +lean_dec(x_239); +x_242 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_242, 0, x_240); +x_192 = x_242; +x_193 = x_241; +goto block_226; } else { -lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; -x_201 = lean_ctor_get(x_185, 2); -lean_inc(x_201); -x_202 = lean_ctor_get(x_184, 0); +lean_object* x_243; lean_object* x_244; lean_object* x_245; +x_243 = lean_ctor_get(x_239, 0); +lean_inc(x_243); +x_244 = lean_ctor_get(x_239, 1); +lean_inc(x_244); +lean_dec(x_239); +x_245 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_245, 0, x_243); +x_192 = x_245; +x_193 = x_244; +goto block_226; +} +block_226: +{ +if (lean_obj_tag(x_192) == 0) +{ +lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; +x_194 = lean_ctor_get(x_193, 2); +lean_inc(x_194); +x_195 = lean_ctor_get(x_192, 0); +lean_inc(x_195); +lean_dec(x_192); +x_196 = lean_ctor_get(x_193, 0); +lean_inc(x_196); +x_197 = lean_ctor_get(x_193, 1); +lean_inc(x_197); +x_198 = lean_ctor_get(x_193, 3); +lean_inc(x_198); +x_199 = lean_ctor_get(x_193, 4); +lean_inc(x_199); +x_200 = lean_ctor_get(x_193, 5); +lean_inc(x_200); +if (lean_is_exclusive(x_193)) { + lean_ctor_release(x_193, 0); + lean_ctor_release(x_193, 1); + lean_ctor_release(x_193, 2); + lean_ctor_release(x_193, 3); + lean_ctor_release(x_193, 4); + lean_ctor_release(x_193, 5); + x_201 = x_193; +} else { + lean_dec_ref(x_193); + x_201 = lean_box(0); +} +x_202 = lean_ctor_get(x_194, 0); lean_inc(x_202); -lean_dec(x_184); -x_203 = lean_ctor_get(x_185, 0); +x_203 = lean_ctor_get(x_194, 1); lean_inc(x_203); -x_204 = lean_ctor_get(x_185, 1); +x_204 = lean_ctor_get(x_194, 3); lean_inc(x_204); -x_205 = lean_ctor_get(x_185, 3); +x_205 = lean_ctor_get(x_194, 4); lean_inc(x_205); -x_206 = lean_ctor_get(x_185, 4); -lean_inc(x_206); -x_207 = lean_ctor_get(x_185, 5); -lean_inc(x_207); -if (lean_is_exclusive(x_185)) { - lean_ctor_release(x_185, 0); - lean_ctor_release(x_185, 1); - lean_ctor_release(x_185, 2); - lean_ctor_release(x_185, 3); - lean_ctor_release(x_185, 4); - lean_ctor_release(x_185, 5); - x_208 = x_185; +if (lean_is_exclusive(x_194)) { + lean_ctor_release(x_194, 0); + lean_ctor_release(x_194, 1); + lean_ctor_release(x_194, 2); + lean_ctor_release(x_194, 3); + lean_ctor_release(x_194, 4); + x_206 = x_194; } else { - lean_dec_ref(x_185); - x_208 = lean_box(0); + lean_dec_ref(x_194); + x_206 = lean_box(0); } -x_209 = lean_ctor_get(x_201, 0); -lean_inc(x_209); -x_210 = lean_ctor_get(x_201, 1); -lean_inc(x_210); -x_211 = lean_ctor_get(x_201, 3); -lean_inc(x_211); -if (lean_is_exclusive(x_201)) { - lean_ctor_release(x_201, 0); - lean_ctor_release(x_201, 1); - lean_ctor_release(x_201, 2); - lean_ctor_release(x_201, 3); - x_212 = x_201; +if (lean_is_scalar(x_206)) { + x_207 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_201); - x_212 = lean_box(0); + x_207 = x_206; } -if (lean_is_scalar(x_212)) { - x_213 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_207, 0, x_202); +lean_ctor_set(x_207, 1, x_203); +lean_ctor_set(x_207, 2, x_188); +lean_ctor_set(x_207, 3, x_204); +lean_ctor_set(x_207, 4, x_205); +if (lean_is_scalar(x_201)) { + x_208 = lean_alloc_ctor(0, 6, 0); } else { - x_213 = x_212; + x_208 = x_201; } -lean_ctor_set(x_213, 0, x_209); -lean_ctor_set(x_213, 1, x_210); -lean_ctor_set(x_213, 2, x_181); -lean_ctor_set(x_213, 3, x_211); -if (lean_is_scalar(x_208)) { - x_214 = lean_alloc_ctor(0, 6, 0); -} else { - x_214 = x_208; -} -lean_ctor_set(x_214, 0, x_203); -lean_ctor_set(x_214, 1, x_204); -lean_ctor_set(x_214, 2, x_213); -lean_ctor_set(x_214, 3, x_205); -lean_ctor_set(x_214, 4, x_206); -lean_ctor_set(x_214, 5, x_207); +lean_ctor_set(x_208, 0, x_196); +lean_ctor_set(x_208, 1, x_197); +lean_ctor_set(x_208, 2, x_207); +lean_ctor_set(x_208, 3, x_198); +lean_ctor_set(x_208, 4, x_199); +lean_ctor_set(x_208, 5, x_200); if (lean_is_scalar(x_32)) { - x_215 = lean_alloc_ctor(0, 2, 0); + x_209 = lean_alloc_ctor(1, 2, 0); } else { - x_215 = x_32; + x_209 = x_32; + lean_ctor_set_tag(x_209, 1); } -lean_ctor_set(x_215, 0, x_202); -lean_ctor_set(x_215, 1, x_214); -return x_215; +lean_ctor_set(x_209, 0, x_195); +lean_ctor_set(x_209, 1, x_208); +return x_209; +} +else +{ +lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; lean_object* x_224; lean_object* x_225; +x_210 = lean_ctor_get(x_193, 2); +lean_inc(x_210); +x_211 = lean_ctor_get(x_192, 0); +lean_inc(x_211); +lean_dec(x_192); +x_212 = lean_ctor_get(x_193, 0); +lean_inc(x_212); +x_213 = lean_ctor_get(x_193, 1); +lean_inc(x_213); +x_214 = lean_ctor_get(x_193, 3); +lean_inc(x_214); +x_215 = lean_ctor_get(x_193, 4); +lean_inc(x_215); +x_216 = lean_ctor_get(x_193, 5); +lean_inc(x_216); +if (lean_is_exclusive(x_193)) { + lean_ctor_release(x_193, 0); + lean_ctor_release(x_193, 1); + lean_ctor_release(x_193, 2); + lean_ctor_release(x_193, 3); + lean_ctor_release(x_193, 4); + lean_ctor_release(x_193, 5); + x_217 = x_193; +} else { + lean_dec_ref(x_193); + x_217 = lean_box(0); +} +x_218 = lean_ctor_get(x_210, 0); +lean_inc(x_218); +x_219 = lean_ctor_get(x_210, 1); +lean_inc(x_219); +x_220 = lean_ctor_get(x_210, 3); +lean_inc(x_220); +x_221 = lean_ctor_get(x_210, 4); +lean_inc(x_221); +if (lean_is_exclusive(x_210)) { + lean_ctor_release(x_210, 0); + lean_ctor_release(x_210, 1); + lean_ctor_release(x_210, 2); + lean_ctor_release(x_210, 3); + lean_ctor_release(x_210, 4); + x_222 = x_210; +} else { + lean_dec_ref(x_210); + x_222 = lean_box(0); +} +if (lean_is_scalar(x_222)) { + x_223 = lean_alloc_ctor(0, 5, 0); +} else { + x_223 = x_222; +} +lean_ctor_set(x_223, 0, x_218); +lean_ctor_set(x_223, 1, x_219); +lean_ctor_set(x_223, 2, x_188); +lean_ctor_set(x_223, 3, x_220); +lean_ctor_set(x_223, 4, x_221); +if (lean_is_scalar(x_217)) { + x_224 = lean_alloc_ctor(0, 6, 0); +} else { + x_224 = x_217; +} +lean_ctor_set(x_224, 0, x_212); +lean_ctor_set(x_224, 1, x_213); +lean_ctor_set(x_224, 2, x_223); +lean_ctor_set(x_224, 3, x_214); +lean_ctor_set(x_224, 4, x_215); +lean_ctor_set(x_224, 5, x_216); +if (lean_is_scalar(x_32)) { + x_225 = lean_alloc_ctor(0, 2, 0); +} else { + x_225 = x_32; +} +lean_ctor_set(x_225, 0, x_211); +lean_ctor_set(x_225, 1, x_224); +return x_225; } } } } default: { -lean_object* x_236; lean_object* x_237; -x_236 = lean_ctor_get(x_25, 1); -lean_inc(x_236); +lean_object* x_246; lean_object* x_247; +x_246 = lean_ctor_get(x_25, 1); +lean_inc(x_246); lean_dec(x_25); lean_inc(x_12); -x_237 = l_Lean_Meta_isClassExpensive___main(x_24, x_12, x_236); -if (lean_obj_tag(x_237) == 0) +x_247 = l_Lean_Meta_isClassExpensive___main(x_24, x_12, x_246); +if (lean_obj_tag(x_247) == 0) { -lean_object* x_238; -x_238 = lean_ctor_get(x_237, 0); -lean_inc(x_238); -if (lean_obj_tag(x_238) == 0) +lean_object* x_248; +x_248 = lean_ctor_get(x_247, 0); +lean_inc(x_248); +if (lean_obj_tag(x_248) == 0) { -lean_object* x_239; lean_object* x_240; lean_object* x_241; +lean_object* x_249; lean_object* x_250; lean_object* x_251; lean_dec(x_20); -x_239 = lean_ctor_get(x_237, 1); -lean_inc(x_239); -lean_dec(x_237); -x_240 = lean_unsigned_to_nat(1u); -x_241 = lean_nat_add(x_11, x_240); +x_249 = lean_ctor_get(x_247, 1); +lean_inc(x_249); +lean_dec(x_247); +x_250 = lean_unsigned_to_nat(1u); +x_251 = lean_nat_add(x_11, x_250); lean_dec(x_11); -x_11 = x_241; -x_13 = x_239; +x_11 = x_251; +x_13 = x_249; goto _start; } else { -lean_object* x_243; lean_object* x_244; lean_object* x_245; lean_object* x_246; lean_object* x_247; uint8_t x_248; -x_243 = lean_ctor_get(x_237, 1); -lean_inc(x_243); -if (lean_is_exclusive(x_237)) { - lean_ctor_release(x_237, 0); - lean_ctor_release(x_237, 1); - x_244 = x_237; +lean_object* x_253; lean_object* x_254; lean_object* x_255; lean_object* x_256; lean_object* x_257; uint8_t x_258; +x_253 = lean_ctor_get(x_247, 1); +lean_inc(x_253); +if (lean_is_exclusive(x_247)) { + lean_ctor_release(x_247, 0); + lean_ctor_release(x_247, 1); + x_254 = x_247; } else { - lean_dec_ref(x_237); - x_244 = lean_box(0); + lean_dec_ref(x_247); + x_254 = lean_box(0); } -x_245 = lean_ctor_get(x_238, 0); -lean_inc(x_245); -lean_dec(x_238); -x_246 = lean_unsigned_to_nat(1u); -x_247 = lean_nat_add(x_11, x_246); -lean_dec(x_11); -x_248 = !lean_is_exclusive(x_243); -if (x_248 == 0) -{ -lean_object* x_249; uint8_t x_250; -x_249 = lean_ctor_get(x_243, 2); -x_250 = !lean_is_exclusive(x_249); -if (x_250 == 0) -{ -lean_object* x_251; lean_object* x_252; lean_object* x_253; lean_object* x_303; uint8_t x_304; -x_251 = lean_ctor_get(x_249, 2); -x_303 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_249, 2, x_303); -x_304 = !lean_is_exclusive(x_12); -if (x_304 == 0) -{ -lean_object* x_305; lean_object* x_306; lean_object* x_307; lean_object* x_308; -x_305 = lean_ctor_get(x_12, 2); -x_306 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_306, 0, x_245); -lean_ctor_set(x_306, 1, x_20); -x_307 = lean_array_push(x_305, x_306); -lean_ctor_set(x_12, 2, x_307); -x_308 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_247, x_12, x_243); -if (lean_obj_tag(x_308) == 0) -{ -lean_object* x_309; lean_object* x_310; lean_object* x_311; -x_309 = lean_ctor_get(x_308, 0); -lean_inc(x_309); -x_310 = lean_ctor_get(x_308, 1); -lean_inc(x_310); -lean_dec(x_308); -x_311 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_311, 0, x_309); -x_252 = x_311; -x_253 = x_310; -goto block_302; -} -else -{ -lean_object* x_312; lean_object* x_313; lean_object* x_314; -x_312 = lean_ctor_get(x_308, 0); -lean_inc(x_312); -x_313 = lean_ctor_get(x_308, 1); -lean_inc(x_313); -lean_dec(x_308); -x_314 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_314, 0, x_312); -x_252 = x_314; -x_253 = x_313; -goto block_302; -} -} -else -{ -lean_object* x_315; lean_object* x_316; lean_object* x_317; lean_object* x_318; lean_object* x_319; lean_object* x_320; lean_object* x_321; lean_object* x_322; lean_object* x_323; -x_315 = lean_ctor_get(x_12, 0); -x_316 = lean_ctor_get(x_12, 1); -x_317 = lean_ctor_get(x_12, 2); -x_318 = lean_ctor_get(x_12, 3); -x_319 = lean_ctor_get(x_12, 4); -lean_inc(x_319); -lean_inc(x_318); -lean_inc(x_317); -lean_inc(x_316); -lean_inc(x_315); -lean_dec(x_12); -x_320 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_320, 0, x_245); -lean_ctor_set(x_320, 1, x_20); -x_321 = lean_array_push(x_317, x_320); -x_322 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_322, 0, x_315); -lean_ctor_set(x_322, 1, x_316); -lean_ctor_set(x_322, 2, x_321); -lean_ctor_set(x_322, 3, x_318); -lean_ctor_set(x_322, 4, x_319); -x_323 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_247, x_322, x_243); -if (lean_obj_tag(x_323) == 0) -{ -lean_object* x_324; lean_object* x_325; lean_object* x_326; -x_324 = lean_ctor_get(x_323, 0); -lean_inc(x_324); -x_325 = lean_ctor_get(x_323, 1); -lean_inc(x_325); -lean_dec(x_323); -x_326 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_326, 0, x_324); -x_252 = x_326; -x_253 = x_325; -goto block_302; -} -else -{ -lean_object* x_327; lean_object* x_328; lean_object* x_329; -x_327 = lean_ctor_get(x_323, 0); -lean_inc(x_327); -x_328 = lean_ctor_get(x_323, 1); -lean_inc(x_328); -lean_dec(x_323); -x_329 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_329, 0, x_327); -x_252 = x_329; -x_253 = x_328; -goto block_302; -} -} -block_302: -{ -if (lean_obj_tag(x_252) == 0) -{ -lean_object* x_254; lean_object* x_255; uint8_t x_256; -x_254 = lean_ctor_get(x_253, 2); -lean_inc(x_254); -x_255 = lean_ctor_get(x_252, 0); +x_255 = lean_ctor_get(x_248, 0); lean_inc(x_255); -lean_dec(x_252); -x_256 = !lean_is_exclusive(x_253); -if (x_256 == 0) -{ -lean_object* x_257; uint8_t x_258; -x_257 = lean_ctor_get(x_253, 2); -lean_dec(x_257); -x_258 = !lean_is_exclusive(x_254); +lean_dec(x_248); +x_256 = lean_unsigned_to_nat(1u); +x_257 = lean_nat_add(x_11, x_256); +lean_dec(x_11); +x_258 = !lean_is_exclusive(x_253); if (x_258 == 0) { -lean_object* x_259; lean_object* x_260; -x_259 = lean_ctor_get(x_254, 2); -lean_dec(x_259); -lean_ctor_set(x_254, 2, x_251); -if (lean_is_scalar(x_244)) { - x_260 = lean_alloc_ctor(1, 2, 0); -} else { - x_260 = x_244; - lean_ctor_set_tag(x_260, 1); -} -lean_ctor_set(x_260, 0, x_255); -lean_ctor_set(x_260, 1, x_253); -return x_260; +lean_object* x_259; uint8_t x_260; +x_259 = lean_ctor_get(x_253, 2); +x_260 = !lean_is_exclusive(x_259); +if (x_260 == 0) +{ +lean_object* x_261; lean_object* x_262; lean_object* x_263; lean_object* x_317; uint8_t x_318; +x_261 = lean_ctor_get(x_259, 2); +x_317 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_259, 2, x_317); +x_318 = !lean_is_exclusive(x_12); +if (x_318 == 0) +{ +lean_object* x_319; lean_object* x_320; lean_object* x_321; lean_object* x_322; +x_319 = lean_ctor_get(x_12, 2); +x_320 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_320, 0, x_255); +lean_ctor_set(x_320, 1, x_20); +x_321 = lean_array_push(x_319, x_320); +lean_ctor_set(x_12, 2, x_321); +x_322 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_257, x_12, x_253); +if (lean_obj_tag(x_322) == 0) +{ +lean_object* x_323; lean_object* x_324; lean_object* x_325; +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_alloc_ctor(1, 1, 0); +lean_ctor_set(x_325, 0, x_323); +x_262 = x_325; +x_263 = x_324; +goto block_316; } else { -lean_object* x_261; lean_object* x_262; lean_object* x_263; lean_object* x_264; lean_object* x_265; -x_261 = lean_ctor_get(x_254, 0); -x_262 = lean_ctor_get(x_254, 1); -x_263 = lean_ctor_get(x_254, 3); -lean_inc(x_263); -lean_inc(x_262); -lean_inc(x_261); -lean_dec(x_254); -x_264 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_264, 0, x_261); -lean_ctor_set(x_264, 1, x_262); -lean_ctor_set(x_264, 2, x_251); -lean_ctor_set(x_264, 3, x_263); -lean_ctor_set(x_253, 2, x_264); -if (lean_is_scalar(x_244)) { - x_265 = lean_alloc_ctor(1, 2, 0); -} else { - x_265 = x_244; - lean_ctor_set_tag(x_265, 1); -} -lean_ctor_set(x_265, 0, x_255); -lean_ctor_set(x_265, 1, x_253); -return x_265; +lean_object* x_326; lean_object* x_327; lean_object* x_328; +x_326 = lean_ctor_get(x_322, 0); +lean_inc(x_326); +x_327 = lean_ctor_get(x_322, 1); +lean_inc(x_327); +lean_dec(x_322); +x_328 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_328, 0, x_326); +x_262 = x_328; +x_263 = x_327; +goto block_316; } } else { -lean_object* x_266; lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_object* x_270; lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_object* x_276; lean_object* x_277; -x_266 = lean_ctor_get(x_253, 0); -x_267 = lean_ctor_get(x_253, 1); -x_268 = lean_ctor_get(x_253, 3); -x_269 = lean_ctor_get(x_253, 4); -x_270 = lean_ctor_get(x_253, 5); -lean_inc(x_270); -lean_inc(x_269); -lean_inc(x_268); -lean_inc(x_267); -lean_inc(x_266); -lean_dec(x_253); -x_271 = lean_ctor_get(x_254, 0); -lean_inc(x_271); -x_272 = lean_ctor_get(x_254, 1); -lean_inc(x_272); -x_273 = lean_ctor_get(x_254, 3); +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; +x_329 = lean_ctor_get(x_12, 0); +x_330 = lean_ctor_get(x_12, 1); +x_331 = lean_ctor_get(x_12, 2); +x_332 = lean_ctor_get(x_12, 3); +x_333 = lean_ctor_get(x_12, 4); +lean_inc(x_333); +lean_inc(x_332); +lean_inc(x_331); +lean_inc(x_330); +lean_inc(x_329); +lean_dec(x_12); +x_334 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_334, 0, x_255); +lean_ctor_set(x_334, 1, x_20); +x_335 = lean_array_push(x_331, x_334); +x_336 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_336, 0, x_329); +lean_ctor_set(x_336, 1, x_330); +lean_ctor_set(x_336, 2, x_335); +lean_ctor_set(x_336, 3, x_332); +lean_ctor_set(x_336, 4, x_333); +x_337 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_257, x_336, x_253); +if (lean_obj_tag(x_337) == 0) +{ +lean_object* x_338; lean_object* x_339; lean_object* x_340; +x_338 = lean_ctor_get(x_337, 0); +lean_inc(x_338); +x_339 = lean_ctor_get(x_337, 1); +lean_inc(x_339); +lean_dec(x_337); +x_340 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_340, 0, x_338); +x_262 = x_340; +x_263 = x_339; +goto block_316; +} +else +{ +lean_object* x_341; lean_object* x_342; lean_object* x_343; +x_341 = lean_ctor_get(x_337, 0); +lean_inc(x_341); +x_342 = lean_ctor_get(x_337, 1); +lean_inc(x_342); +lean_dec(x_337); +x_343 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_343, 0, x_341); +x_262 = x_343; +x_263 = x_342; +goto block_316; +} +} +block_316: +{ +if (lean_obj_tag(x_262) == 0) +{ +lean_object* x_264; lean_object* x_265; uint8_t x_266; +x_264 = lean_ctor_get(x_263, 2); +lean_inc(x_264); +x_265 = lean_ctor_get(x_262, 0); +lean_inc(x_265); +lean_dec(x_262); +x_266 = !lean_is_exclusive(x_263); +if (x_266 == 0) +{ +lean_object* x_267; uint8_t x_268; +x_267 = lean_ctor_get(x_263, 2); +lean_dec(x_267); +x_268 = !lean_is_exclusive(x_264); +if (x_268 == 0) +{ +lean_object* x_269; lean_object* x_270; +x_269 = lean_ctor_get(x_264, 2); +lean_dec(x_269); +lean_ctor_set(x_264, 2, x_261); +if (lean_is_scalar(x_254)) { + x_270 = lean_alloc_ctor(1, 2, 0); +} else { + x_270 = x_254; + lean_ctor_set_tag(x_270, 1); +} +lean_ctor_set(x_270, 0, x_265); +lean_ctor_set(x_270, 1, x_263); +return x_270; +} +else +{ +lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_object* x_276; +x_271 = lean_ctor_get(x_264, 0); +x_272 = lean_ctor_get(x_264, 1); +x_273 = lean_ctor_get(x_264, 3); +x_274 = lean_ctor_get(x_264, 4); +lean_inc(x_274); lean_inc(x_273); -if (lean_is_exclusive(x_254)) { - lean_ctor_release(x_254, 0); - lean_ctor_release(x_254, 1); - lean_ctor_release(x_254, 2); - lean_ctor_release(x_254, 3); - x_274 = x_254; -} else { - lean_dec_ref(x_254); - x_274 = lean_box(0); -} -if (lean_is_scalar(x_274)) { - x_275 = lean_alloc_ctor(0, 4, 0); -} else { - x_275 = x_274; -} +lean_inc(x_272); +lean_inc(x_271); +lean_dec(x_264); +x_275 = lean_alloc_ctor(0, 5, 0); lean_ctor_set(x_275, 0, x_271); lean_ctor_set(x_275, 1, x_272); -lean_ctor_set(x_275, 2, x_251); +lean_ctor_set(x_275, 2, x_261); lean_ctor_set(x_275, 3, x_273); -x_276 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_276, 0, x_266); -lean_ctor_set(x_276, 1, x_267); -lean_ctor_set(x_276, 2, x_275); -lean_ctor_set(x_276, 3, x_268); -lean_ctor_set(x_276, 4, x_269); -lean_ctor_set(x_276, 5, x_270); -if (lean_is_scalar(x_244)) { - x_277 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_275, 4, x_274); +lean_ctor_set(x_263, 2, x_275); +if (lean_is_scalar(x_254)) { + x_276 = lean_alloc_ctor(1, 2, 0); } else { - x_277 = x_244; - lean_ctor_set_tag(x_277, 1); + x_276 = x_254; + lean_ctor_set_tag(x_276, 1); } -lean_ctor_set(x_277, 0, x_255); -lean_ctor_set(x_277, 1, x_276); -return x_277; +lean_ctor_set(x_276, 0, x_265); +lean_ctor_set(x_276, 1, x_263); +return x_276; } } else { -lean_object* x_278; lean_object* x_279; uint8_t x_280; -x_278 = lean_ctor_get(x_253, 2); -lean_inc(x_278); -x_279 = lean_ctor_get(x_252, 0); +lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; lean_object* x_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; lean_object* x_289; +x_277 = lean_ctor_get(x_263, 0); +x_278 = lean_ctor_get(x_263, 1); +x_279 = lean_ctor_get(x_263, 3); +x_280 = lean_ctor_get(x_263, 4); +x_281 = lean_ctor_get(x_263, 5); +lean_inc(x_281); +lean_inc(x_280); lean_inc(x_279); -lean_dec(x_252); -x_280 = !lean_is_exclusive(x_253); -if (x_280 == 0) -{ -lean_object* x_281; uint8_t x_282; -x_281 = lean_ctor_get(x_253, 2); -lean_dec(x_281); -x_282 = !lean_is_exclusive(x_278); -if (x_282 == 0) -{ -lean_object* x_283; lean_object* x_284; -x_283 = lean_ctor_get(x_278, 2); -lean_dec(x_283); -lean_ctor_set(x_278, 2, x_251); -if (lean_is_scalar(x_244)) { - x_284 = lean_alloc_ctor(0, 2, 0); -} else { - x_284 = x_244; -} -lean_ctor_set(x_284, 0, x_279); -lean_ctor_set(x_284, 1, x_253); -return x_284; -} -else -{ -lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; lean_object* x_289; -x_285 = lean_ctor_get(x_278, 0); -x_286 = lean_ctor_get(x_278, 1); -x_287 = lean_ctor_get(x_278, 3); -lean_inc(x_287); -lean_inc(x_286); +lean_inc(x_278); +lean_inc(x_277); +lean_dec(x_263); +x_282 = lean_ctor_get(x_264, 0); +lean_inc(x_282); +x_283 = lean_ctor_get(x_264, 1); +lean_inc(x_283); +x_284 = lean_ctor_get(x_264, 3); +lean_inc(x_284); +x_285 = lean_ctor_get(x_264, 4); lean_inc(x_285); -lean_dec(x_278); -x_288 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_288, 0, x_285); -lean_ctor_set(x_288, 1, x_286); -lean_ctor_set(x_288, 2, x_251); -lean_ctor_set(x_288, 3, x_287); -lean_ctor_set(x_253, 2, x_288); -if (lean_is_scalar(x_244)) { - x_289 = lean_alloc_ctor(0, 2, 0); +if (lean_is_exclusive(x_264)) { + lean_ctor_release(x_264, 0); + lean_ctor_release(x_264, 1); + lean_ctor_release(x_264, 2); + lean_ctor_release(x_264, 3); + lean_ctor_release(x_264, 4); + x_286 = x_264; } else { - x_289 = x_244; + lean_dec_ref(x_264); + x_286 = lean_box(0); } -lean_ctor_set(x_289, 0, x_279); -lean_ctor_set(x_289, 1, x_253); +if (lean_is_scalar(x_286)) { + x_287 = lean_alloc_ctor(0, 5, 0); +} else { + x_287 = x_286; +} +lean_ctor_set(x_287, 0, x_282); +lean_ctor_set(x_287, 1, x_283); +lean_ctor_set(x_287, 2, x_261); +lean_ctor_set(x_287, 3, x_284); +lean_ctor_set(x_287, 4, x_285); +x_288 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_288, 0, x_277); +lean_ctor_set(x_288, 1, x_278); +lean_ctor_set(x_288, 2, x_287); +lean_ctor_set(x_288, 3, x_279); +lean_ctor_set(x_288, 4, x_280); +lean_ctor_set(x_288, 5, x_281); +if (lean_is_scalar(x_254)) { + x_289 = lean_alloc_ctor(1, 2, 0); +} else { + x_289 = x_254; + lean_ctor_set_tag(x_289, 1); +} +lean_ctor_set(x_289, 0, x_265); +lean_ctor_set(x_289, 1, x_288); return x_289; } } else { -lean_object* x_290; lean_object* x_291; lean_object* x_292; lean_object* x_293; lean_object* x_294; lean_object* x_295; lean_object* x_296; lean_object* x_297; lean_object* x_298; lean_object* x_299; lean_object* x_300; lean_object* x_301; -x_290 = lean_ctor_get(x_253, 0); -x_291 = lean_ctor_get(x_253, 1); -x_292 = lean_ctor_get(x_253, 3); -x_293 = lean_ctor_get(x_253, 4); -x_294 = lean_ctor_get(x_253, 5); -lean_inc(x_294); -lean_inc(x_293); -lean_inc(x_292); -lean_inc(x_291); +lean_object* x_290; lean_object* x_291; uint8_t x_292; +x_290 = lean_ctor_get(x_263, 2); lean_inc(x_290); -lean_dec(x_253); -x_295 = lean_ctor_get(x_278, 0); -lean_inc(x_295); -x_296 = lean_ctor_get(x_278, 1); -lean_inc(x_296); -x_297 = lean_ctor_get(x_278, 3); +x_291 = lean_ctor_get(x_262, 0); +lean_inc(x_291); +lean_dec(x_262); +x_292 = !lean_is_exclusive(x_263); +if (x_292 == 0) +{ +lean_object* x_293; uint8_t x_294; +x_293 = lean_ctor_get(x_263, 2); +lean_dec(x_293); +x_294 = !lean_is_exclusive(x_290); +if (x_294 == 0) +{ +lean_object* x_295; lean_object* x_296; +x_295 = lean_ctor_get(x_290, 2); +lean_dec(x_295); +lean_ctor_set(x_290, 2, x_261); +if (lean_is_scalar(x_254)) { + x_296 = lean_alloc_ctor(0, 2, 0); +} else { + x_296 = x_254; +} +lean_ctor_set(x_296, 0, x_291); +lean_ctor_set(x_296, 1, x_263); +return x_296; +} +else +{ +lean_object* x_297; lean_object* x_298; lean_object* x_299; lean_object* x_300; lean_object* x_301; lean_object* x_302; +x_297 = lean_ctor_get(x_290, 0); +x_298 = lean_ctor_get(x_290, 1); +x_299 = lean_ctor_get(x_290, 3); +x_300 = lean_ctor_get(x_290, 4); +lean_inc(x_300); +lean_inc(x_299); +lean_inc(x_298); lean_inc(x_297); -if (lean_is_exclusive(x_278)) { - lean_ctor_release(x_278, 0); - lean_ctor_release(x_278, 1); - lean_ctor_release(x_278, 2); - lean_ctor_release(x_278, 3); - x_298 = x_278; +lean_dec(x_290); +x_301 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_301, 0, x_297); +lean_ctor_set(x_301, 1, x_298); +lean_ctor_set(x_301, 2, x_261); +lean_ctor_set(x_301, 3, x_299); +lean_ctor_set(x_301, 4, x_300); +lean_ctor_set(x_263, 2, x_301); +if (lean_is_scalar(x_254)) { + x_302 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_278); - x_298 = lean_box(0); + x_302 = x_254; } -if (lean_is_scalar(x_298)) { - x_299 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_302, 0, x_291); +lean_ctor_set(x_302, 1, x_263); +return x_302; +} +} +else +{ +lean_object* x_303; lean_object* x_304; lean_object* x_305; lean_object* x_306; lean_object* x_307; lean_object* x_308; lean_object* x_309; lean_object* x_310; lean_object* x_311; lean_object* x_312; lean_object* x_313; lean_object* x_314; lean_object* x_315; +x_303 = lean_ctor_get(x_263, 0); +x_304 = lean_ctor_get(x_263, 1); +x_305 = lean_ctor_get(x_263, 3); +x_306 = lean_ctor_get(x_263, 4); +x_307 = lean_ctor_get(x_263, 5); +lean_inc(x_307); +lean_inc(x_306); +lean_inc(x_305); +lean_inc(x_304); +lean_inc(x_303); +lean_dec(x_263); +x_308 = lean_ctor_get(x_290, 0); +lean_inc(x_308); +x_309 = lean_ctor_get(x_290, 1); +lean_inc(x_309); +x_310 = lean_ctor_get(x_290, 3); +lean_inc(x_310); +x_311 = lean_ctor_get(x_290, 4); +lean_inc(x_311); +if (lean_is_exclusive(x_290)) { + lean_ctor_release(x_290, 0); + lean_ctor_release(x_290, 1); + lean_ctor_release(x_290, 2); + lean_ctor_release(x_290, 3); + lean_ctor_release(x_290, 4); + x_312 = x_290; } else { - x_299 = x_298; + lean_dec_ref(x_290); + x_312 = lean_box(0); } -lean_ctor_set(x_299, 0, x_295); -lean_ctor_set(x_299, 1, x_296); -lean_ctor_set(x_299, 2, x_251); -lean_ctor_set(x_299, 3, x_297); -x_300 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_300, 0, x_290); -lean_ctor_set(x_300, 1, x_291); -lean_ctor_set(x_300, 2, x_299); -lean_ctor_set(x_300, 3, x_292); -lean_ctor_set(x_300, 4, x_293); -lean_ctor_set(x_300, 5, x_294); -if (lean_is_scalar(x_244)) { - x_301 = lean_alloc_ctor(0, 2, 0); +if (lean_is_scalar(x_312)) { + x_313 = lean_alloc_ctor(0, 5, 0); } else { - x_301 = x_244; + x_313 = x_312; } -lean_ctor_set(x_301, 0, x_279); -lean_ctor_set(x_301, 1, x_300); -return x_301; +lean_ctor_set(x_313, 0, x_308); +lean_ctor_set(x_313, 1, x_309); +lean_ctor_set(x_313, 2, x_261); +lean_ctor_set(x_313, 3, x_310); +lean_ctor_set(x_313, 4, x_311); +x_314 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_314, 0, x_303); +lean_ctor_set(x_314, 1, x_304); +lean_ctor_set(x_314, 2, x_313); +lean_ctor_set(x_314, 3, x_305); +lean_ctor_set(x_314, 4, x_306); +lean_ctor_set(x_314, 5, x_307); +if (lean_is_scalar(x_254)) { + x_315 = lean_alloc_ctor(0, 2, 0); +} else { + x_315 = x_254; +} +lean_ctor_set(x_315, 0, x_291); +lean_ctor_set(x_315, 1, x_314); +return x_315; } } } } else { -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_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; lean_object* x_374; lean_object* x_375; lean_object* x_376; lean_object* x_377; lean_object* x_378; -x_330 = lean_ctor_get(x_249, 0); -x_331 = lean_ctor_get(x_249, 1); -x_332 = lean_ctor_get(x_249, 2); -x_333 = lean_ctor_get(x_249, 3); -lean_inc(x_333); -lean_inc(x_332); -lean_inc(x_331); -lean_inc(x_330); -lean_dec(x_249); -x_367 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_368 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_368, 0, x_330); -lean_ctor_set(x_368, 1, x_331); -lean_ctor_set(x_368, 2, x_367); -lean_ctor_set(x_368, 3, x_333); -lean_ctor_set(x_243, 2, x_368); -x_369 = lean_ctor_get(x_12, 0); -lean_inc(x_369); -x_370 = lean_ctor_get(x_12, 1); -lean_inc(x_370); -x_371 = lean_ctor_get(x_12, 2); -lean_inc(x_371); -x_372 = lean_ctor_get(x_12, 3); -lean_inc(x_372); -x_373 = lean_ctor_get(x_12, 4); -lean_inc(x_373); +lean_object* x_344; lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; lean_object* x_350; 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; lean_object* x_391; lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; +x_344 = lean_ctor_get(x_259, 0); +x_345 = lean_ctor_get(x_259, 1); +x_346 = lean_ctor_get(x_259, 2); +x_347 = lean_ctor_get(x_259, 3); +x_348 = lean_ctor_get(x_259, 4); +lean_inc(x_348); +lean_inc(x_347); +lean_inc(x_346); +lean_inc(x_345); +lean_inc(x_344); +lean_dec(x_259); +x_384 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_385 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_385, 0, x_344); +lean_ctor_set(x_385, 1, x_345); +lean_ctor_set(x_385, 2, x_384); +lean_ctor_set(x_385, 3, x_347); +lean_ctor_set(x_385, 4, x_348); +lean_ctor_set(x_253, 2, x_385); +x_386 = lean_ctor_get(x_12, 0); +lean_inc(x_386); +x_387 = lean_ctor_get(x_12, 1); +lean_inc(x_387); +x_388 = lean_ctor_get(x_12, 2); +lean_inc(x_388); +x_389 = lean_ctor_get(x_12, 3); +lean_inc(x_389); +x_390 = lean_ctor_get(x_12, 4); +lean_inc(x_390); if (lean_is_exclusive(x_12)) { lean_ctor_release(x_12, 0); lean_ctor_release(x_12, 1); lean_ctor_release(x_12, 2); lean_ctor_release(x_12, 3); lean_ctor_release(x_12, 4); - x_374 = x_12; + x_391 = x_12; } else { lean_dec_ref(x_12); - x_374 = lean_box(0); + x_391 = lean_box(0); } -x_375 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_375, 0, x_245); -lean_ctor_set(x_375, 1, x_20); -x_376 = lean_array_push(x_371, x_375); -if (lean_is_scalar(x_374)) { - x_377 = lean_alloc_ctor(0, 5, 0); +x_392 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_392, 0, x_255); +lean_ctor_set(x_392, 1, x_20); +x_393 = lean_array_push(x_388, x_392); +if (lean_is_scalar(x_391)) { + x_394 = lean_alloc_ctor(0, 5, 0); } else { - x_377 = x_374; + x_394 = x_391; } -lean_ctor_set(x_377, 0, x_369); -lean_ctor_set(x_377, 1, x_370); -lean_ctor_set(x_377, 2, x_376); -lean_ctor_set(x_377, 3, x_372); -lean_ctor_set(x_377, 4, x_373); -x_378 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_247, x_377, x_243); -if (lean_obj_tag(x_378) == 0) +lean_ctor_set(x_394, 0, x_386); +lean_ctor_set(x_394, 1, x_387); +lean_ctor_set(x_394, 2, x_393); +lean_ctor_set(x_394, 3, x_389); +lean_ctor_set(x_394, 4, x_390); +x_395 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_257, x_394, x_253); +if (lean_obj_tag(x_395) == 0) { -lean_object* x_379; lean_object* x_380; lean_object* x_381; -x_379 = lean_ctor_get(x_378, 0); -lean_inc(x_379); -x_380 = lean_ctor_get(x_378, 1); -lean_inc(x_380); -lean_dec(x_378); -x_381 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_381, 0, x_379); -x_334 = x_381; -x_335 = x_380; -goto block_366; +lean_object* x_396; lean_object* x_397; lean_object* x_398; +x_396 = lean_ctor_get(x_395, 0); +lean_inc(x_396); +x_397 = lean_ctor_get(x_395, 1); +lean_inc(x_397); +lean_dec(x_395); +x_398 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_398, 0, x_396); +x_349 = x_398; +x_350 = x_397; +goto block_383; } else { -lean_object* x_382; lean_object* x_383; lean_object* x_384; -x_382 = lean_ctor_get(x_378, 0); -lean_inc(x_382); -x_383 = lean_ctor_get(x_378, 1); -lean_inc(x_383); -lean_dec(x_378); -x_384 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_384, 0, x_382); -x_334 = x_384; -x_335 = x_383; -goto block_366; +lean_object* x_399; lean_object* x_400; lean_object* x_401; +x_399 = lean_ctor_get(x_395, 0); +lean_inc(x_399); +x_400 = lean_ctor_get(x_395, 1); +lean_inc(x_400); +lean_dec(x_395); +x_401 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_401, 0, x_399); +x_349 = x_401; +x_350 = x_400; +goto block_383; } -block_366: +block_383: { -if (lean_obj_tag(x_334) == 0) +if (lean_obj_tag(x_349) == 0) { -lean_object* x_336; lean_object* x_337; lean_object* x_338; lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; lean_object* x_350; -x_336 = lean_ctor_get(x_335, 2); -lean_inc(x_336); -x_337 = lean_ctor_get(x_334, 0); -lean_inc(x_337); -lean_dec(x_334); -x_338 = lean_ctor_get(x_335, 0); -lean_inc(x_338); -x_339 = lean_ctor_get(x_335, 1); -lean_inc(x_339); -x_340 = lean_ctor_get(x_335, 3); -lean_inc(x_340); -x_341 = lean_ctor_get(x_335, 4); -lean_inc(x_341); -x_342 = lean_ctor_get(x_335, 5); -lean_inc(x_342); -if (lean_is_exclusive(x_335)) { - lean_ctor_release(x_335, 0); - lean_ctor_release(x_335, 1); - lean_ctor_release(x_335, 2); - lean_ctor_release(x_335, 3); - lean_ctor_release(x_335, 4); - lean_ctor_release(x_335, 5); - x_343 = x_335; -} else { - lean_dec_ref(x_335); - x_343 = lean_box(0); -} -x_344 = lean_ctor_get(x_336, 0); -lean_inc(x_344); -x_345 = lean_ctor_get(x_336, 1); -lean_inc(x_345); -x_346 = lean_ctor_get(x_336, 3); -lean_inc(x_346); -if (lean_is_exclusive(x_336)) { - lean_ctor_release(x_336, 0); - lean_ctor_release(x_336, 1); - lean_ctor_release(x_336, 2); - lean_ctor_release(x_336, 3); - x_347 = x_336; -} else { - lean_dec_ref(x_336); - x_347 = lean_box(0); -} -if (lean_is_scalar(x_347)) { - x_348 = lean_alloc_ctor(0, 4, 0); -} else { - x_348 = x_347; -} -lean_ctor_set(x_348, 0, x_344); -lean_ctor_set(x_348, 1, x_345); -lean_ctor_set(x_348, 2, x_332); -lean_ctor_set(x_348, 3, x_346); -if (lean_is_scalar(x_343)) { - x_349 = lean_alloc_ctor(0, 6, 0); -} else { - x_349 = x_343; -} -lean_ctor_set(x_349, 0, x_338); -lean_ctor_set(x_349, 1, x_339); -lean_ctor_set(x_349, 2, x_348); -lean_ctor_set(x_349, 3, x_340); -lean_ctor_set(x_349, 4, x_341); -lean_ctor_set(x_349, 5, x_342); -if (lean_is_scalar(x_244)) { - x_350 = lean_alloc_ctor(1, 2, 0); -} else { - x_350 = x_244; - lean_ctor_set_tag(x_350, 1); -} -lean_ctor_set(x_350, 0, x_337); -lean_ctor_set(x_350, 1, x_349); -return x_350; -} -else -{ -lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; 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; -x_351 = lean_ctor_get(x_335, 2); +lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; 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; +x_351 = lean_ctor_get(x_350, 2); lean_inc(x_351); -x_352 = lean_ctor_get(x_334, 0); +x_352 = lean_ctor_get(x_349, 0); lean_inc(x_352); -lean_dec(x_334); -x_353 = lean_ctor_get(x_335, 0); +lean_dec(x_349); +x_353 = lean_ctor_get(x_350, 0); lean_inc(x_353); -x_354 = lean_ctor_get(x_335, 1); +x_354 = lean_ctor_get(x_350, 1); lean_inc(x_354); -x_355 = lean_ctor_get(x_335, 3); +x_355 = lean_ctor_get(x_350, 3); lean_inc(x_355); -x_356 = lean_ctor_get(x_335, 4); +x_356 = lean_ctor_get(x_350, 4); lean_inc(x_356); -x_357 = lean_ctor_get(x_335, 5); +x_357 = lean_ctor_get(x_350, 5); lean_inc(x_357); -if (lean_is_exclusive(x_335)) { - lean_ctor_release(x_335, 0); - lean_ctor_release(x_335, 1); - lean_ctor_release(x_335, 2); - lean_ctor_release(x_335, 3); - lean_ctor_release(x_335, 4); - lean_ctor_release(x_335, 5); - x_358 = x_335; +if (lean_is_exclusive(x_350)) { + lean_ctor_release(x_350, 0); + lean_ctor_release(x_350, 1); + lean_ctor_release(x_350, 2); + lean_ctor_release(x_350, 3); + lean_ctor_release(x_350, 4); + lean_ctor_release(x_350, 5); + x_358 = x_350; } else { - lean_dec_ref(x_335); + lean_dec_ref(x_350); x_358 = lean_box(0); } x_359 = lean_ctor_get(x_351, 0); @@ -33063,315 +34035,411 @@ x_360 = lean_ctor_get(x_351, 1); lean_inc(x_360); x_361 = lean_ctor_get(x_351, 3); lean_inc(x_361); +x_362 = lean_ctor_get(x_351, 4); +lean_inc(x_362); if (lean_is_exclusive(x_351)) { lean_ctor_release(x_351, 0); lean_ctor_release(x_351, 1); lean_ctor_release(x_351, 2); lean_ctor_release(x_351, 3); - x_362 = x_351; + lean_ctor_release(x_351, 4); + x_363 = x_351; } else { lean_dec_ref(x_351); - x_362 = lean_box(0); + x_363 = lean_box(0); } -if (lean_is_scalar(x_362)) { - x_363 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_363)) { + x_364 = lean_alloc_ctor(0, 5, 0); } else { - x_363 = x_362; + x_364 = x_363; } -lean_ctor_set(x_363, 0, x_359); -lean_ctor_set(x_363, 1, x_360); -lean_ctor_set(x_363, 2, x_332); -lean_ctor_set(x_363, 3, x_361); +lean_ctor_set(x_364, 0, x_359); +lean_ctor_set(x_364, 1, x_360); +lean_ctor_set(x_364, 2, x_346); +lean_ctor_set(x_364, 3, x_361); +lean_ctor_set(x_364, 4, x_362); if (lean_is_scalar(x_358)) { - x_364 = lean_alloc_ctor(0, 6, 0); + x_365 = lean_alloc_ctor(0, 6, 0); } else { - x_364 = x_358; + x_365 = x_358; } -lean_ctor_set(x_364, 0, x_353); -lean_ctor_set(x_364, 1, x_354); -lean_ctor_set(x_364, 2, x_363); -lean_ctor_set(x_364, 3, x_355); -lean_ctor_set(x_364, 4, x_356); -lean_ctor_set(x_364, 5, x_357); -if (lean_is_scalar(x_244)) { - x_365 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_365, 0, x_353); +lean_ctor_set(x_365, 1, x_354); +lean_ctor_set(x_365, 2, x_364); +lean_ctor_set(x_365, 3, x_355); +lean_ctor_set(x_365, 4, x_356); +lean_ctor_set(x_365, 5, x_357); +if (lean_is_scalar(x_254)) { + x_366 = lean_alloc_ctor(1, 2, 0); } else { - x_365 = x_244; + x_366 = x_254; + lean_ctor_set_tag(x_366, 1); } -lean_ctor_set(x_365, 0, x_352); -lean_ctor_set(x_365, 1, x_364); -return x_365; +lean_ctor_set(x_366, 0, x_352); +lean_ctor_set(x_366, 1, x_365); +return x_366; +} +else +{ +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; lean_object* x_374; lean_object* x_375; 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; +x_367 = lean_ctor_get(x_350, 2); +lean_inc(x_367); +x_368 = lean_ctor_get(x_349, 0); +lean_inc(x_368); +lean_dec(x_349); +x_369 = lean_ctor_get(x_350, 0); +lean_inc(x_369); +x_370 = lean_ctor_get(x_350, 1); +lean_inc(x_370); +x_371 = lean_ctor_get(x_350, 3); +lean_inc(x_371); +x_372 = lean_ctor_get(x_350, 4); +lean_inc(x_372); +x_373 = lean_ctor_get(x_350, 5); +lean_inc(x_373); +if (lean_is_exclusive(x_350)) { + lean_ctor_release(x_350, 0); + lean_ctor_release(x_350, 1); + lean_ctor_release(x_350, 2); + lean_ctor_release(x_350, 3); + lean_ctor_release(x_350, 4); + lean_ctor_release(x_350, 5); + x_374 = x_350; +} else { + lean_dec_ref(x_350); + x_374 = lean_box(0); +} +x_375 = lean_ctor_get(x_367, 0); +lean_inc(x_375); +x_376 = lean_ctor_get(x_367, 1); +lean_inc(x_376); +x_377 = lean_ctor_get(x_367, 3); +lean_inc(x_377); +x_378 = lean_ctor_get(x_367, 4); +lean_inc(x_378); +if (lean_is_exclusive(x_367)) { + lean_ctor_release(x_367, 0); + lean_ctor_release(x_367, 1); + lean_ctor_release(x_367, 2); + lean_ctor_release(x_367, 3); + lean_ctor_release(x_367, 4); + x_379 = x_367; +} else { + lean_dec_ref(x_367); + x_379 = lean_box(0); +} +if (lean_is_scalar(x_379)) { + x_380 = lean_alloc_ctor(0, 5, 0); +} else { + x_380 = x_379; +} +lean_ctor_set(x_380, 0, x_375); +lean_ctor_set(x_380, 1, x_376); +lean_ctor_set(x_380, 2, x_346); +lean_ctor_set(x_380, 3, x_377); +lean_ctor_set(x_380, 4, x_378); +if (lean_is_scalar(x_374)) { + x_381 = lean_alloc_ctor(0, 6, 0); +} else { + x_381 = x_374; +} +lean_ctor_set(x_381, 0, x_369); +lean_ctor_set(x_381, 1, x_370); +lean_ctor_set(x_381, 2, x_380); +lean_ctor_set(x_381, 3, x_371); +lean_ctor_set(x_381, 4, x_372); +lean_ctor_set(x_381, 5, x_373); +if (lean_is_scalar(x_254)) { + x_382 = lean_alloc_ctor(0, 2, 0); +} else { + x_382 = x_254; +} +lean_ctor_set(x_382, 0, x_368); +lean_ctor_set(x_382, 1, x_381); +return x_382; } } } } else { -lean_object* x_385; lean_object* x_386; lean_object* x_387; lean_object* x_388; lean_object* x_389; lean_object* x_390; lean_object* x_391; lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_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; -x_385 = lean_ctor_get(x_243, 2); -x_386 = lean_ctor_get(x_243, 0); -x_387 = lean_ctor_get(x_243, 1); -x_388 = lean_ctor_get(x_243, 3); -x_389 = lean_ctor_get(x_243, 4); -x_390 = lean_ctor_get(x_243, 5); -lean_inc(x_390); -lean_inc(x_389); -lean_inc(x_388); -lean_inc(x_385); -lean_inc(x_387); -lean_inc(x_386); -lean_dec(x_243); -x_391 = lean_ctor_get(x_385, 0); -lean_inc(x_391); -x_392 = lean_ctor_get(x_385, 1); -lean_inc(x_392); -x_393 = lean_ctor_get(x_385, 2); -lean_inc(x_393); -x_394 = lean_ctor_get(x_385, 3); -lean_inc(x_394); -if (lean_is_exclusive(x_385)) { - lean_ctor_release(x_385, 0); - lean_ctor_release(x_385, 1); - lean_ctor_release(x_385, 2); - lean_ctor_release(x_385, 3); - x_395 = x_385; +lean_object* x_402; lean_object* x_403; lean_object* x_404; lean_object* x_405; lean_object* x_406; lean_object* x_407; lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_object* x_412; lean_object* x_413; lean_object* x_414; lean_object* x_415; lean_object* x_449; lean_object* x_450; lean_object* x_451; lean_object* x_452; lean_object* x_453; lean_object* x_454; lean_object* x_455; lean_object* x_456; lean_object* x_457; lean_object* x_458; lean_object* x_459; lean_object* x_460; lean_object* x_461; +x_402 = lean_ctor_get(x_253, 2); +x_403 = lean_ctor_get(x_253, 0); +x_404 = lean_ctor_get(x_253, 1); +x_405 = lean_ctor_get(x_253, 3); +x_406 = lean_ctor_get(x_253, 4); +x_407 = lean_ctor_get(x_253, 5); +lean_inc(x_407); +lean_inc(x_406); +lean_inc(x_405); +lean_inc(x_402); +lean_inc(x_404); +lean_inc(x_403); +lean_dec(x_253); +x_408 = lean_ctor_get(x_402, 0); +lean_inc(x_408); +x_409 = lean_ctor_get(x_402, 1); +lean_inc(x_409); +x_410 = lean_ctor_get(x_402, 2); +lean_inc(x_410); +x_411 = lean_ctor_get(x_402, 3); +lean_inc(x_411); +x_412 = lean_ctor_get(x_402, 4); +lean_inc(x_412); +if (lean_is_exclusive(x_402)) { + lean_ctor_release(x_402, 0); + lean_ctor_release(x_402, 1); + lean_ctor_release(x_402, 2); + lean_ctor_release(x_402, 3); + lean_ctor_release(x_402, 4); + x_413 = x_402; } else { - lean_dec_ref(x_385); - x_395 = lean_box(0); + lean_dec_ref(x_402); + x_413 = lean_box(0); } -x_429 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_395)) { - x_430 = lean_alloc_ctor(0, 4, 0); +x_449 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_413)) { + x_450 = lean_alloc_ctor(0, 5, 0); } else { - x_430 = x_395; + x_450 = x_413; } -lean_ctor_set(x_430, 0, x_391); -lean_ctor_set(x_430, 1, x_392); -lean_ctor_set(x_430, 2, x_429); -lean_ctor_set(x_430, 3, x_394); -x_431 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_431, 0, x_386); -lean_ctor_set(x_431, 1, x_387); -lean_ctor_set(x_431, 2, x_430); -lean_ctor_set(x_431, 3, x_388); -lean_ctor_set(x_431, 4, x_389); -lean_ctor_set(x_431, 5, x_390); -x_432 = lean_ctor_get(x_12, 0); -lean_inc(x_432); -x_433 = lean_ctor_get(x_12, 1); -lean_inc(x_433); -x_434 = lean_ctor_get(x_12, 2); -lean_inc(x_434); -x_435 = lean_ctor_get(x_12, 3); -lean_inc(x_435); -x_436 = lean_ctor_get(x_12, 4); -lean_inc(x_436); +lean_ctor_set(x_450, 0, x_408); +lean_ctor_set(x_450, 1, x_409); +lean_ctor_set(x_450, 2, x_449); +lean_ctor_set(x_450, 3, x_411); +lean_ctor_set(x_450, 4, x_412); +x_451 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_451, 0, x_403); +lean_ctor_set(x_451, 1, x_404); +lean_ctor_set(x_451, 2, x_450); +lean_ctor_set(x_451, 3, x_405); +lean_ctor_set(x_451, 4, x_406); +lean_ctor_set(x_451, 5, x_407); +x_452 = lean_ctor_get(x_12, 0); +lean_inc(x_452); +x_453 = lean_ctor_get(x_12, 1); +lean_inc(x_453); +x_454 = lean_ctor_get(x_12, 2); +lean_inc(x_454); +x_455 = lean_ctor_get(x_12, 3); +lean_inc(x_455); +x_456 = lean_ctor_get(x_12, 4); +lean_inc(x_456); if (lean_is_exclusive(x_12)) { lean_ctor_release(x_12, 0); lean_ctor_release(x_12, 1); lean_ctor_release(x_12, 2); lean_ctor_release(x_12, 3); lean_ctor_release(x_12, 4); - x_437 = x_12; + x_457 = x_12; } else { lean_dec_ref(x_12); - x_437 = lean_box(0); + x_457 = lean_box(0); } -x_438 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_438, 0, x_245); -lean_ctor_set(x_438, 1, x_20); -x_439 = lean_array_push(x_434, x_438); -if (lean_is_scalar(x_437)) { - x_440 = lean_alloc_ctor(0, 5, 0); +x_458 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_458, 0, x_255); +lean_ctor_set(x_458, 1, x_20); +x_459 = lean_array_push(x_454, x_458); +if (lean_is_scalar(x_457)) { + x_460 = lean_alloc_ctor(0, 5, 0); } else { - x_440 = x_437; + x_460 = x_457; } -lean_ctor_set(x_440, 0, x_432); -lean_ctor_set(x_440, 1, x_433); -lean_ctor_set(x_440, 2, x_439); -lean_ctor_set(x_440, 3, x_435); -lean_ctor_set(x_440, 4, x_436); -x_441 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_247, x_440, x_431); -if (lean_obj_tag(x_441) == 0) +lean_ctor_set(x_460, 0, x_452); +lean_ctor_set(x_460, 1, x_453); +lean_ctor_set(x_460, 2, x_459); +lean_ctor_set(x_460, 3, x_455); +lean_ctor_set(x_460, 4, x_456); +x_461 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_257, x_460, x_451); +if (lean_obj_tag(x_461) == 0) { -lean_object* x_442; lean_object* x_443; lean_object* x_444; -x_442 = lean_ctor_get(x_441, 0); -lean_inc(x_442); -x_443 = lean_ctor_get(x_441, 1); -lean_inc(x_443); -lean_dec(x_441); -x_444 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_444, 0, x_442); -x_396 = x_444; -x_397 = x_443; -goto block_428; +lean_object* x_462; lean_object* x_463; lean_object* x_464; +x_462 = lean_ctor_get(x_461, 0); +lean_inc(x_462); +x_463 = lean_ctor_get(x_461, 1); +lean_inc(x_463); +lean_dec(x_461); +x_464 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_464, 0, x_462); +x_414 = x_464; +x_415 = x_463; +goto block_448; } else { -lean_object* x_445; lean_object* x_446; lean_object* x_447; -x_445 = lean_ctor_get(x_441, 0); -lean_inc(x_445); -x_446 = lean_ctor_get(x_441, 1); -lean_inc(x_446); -lean_dec(x_441); -x_447 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_447, 0, x_445); -x_396 = x_447; -x_397 = x_446; -goto block_428; +lean_object* x_465; lean_object* x_466; lean_object* x_467; +x_465 = lean_ctor_get(x_461, 0); +lean_inc(x_465); +x_466 = lean_ctor_get(x_461, 1); +lean_inc(x_466); +lean_dec(x_461); +x_467 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_467, 0, x_465); +x_414 = x_467; +x_415 = x_466; +goto block_448; } -block_428: +block_448: { -if (lean_obj_tag(x_396) == 0) +if (lean_obj_tag(x_414) == 0) { -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; lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_object* x_412; -x_398 = lean_ctor_get(x_397, 2); -lean_inc(x_398); -x_399 = lean_ctor_get(x_396, 0); -lean_inc(x_399); -lean_dec(x_396); -x_400 = lean_ctor_get(x_397, 0); -lean_inc(x_400); -x_401 = lean_ctor_get(x_397, 1); -lean_inc(x_401); -x_402 = lean_ctor_get(x_397, 3); -lean_inc(x_402); -x_403 = lean_ctor_get(x_397, 4); -lean_inc(x_403); -x_404 = lean_ctor_get(x_397, 5); -lean_inc(x_404); -if (lean_is_exclusive(x_397)) { - lean_ctor_release(x_397, 0); - lean_ctor_release(x_397, 1); - lean_ctor_release(x_397, 2); - lean_ctor_release(x_397, 3); - lean_ctor_release(x_397, 4); - lean_ctor_release(x_397, 5); - x_405 = x_397; -} else { - lean_dec_ref(x_397); - x_405 = lean_box(0); -} -x_406 = lean_ctor_get(x_398, 0); -lean_inc(x_406); -x_407 = lean_ctor_get(x_398, 1); -lean_inc(x_407); -x_408 = lean_ctor_get(x_398, 3); -lean_inc(x_408); -if (lean_is_exclusive(x_398)) { - lean_ctor_release(x_398, 0); - lean_ctor_release(x_398, 1); - lean_ctor_release(x_398, 2); - lean_ctor_release(x_398, 3); - x_409 = x_398; -} else { - lean_dec_ref(x_398); - x_409 = lean_box(0); -} -if (lean_is_scalar(x_409)) { - x_410 = lean_alloc_ctor(0, 4, 0); -} else { - x_410 = x_409; -} -lean_ctor_set(x_410, 0, x_406); -lean_ctor_set(x_410, 1, x_407); -lean_ctor_set(x_410, 2, x_393); -lean_ctor_set(x_410, 3, x_408); -if (lean_is_scalar(x_405)) { - x_411 = lean_alloc_ctor(0, 6, 0); -} else { - x_411 = x_405; -} -lean_ctor_set(x_411, 0, x_400); -lean_ctor_set(x_411, 1, x_401); -lean_ctor_set(x_411, 2, x_410); -lean_ctor_set(x_411, 3, x_402); -lean_ctor_set(x_411, 4, x_403); -lean_ctor_set(x_411, 5, x_404); -if (lean_is_scalar(x_244)) { - x_412 = lean_alloc_ctor(1, 2, 0); -} else { - x_412 = x_244; - lean_ctor_set_tag(x_412, 1); -} -lean_ctor_set(x_412, 0, x_399); -lean_ctor_set(x_412, 1, x_411); -return x_412; -} -else -{ -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; lean_object* x_426; lean_object* x_427; -x_413 = lean_ctor_get(x_397, 2); -lean_inc(x_413); -x_414 = lean_ctor_get(x_396, 0); -lean_inc(x_414); -lean_dec(x_396); -x_415 = lean_ctor_get(x_397, 0); -lean_inc(x_415); -x_416 = lean_ctor_get(x_397, 1); +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; lean_object* x_426; lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; +x_416 = lean_ctor_get(x_415, 2); lean_inc(x_416); -x_417 = lean_ctor_get(x_397, 3); +x_417 = lean_ctor_get(x_414, 0); lean_inc(x_417); -x_418 = lean_ctor_get(x_397, 4); +lean_dec(x_414); +x_418 = lean_ctor_get(x_415, 0); lean_inc(x_418); -x_419 = lean_ctor_get(x_397, 5); +x_419 = lean_ctor_get(x_415, 1); lean_inc(x_419); -if (lean_is_exclusive(x_397)) { - lean_ctor_release(x_397, 0); - lean_ctor_release(x_397, 1); - lean_ctor_release(x_397, 2); - lean_ctor_release(x_397, 3); - lean_ctor_release(x_397, 4); - lean_ctor_release(x_397, 5); - x_420 = x_397; -} else { - lean_dec_ref(x_397); - x_420 = lean_box(0); -} -x_421 = lean_ctor_get(x_413, 0); +x_420 = lean_ctor_get(x_415, 3); +lean_inc(x_420); +x_421 = lean_ctor_get(x_415, 4); lean_inc(x_421); -x_422 = lean_ctor_get(x_413, 1); +x_422 = lean_ctor_get(x_415, 5); lean_inc(x_422); -x_423 = lean_ctor_get(x_413, 3); -lean_inc(x_423); -if (lean_is_exclusive(x_413)) { - lean_ctor_release(x_413, 0); - lean_ctor_release(x_413, 1); - lean_ctor_release(x_413, 2); - lean_ctor_release(x_413, 3); - x_424 = x_413; +if (lean_is_exclusive(x_415)) { + lean_ctor_release(x_415, 0); + lean_ctor_release(x_415, 1); + lean_ctor_release(x_415, 2); + lean_ctor_release(x_415, 3); + lean_ctor_release(x_415, 4); + lean_ctor_release(x_415, 5); + x_423 = x_415; } else { - lean_dec_ref(x_413); - x_424 = lean_box(0); + lean_dec_ref(x_415); + x_423 = lean_box(0); } -if (lean_is_scalar(x_424)) { - x_425 = lean_alloc_ctor(0, 4, 0); +x_424 = lean_ctor_get(x_416, 0); +lean_inc(x_424); +x_425 = lean_ctor_get(x_416, 1); +lean_inc(x_425); +x_426 = lean_ctor_get(x_416, 3); +lean_inc(x_426); +x_427 = lean_ctor_get(x_416, 4); +lean_inc(x_427); +if (lean_is_exclusive(x_416)) { + lean_ctor_release(x_416, 0); + lean_ctor_release(x_416, 1); + lean_ctor_release(x_416, 2); + lean_ctor_release(x_416, 3); + lean_ctor_release(x_416, 4); + x_428 = x_416; } else { - x_425 = x_424; + lean_dec_ref(x_416); + x_428 = lean_box(0); } -lean_ctor_set(x_425, 0, x_421); -lean_ctor_set(x_425, 1, x_422); -lean_ctor_set(x_425, 2, x_393); -lean_ctor_set(x_425, 3, x_423); -if (lean_is_scalar(x_420)) { - x_426 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_428)) { + x_429 = lean_alloc_ctor(0, 5, 0); } else { - x_426 = x_420; + x_429 = x_428; } -lean_ctor_set(x_426, 0, x_415); -lean_ctor_set(x_426, 1, x_416); -lean_ctor_set(x_426, 2, x_425); -lean_ctor_set(x_426, 3, x_417); -lean_ctor_set(x_426, 4, x_418); -lean_ctor_set(x_426, 5, x_419); -if (lean_is_scalar(x_244)) { - x_427 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_429, 0, x_424); +lean_ctor_set(x_429, 1, x_425); +lean_ctor_set(x_429, 2, x_410); +lean_ctor_set(x_429, 3, x_426); +lean_ctor_set(x_429, 4, x_427); +if (lean_is_scalar(x_423)) { + x_430 = lean_alloc_ctor(0, 6, 0); } else { - x_427 = x_244; + x_430 = x_423; } -lean_ctor_set(x_427, 0, x_414); -lean_ctor_set(x_427, 1, x_426); -return x_427; +lean_ctor_set(x_430, 0, x_418); +lean_ctor_set(x_430, 1, x_419); +lean_ctor_set(x_430, 2, x_429); +lean_ctor_set(x_430, 3, x_420); +lean_ctor_set(x_430, 4, x_421); +lean_ctor_set(x_430, 5, x_422); +if (lean_is_scalar(x_254)) { + x_431 = lean_alloc_ctor(1, 2, 0); +} else { + x_431 = x_254; + lean_ctor_set_tag(x_431, 1); +} +lean_ctor_set(x_431, 0, x_417); +lean_ctor_set(x_431, 1, x_430); +return x_431; +} +else +{ +lean_object* x_432; lean_object* x_433; lean_object* x_434; lean_object* x_435; lean_object* x_436; lean_object* x_437; lean_object* x_438; lean_object* x_439; lean_object* x_440; lean_object* x_441; lean_object* x_442; lean_object* x_443; lean_object* x_444; lean_object* x_445; lean_object* x_446; lean_object* x_447; +x_432 = lean_ctor_get(x_415, 2); +lean_inc(x_432); +x_433 = lean_ctor_get(x_414, 0); +lean_inc(x_433); +lean_dec(x_414); +x_434 = lean_ctor_get(x_415, 0); +lean_inc(x_434); +x_435 = lean_ctor_get(x_415, 1); +lean_inc(x_435); +x_436 = lean_ctor_get(x_415, 3); +lean_inc(x_436); +x_437 = lean_ctor_get(x_415, 4); +lean_inc(x_437); +x_438 = lean_ctor_get(x_415, 5); +lean_inc(x_438); +if (lean_is_exclusive(x_415)) { + lean_ctor_release(x_415, 0); + lean_ctor_release(x_415, 1); + lean_ctor_release(x_415, 2); + lean_ctor_release(x_415, 3); + lean_ctor_release(x_415, 4); + lean_ctor_release(x_415, 5); + x_439 = x_415; +} else { + lean_dec_ref(x_415); + x_439 = lean_box(0); +} +x_440 = lean_ctor_get(x_432, 0); +lean_inc(x_440); +x_441 = lean_ctor_get(x_432, 1); +lean_inc(x_441); +x_442 = lean_ctor_get(x_432, 3); +lean_inc(x_442); +x_443 = lean_ctor_get(x_432, 4); +lean_inc(x_443); +if (lean_is_exclusive(x_432)) { + lean_ctor_release(x_432, 0); + lean_ctor_release(x_432, 1); + lean_ctor_release(x_432, 2); + lean_ctor_release(x_432, 3); + lean_ctor_release(x_432, 4); + x_444 = x_432; +} else { + lean_dec_ref(x_432); + x_444 = lean_box(0); +} +if (lean_is_scalar(x_444)) { + x_445 = lean_alloc_ctor(0, 5, 0); +} else { + x_445 = x_444; +} +lean_ctor_set(x_445, 0, x_440); +lean_ctor_set(x_445, 1, x_441); +lean_ctor_set(x_445, 2, x_410); +lean_ctor_set(x_445, 3, x_442); +lean_ctor_set(x_445, 4, x_443); +if (lean_is_scalar(x_439)) { + x_446 = lean_alloc_ctor(0, 6, 0); +} else { + x_446 = x_439; +} +lean_ctor_set(x_446, 0, x_434); +lean_ctor_set(x_446, 1, x_435); +lean_ctor_set(x_446, 2, x_445); +lean_ctor_set(x_446, 3, x_436); +lean_ctor_set(x_446, 4, x_437); +lean_ctor_set(x_446, 5, x_438); +if (lean_is_scalar(x_254)) { + x_447 = lean_alloc_ctor(0, 2, 0); +} else { + x_447 = x_254; +} +lean_ctor_set(x_447, 0, x_433); +lean_ctor_set(x_447, 1, x_446); +return x_447; } } } @@ -33379,7 +34447,7 @@ return x_427; } else { -uint8_t x_448; +uint8_t x_468; lean_dec(x_20); lean_dec(x_12); lean_dec(x_11); @@ -33389,23 +34457,23 @@ lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_448 = !lean_is_exclusive(x_237); -if (x_448 == 0) +x_468 = !lean_is_exclusive(x_247); +if (x_468 == 0) { -return x_237; +return x_247; } else { -lean_object* x_449; lean_object* x_450; lean_object* x_451; -x_449 = lean_ctor_get(x_237, 0); -x_450 = lean_ctor_get(x_237, 1); -lean_inc(x_450); -lean_inc(x_449); -lean_dec(x_237); -x_451 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_451, 0, x_449); -lean_ctor_set(x_451, 1, x_450); -return x_451; +lean_object* x_469; lean_object* x_470; lean_object* x_471; +x_469 = lean_ctor_get(x_247, 0); +x_470 = lean_ctor_get(x_247, 1); +lean_inc(x_470); +lean_inc(x_469); +lean_dec(x_247); +x_471 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_471, 0, x_469); +lean_ctor_set(x_471, 1, x_470); +return x_471; } } } @@ -33413,7 +34481,7 @@ return x_451; } else { -uint8_t x_452; +uint8_t x_472; lean_dec(x_24); lean_dec(x_20); lean_dec(x_12); @@ -33424,29 +34492,29 @@ lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_452 = !lean_is_exclusive(x_25); -if (x_452 == 0) +x_472 = !lean_is_exclusive(x_25); +if (x_472 == 0) { return x_25; } else { -lean_object* x_453; lean_object* x_454; lean_object* x_455; -x_453 = lean_ctor_get(x_25, 0); -x_454 = lean_ctor_get(x_25, 1); -lean_inc(x_454); -lean_inc(x_453); +lean_object* x_473; lean_object* x_474; lean_object* x_475; +x_473 = lean_ctor_get(x_25, 0); +x_474 = lean_ctor_get(x_25, 1); +lean_inc(x_474); +lean_inc(x_473); lean_dec(x_25); -x_455 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_455, 0, x_453); -lean_ctor_set(x_455, 1, x_454); -return x_455; +x_475 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_475, 0, x_473); +lean_ctor_set(x_475, 1, x_474); +return x_475; } } } else { -uint8_t x_456; +uint8_t x_476; lean_dec(x_20); lean_dec(x_12); lean_dec(x_11); @@ -33456,23 +34524,23 @@ lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_456 = !lean_is_exclusive(x_21); -if (x_456 == 0) +x_476 = !lean_is_exclusive(x_21); +if (x_476 == 0) { return x_21; } else { -lean_object* x_457; lean_object* x_458; lean_object* x_459; -x_457 = lean_ctor_get(x_21, 0); -x_458 = lean_ctor_get(x_21, 1); -lean_inc(x_458); -lean_inc(x_457); +lean_object* x_477; lean_object* x_478; lean_object* x_479; +x_477 = lean_ctor_get(x_21, 0); +x_478 = lean_ctor_get(x_21, 1); +lean_inc(x_478); +lean_inc(x_477); lean_dec(x_21); -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_479 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_479, 0, x_477); +lean_ctor_set(x_479, 1, x_478); +return x_479; } } } @@ -33572,105 +34640,105 @@ x_31 = lean_ctor_get(x_25, 2); x_32 = !lean_is_exclusive(x_31); if (x_32 == 0) { -lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_85; uint8_t x_86; +lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_89; uint8_t x_90; x_33 = lean_ctor_get(x_31, 2); -x_85 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_31, 2, x_85); -x_86 = !lean_is_exclusive(x_7); -if (x_86 == 0) +x_89 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_31, 2, x_89); +x_90 = !lean_is_exclusive(x_7); +if (x_90 == 0) { -lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; -x_87 = lean_ctor_get(x_7, 2); -x_88 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_88, 0, x_27); -lean_ctor_set(x_88, 1, x_14); -x_89 = lean_array_push(x_87, x_88); -lean_ctor_set(x_7, 2, x_89); -x_90 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_7, x_25); -if (lean_obj_tag(x_90) == 0) +lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; +x_91 = lean_ctor_get(x_7, 2); +x_92 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_92, 0, x_27); +lean_ctor_set(x_92, 1, x_14); +x_93 = lean_array_push(x_91, x_92); +lean_ctor_set(x_7, 2, x_93); +x_94 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_7, x_25); +if (lean_obj_tag(x_94) == 0) { -lean_object* x_91; lean_object* x_92; lean_object* x_93; -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_alloc_ctor(1, 1, 0); -lean_ctor_set(x_93, 0, x_91); -x_34 = x_93; -x_35 = x_92; -goto block_84; -} -else -{ -lean_object* x_94; lean_object* x_95; lean_object* x_96; -x_94 = lean_ctor_get(x_90, 0); -lean_inc(x_94); -x_95 = lean_ctor_get(x_90, 1); +lean_object* x_95; lean_object* x_96; lean_object* x_97; +x_95 = lean_ctor_get(x_94, 0); lean_inc(x_95); -lean_dec(x_90); -x_96 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_96, 0, x_94); -x_34 = x_96; -x_35 = x_95; -goto block_84; -} +x_96 = lean_ctor_get(x_94, 1); +lean_inc(x_96); +lean_dec(x_94); +x_97 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_97, 0, x_95); +x_34 = x_97; +x_35 = x_96; +goto block_88; } else { -lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; -x_97 = lean_ctor_get(x_7, 0); -x_98 = lean_ctor_get(x_7, 1); -x_99 = lean_ctor_get(x_7, 2); -x_100 = lean_ctor_get(x_7, 3); -x_101 = lean_ctor_get(x_7, 4); -lean_inc(x_101); -lean_inc(x_100); -lean_inc(x_99); +lean_object* x_98; lean_object* x_99; lean_object* x_100; +x_98 = lean_ctor_get(x_94, 0); lean_inc(x_98); -lean_inc(x_97); -lean_dec(x_7); -x_102 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_102, 0, x_27); -lean_ctor_set(x_102, 1, x_14); -x_103 = lean_array_push(x_99, x_102); -x_104 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_104, 0, x_97); -lean_ctor_set(x_104, 1, x_98); -lean_ctor_set(x_104, 2, x_103); -lean_ctor_set(x_104, 3, x_100); -lean_ctor_set(x_104, 4, x_101); -x_105 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_104, x_25); -if (lean_obj_tag(x_105) == 0) -{ -lean_object* x_106; lean_object* x_107; lean_object* x_108; -x_106 = lean_ctor_get(x_105, 0); -lean_inc(x_106); -x_107 = lean_ctor_get(x_105, 1); -lean_inc(x_107); -lean_dec(x_105); -x_108 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_108, 0, x_106); -x_34 = x_108; -x_35 = x_107; -goto block_84; +x_99 = lean_ctor_get(x_94, 1); +lean_inc(x_99); +lean_dec(x_94); +x_100 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_100, 0, x_98); +x_34 = x_100; +x_35 = x_99; +goto block_88; +} } else { -lean_object* x_109; lean_object* x_110; lean_object* x_111; -x_109 = lean_ctor_get(x_105, 0); -lean_inc(x_109); -x_110 = lean_ctor_get(x_105, 1); +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; +x_101 = lean_ctor_get(x_7, 0); +x_102 = lean_ctor_get(x_7, 1); +x_103 = lean_ctor_get(x_7, 2); +x_104 = lean_ctor_get(x_7, 3); +x_105 = lean_ctor_get(x_7, 4); +lean_inc(x_105); +lean_inc(x_104); +lean_inc(x_103); +lean_inc(x_102); +lean_inc(x_101); +lean_dec(x_7); +x_106 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_106, 0, x_27); +lean_ctor_set(x_106, 1, x_14); +x_107 = lean_array_push(x_103, x_106); +x_108 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_108, 0, x_101); +lean_ctor_set(x_108, 1, x_102); +lean_ctor_set(x_108, 2, x_107); +lean_ctor_set(x_108, 3, x_104); +lean_ctor_set(x_108, 4, x_105); +x_109 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_108, x_25); +if (lean_obj_tag(x_109) == 0) +{ +lean_object* x_110; lean_object* x_111; lean_object* x_112; +x_110 = lean_ctor_get(x_109, 0); lean_inc(x_110); -lean_dec(x_105); -x_111 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_111, 0, x_109); -x_34 = x_111; -x_35 = x_110; -goto block_84; +x_111 = lean_ctor_get(x_109, 1); +lean_inc(x_111); +lean_dec(x_109); +x_112 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_112, 0, x_110); +x_34 = x_112; +x_35 = x_111; +goto block_88; +} +else +{ +lean_object* x_113; lean_object* x_114; lean_object* x_115; +x_113 = lean_ctor_get(x_109, 0); +lean_inc(x_113); +x_114 = lean_ctor_get(x_109, 1); +lean_inc(x_114); +lean_dec(x_109); +x_115 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_115, 0, x_113); +x_34 = x_115; +x_35 = x_114; +goto block_88; } } -block_84: +block_88: { if (lean_obj_tag(x_34) == 0) { @@ -33705,1284 +34773,1262 @@ return x_42; } else { -lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; +lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; x_43 = lean_ctor_get(x_36, 0); x_44 = lean_ctor_get(x_36, 1); x_45 = lean_ctor_get(x_36, 3); +x_46 = lean_ctor_get(x_36, 4); +lean_inc(x_46); lean_inc(x_45); lean_inc(x_44); lean_inc(x_43); lean_dec(x_36); -x_46 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_46, 0, x_43); -lean_ctor_set(x_46, 1, x_44); -lean_ctor_set(x_46, 2, x_33); -lean_ctor_set(x_46, 3, x_45); -lean_ctor_set(x_35, 2, x_46); +x_47 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_47, 0, x_43); +lean_ctor_set(x_47, 1, x_44); +lean_ctor_set(x_47, 2, x_33); +lean_ctor_set(x_47, 3, x_45); +lean_ctor_set(x_47, 4, x_46); +lean_ctor_set(x_35, 2, x_47); if (lean_is_scalar(x_26)) { - x_47 = lean_alloc_ctor(1, 2, 0); + x_48 = lean_alloc_ctor(1, 2, 0); } else { - x_47 = x_26; - lean_ctor_set_tag(x_47, 1); + x_48 = x_26; + lean_ctor_set_tag(x_48, 1); } -lean_ctor_set(x_47, 0, x_37); -lean_ctor_set(x_47, 1, x_35); -return x_47; +lean_ctor_set(x_48, 0, x_37); +lean_ctor_set(x_48, 1, x_35); +return x_48; } } else { -lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; -x_48 = lean_ctor_get(x_35, 0); -x_49 = lean_ctor_get(x_35, 1); -x_50 = lean_ctor_get(x_35, 3); -x_51 = lean_ctor_get(x_35, 4); -x_52 = lean_ctor_get(x_35, 5); +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; +x_49 = lean_ctor_get(x_35, 0); +x_50 = lean_ctor_get(x_35, 1); +x_51 = lean_ctor_get(x_35, 3); +x_52 = lean_ctor_get(x_35, 4); +x_53 = lean_ctor_get(x_35, 5); +lean_inc(x_53); lean_inc(x_52); lean_inc(x_51); lean_inc(x_50); lean_inc(x_49); -lean_inc(x_48); lean_dec(x_35); -x_53 = lean_ctor_get(x_36, 0); -lean_inc(x_53); -x_54 = lean_ctor_get(x_36, 1); +x_54 = lean_ctor_get(x_36, 0); lean_inc(x_54); -x_55 = lean_ctor_get(x_36, 3); +x_55 = lean_ctor_get(x_36, 1); lean_inc(x_55); +x_56 = lean_ctor_get(x_36, 3); +lean_inc(x_56); +x_57 = lean_ctor_get(x_36, 4); +lean_inc(x_57); if (lean_is_exclusive(x_36)) { lean_ctor_release(x_36, 0); lean_ctor_release(x_36, 1); lean_ctor_release(x_36, 2); lean_ctor_release(x_36, 3); - x_56 = x_36; + lean_ctor_release(x_36, 4); + x_58 = x_36; } else { lean_dec_ref(x_36); - x_56 = lean_box(0); + x_58 = lean_box(0); } -if (lean_is_scalar(x_56)) { - x_57 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_58)) { + x_59 = lean_alloc_ctor(0, 5, 0); } else { - x_57 = x_56; + x_59 = x_58; } -lean_ctor_set(x_57, 0, x_53); -lean_ctor_set(x_57, 1, x_54); -lean_ctor_set(x_57, 2, x_33); -lean_ctor_set(x_57, 3, x_55); -x_58 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_58, 0, x_48); -lean_ctor_set(x_58, 1, x_49); -lean_ctor_set(x_58, 2, x_57); -lean_ctor_set(x_58, 3, x_50); -lean_ctor_set(x_58, 4, x_51); -lean_ctor_set(x_58, 5, x_52); +lean_ctor_set(x_59, 0, x_54); +lean_ctor_set(x_59, 1, x_55); +lean_ctor_set(x_59, 2, x_33); +lean_ctor_set(x_59, 3, x_56); +lean_ctor_set(x_59, 4, x_57); +x_60 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_60, 0, x_49); +lean_ctor_set(x_60, 1, x_50); +lean_ctor_set(x_60, 2, x_59); +lean_ctor_set(x_60, 3, x_51); +lean_ctor_set(x_60, 4, x_52); +lean_ctor_set(x_60, 5, x_53); if (lean_is_scalar(x_26)) { - x_59 = lean_alloc_ctor(1, 2, 0); + x_61 = lean_alloc_ctor(1, 2, 0); } else { - x_59 = x_26; - lean_ctor_set_tag(x_59, 1); + x_61 = x_26; + lean_ctor_set_tag(x_61, 1); } -lean_ctor_set(x_59, 0, x_37); -lean_ctor_set(x_59, 1, x_58); -return x_59; +lean_ctor_set(x_61, 0, x_37); +lean_ctor_set(x_61, 1, x_60); +return x_61; } } else { -lean_object* x_60; lean_object* x_61; uint8_t x_62; -x_60 = lean_ctor_get(x_35, 2); -lean_inc(x_60); -x_61 = lean_ctor_get(x_34, 0); -lean_inc(x_61); +lean_object* x_62; lean_object* x_63; uint8_t x_64; +x_62 = lean_ctor_get(x_35, 2); +lean_inc(x_62); +x_63 = lean_ctor_get(x_34, 0); +lean_inc(x_63); lean_dec(x_34); -x_62 = !lean_is_exclusive(x_35); -if (x_62 == 0) -{ -lean_object* x_63; uint8_t x_64; -x_63 = lean_ctor_get(x_35, 2); -lean_dec(x_63); -x_64 = !lean_is_exclusive(x_60); +x_64 = !lean_is_exclusive(x_35); if (x_64 == 0) { -lean_object* x_65; lean_object* x_66; -x_65 = lean_ctor_get(x_60, 2); +lean_object* x_65; uint8_t x_66; +x_65 = lean_ctor_get(x_35, 2); lean_dec(x_65); -lean_ctor_set(x_60, 2, x_33); +x_66 = !lean_is_exclusive(x_62); +if (x_66 == 0) +{ +lean_object* x_67; lean_object* x_68; +x_67 = lean_ctor_get(x_62, 2); +lean_dec(x_67); +lean_ctor_set(x_62, 2, x_33); if (lean_is_scalar(x_26)) { - x_66 = lean_alloc_ctor(0, 2, 0); + x_68 = lean_alloc_ctor(0, 2, 0); } else { - x_66 = x_26; + x_68 = x_26; } -lean_ctor_set(x_66, 0, x_61); -lean_ctor_set(x_66, 1, x_35); -return x_66; +lean_ctor_set(x_68, 0, x_63); +lean_ctor_set(x_68, 1, x_35); +return x_68; } else { -lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; -x_67 = lean_ctor_get(x_60, 0); -x_68 = lean_ctor_get(x_60, 1); -x_69 = lean_ctor_get(x_60, 3); +lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; +x_69 = lean_ctor_get(x_62, 0); +x_70 = lean_ctor_get(x_62, 1); +x_71 = lean_ctor_get(x_62, 3); +x_72 = lean_ctor_get(x_62, 4); +lean_inc(x_72); +lean_inc(x_71); +lean_inc(x_70); lean_inc(x_69); -lean_inc(x_68); -lean_inc(x_67); -lean_dec(x_60); -x_70 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_70, 0, x_67); -lean_ctor_set(x_70, 1, x_68); -lean_ctor_set(x_70, 2, x_33); -lean_ctor_set(x_70, 3, x_69); -lean_ctor_set(x_35, 2, x_70); +lean_dec(x_62); +x_73 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_73, 0, x_69); +lean_ctor_set(x_73, 1, x_70); +lean_ctor_set(x_73, 2, x_33); +lean_ctor_set(x_73, 3, x_71); +lean_ctor_set(x_73, 4, x_72); +lean_ctor_set(x_35, 2, x_73); if (lean_is_scalar(x_26)) { - x_71 = lean_alloc_ctor(0, 2, 0); + x_74 = lean_alloc_ctor(0, 2, 0); } else { - x_71 = x_26; + x_74 = x_26; } -lean_ctor_set(x_71, 0, x_61); -lean_ctor_set(x_71, 1, x_35); -return x_71; +lean_ctor_set(x_74, 0, x_63); +lean_ctor_set(x_74, 1, x_35); +return x_74; } } else { -lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; -x_72 = lean_ctor_get(x_35, 0); -x_73 = lean_ctor_get(x_35, 1); -x_74 = lean_ctor_get(x_35, 3); -x_75 = lean_ctor_get(x_35, 4); -x_76 = lean_ctor_get(x_35, 5); +lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; +x_75 = lean_ctor_get(x_35, 0); +x_76 = lean_ctor_get(x_35, 1); +x_77 = lean_ctor_get(x_35, 3); +x_78 = lean_ctor_get(x_35, 4); +x_79 = lean_ctor_get(x_35, 5); +lean_inc(x_79); +lean_inc(x_78); +lean_inc(x_77); lean_inc(x_76); lean_inc(x_75); -lean_inc(x_74); -lean_inc(x_73); -lean_inc(x_72); lean_dec(x_35); -x_77 = lean_ctor_get(x_60, 0); -lean_inc(x_77); -x_78 = lean_ctor_get(x_60, 1); -lean_inc(x_78); -x_79 = lean_ctor_get(x_60, 3); -lean_inc(x_79); -if (lean_is_exclusive(x_60)) { - lean_ctor_release(x_60, 0); - lean_ctor_release(x_60, 1); - lean_ctor_release(x_60, 2); - lean_ctor_release(x_60, 3); - x_80 = x_60; +x_80 = lean_ctor_get(x_62, 0); +lean_inc(x_80); +x_81 = lean_ctor_get(x_62, 1); +lean_inc(x_81); +x_82 = lean_ctor_get(x_62, 3); +lean_inc(x_82); +x_83 = lean_ctor_get(x_62, 4); +lean_inc(x_83); +if (lean_is_exclusive(x_62)) { + lean_ctor_release(x_62, 0); + lean_ctor_release(x_62, 1); + lean_ctor_release(x_62, 2); + lean_ctor_release(x_62, 3); + lean_ctor_release(x_62, 4); + x_84 = x_62; } else { - lean_dec_ref(x_60); - x_80 = lean_box(0); + lean_dec_ref(x_62); + x_84 = lean_box(0); } -if (lean_is_scalar(x_80)) { - x_81 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_84)) { + x_85 = lean_alloc_ctor(0, 5, 0); } else { - x_81 = x_80; + x_85 = x_84; } -lean_ctor_set(x_81, 0, x_77); -lean_ctor_set(x_81, 1, x_78); -lean_ctor_set(x_81, 2, x_33); -lean_ctor_set(x_81, 3, x_79); -x_82 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_82, 0, x_72); -lean_ctor_set(x_82, 1, x_73); -lean_ctor_set(x_82, 2, x_81); -lean_ctor_set(x_82, 3, x_74); -lean_ctor_set(x_82, 4, x_75); -lean_ctor_set(x_82, 5, x_76); +lean_ctor_set(x_85, 0, x_80); +lean_ctor_set(x_85, 1, x_81); +lean_ctor_set(x_85, 2, x_33); +lean_ctor_set(x_85, 3, x_82); +lean_ctor_set(x_85, 4, x_83); +x_86 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_86, 0, x_75); +lean_ctor_set(x_86, 1, x_76); +lean_ctor_set(x_86, 2, x_85); +lean_ctor_set(x_86, 3, x_77); +lean_ctor_set(x_86, 4, x_78); +lean_ctor_set(x_86, 5, x_79); if (lean_is_scalar(x_26)) { - x_83 = lean_alloc_ctor(0, 2, 0); + x_87 = lean_alloc_ctor(0, 2, 0); } else { - x_83 = x_26; + x_87 = x_26; } -lean_ctor_set(x_83, 0, x_61); -lean_ctor_set(x_83, 1, x_82); -return x_83; +lean_ctor_set(x_87, 0, x_63); +lean_ctor_set(x_87, 1, x_86); +return x_87; } } } } else { -lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_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; -x_112 = lean_ctor_get(x_31, 0); -x_113 = lean_ctor_get(x_31, 1); -x_114 = lean_ctor_get(x_31, 2); -x_115 = lean_ctor_get(x_31, 3); -lean_inc(x_115); -lean_inc(x_114); -lean_inc(x_113); -lean_inc(x_112); -lean_dec(x_31); -x_149 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_150 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_150, 0, x_112); -lean_ctor_set(x_150, 1, x_113); -lean_ctor_set(x_150, 2, x_149); -lean_ctor_set(x_150, 3, x_115); -lean_ctor_set(x_25, 2, x_150); -x_151 = lean_ctor_get(x_7, 0); -lean_inc(x_151); -x_152 = lean_ctor_get(x_7, 1); -lean_inc(x_152); -x_153 = lean_ctor_get(x_7, 2); -lean_inc(x_153); -x_154 = lean_ctor_get(x_7, 3); -lean_inc(x_154); -x_155 = lean_ctor_get(x_7, 4); -lean_inc(x_155); -if (lean_is_exclusive(x_7)) { - lean_ctor_release(x_7, 0); - lean_ctor_release(x_7, 1); - lean_ctor_release(x_7, 2); - lean_ctor_release(x_7, 3); - lean_ctor_release(x_7, 4); - x_156 = x_7; -} else { - lean_dec_ref(x_7); - x_156 = lean_box(0); -} -x_157 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_157, 0, x_27); -lean_ctor_set(x_157, 1, x_14); -x_158 = lean_array_push(x_153, x_157); -if (lean_is_scalar(x_156)) { - x_159 = lean_alloc_ctor(0, 5, 0); -} else { - x_159 = x_156; -} -lean_ctor_set(x_159, 0, x_151); -lean_ctor_set(x_159, 1, x_152); -lean_ctor_set(x_159, 2, x_158); -lean_ctor_set(x_159, 3, x_154); -lean_ctor_set(x_159, 4, x_155); -x_160 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_159, x_25); -if (lean_obj_tag(x_160) == 0) -{ -lean_object* x_161; lean_object* x_162; lean_object* x_163; -x_161 = lean_ctor_get(x_160, 0); -lean_inc(x_161); -x_162 = lean_ctor_get(x_160, 1); -lean_inc(x_162); -lean_dec(x_160); -x_163 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_163, 0, x_161); -x_116 = x_163; -x_117 = x_162; -goto block_148; -} -else -{ -lean_object* x_164; lean_object* x_165; lean_object* x_166; -x_164 = lean_ctor_get(x_160, 0); -lean_inc(x_164); -x_165 = lean_ctor_get(x_160, 1); -lean_inc(x_165); -lean_dec(x_160); -x_166 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_166, 0, x_164); -x_116 = x_166; -x_117 = x_165; -goto block_148; -} -block_148: -{ -if (lean_obj_tag(x_116) == 0) -{ -lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; -x_118 = lean_ctor_get(x_117, 2); -lean_inc(x_118); -x_119 = lean_ctor_get(x_116, 0); -lean_inc(x_119); -lean_dec(x_116); -x_120 = lean_ctor_get(x_117, 0); +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_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; +x_116 = lean_ctor_get(x_31, 0); +x_117 = lean_ctor_get(x_31, 1); +x_118 = lean_ctor_get(x_31, 2); +x_119 = lean_ctor_get(x_31, 3); +x_120 = lean_ctor_get(x_31, 4); lean_inc(x_120); -x_121 = lean_ctor_get(x_117, 1); -lean_inc(x_121); -x_122 = lean_ctor_get(x_117, 3); -lean_inc(x_122); -x_123 = lean_ctor_get(x_117, 4); -lean_inc(x_123); -x_124 = lean_ctor_get(x_117, 5); -lean_inc(x_124); -if (lean_is_exclusive(x_117)) { - lean_ctor_release(x_117, 0); - lean_ctor_release(x_117, 1); - lean_ctor_release(x_117, 2); - lean_ctor_release(x_117, 3); - lean_ctor_release(x_117, 4); - lean_ctor_release(x_117, 5); - x_125 = x_117; -} else { - lean_dec_ref(x_117); - x_125 = lean_box(0); -} -x_126 = lean_ctor_get(x_118, 0); -lean_inc(x_126); -x_127 = lean_ctor_get(x_118, 1); -lean_inc(x_127); -x_128 = lean_ctor_get(x_118, 3); -lean_inc(x_128); -if (lean_is_exclusive(x_118)) { - lean_ctor_release(x_118, 0); - lean_ctor_release(x_118, 1); - lean_ctor_release(x_118, 2); - lean_ctor_release(x_118, 3); - x_129 = x_118; -} else { - lean_dec_ref(x_118); - x_129 = lean_box(0); -} -if (lean_is_scalar(x_129)) { - x_130 = lean_alloc_ctor(0, 4, 0); -} else { - x_130 = x_129; -} -lean_ctor_set(x_130, 0, x_126); -lean_ctor_set(x_130, 1, x_127); -lean_ctor_set(x_130, 2, x_114); -lean_ctor_set(x_130, 3, x_128); -if (lean_is_scalar(x_125)) { - x_131 = lean_alloc_ctor(0, 6, 0); -} else { - x_131 = x_125; -} -lean_ctor_set(x_131, 0, x_120); -lean_ctor_set(x_131, 1, x_121); -lean_ctor_set(x_131, 2, x_130); -lean_ctor_set(x_131, 3, x_122); -lean_ctor_set(x_131, 4, x_123); -lean_ctor_set(x_131, 5, x_124); -if (lean_is_scalar(x_26)) { - x_132 = lean_alloc_ctor(1, 2, 0); -} else { - x_132 = x_26; - lean_ctor_set_tag(x_132, 1); -} -lean_ctor_set(x_132, 0, x_119); -lean_ctor_set(x_132, 1, x_131); -return x_132; -} -else -{ -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; -x_133 = lean_ctor_get(x_117, 2); -lean_inc(x_133); -x_134 = lean_ctor_get(x_116, 0); -lean_inc(x_134); -lean_dec(x_116); -x_135 = lean_ctor_get(x_117, 0); -lean_inc(x_135); -x_136 = lean_ctor_get(x_117, 1); -lean_inc(x_136); -x_137 = lean_ctor_get(x_117, 3); -lean_inc(x_137); -x_138 = lean_ctor_get(x_117, 4); -lean_inc(x_138); -x_139 = lean_ctor_get(x_117, 5); -lean_inc(x_139); -if (lean_is_exclusive(x_117)) { - lean_ctor_release(x_117, 0); - lean_ctor_release(x_117, 1); - lean_ctor_release(x_117, 2); - lean_ctor_release(x_117, 3); - lean_ctor_release(x_117, 4); - lean_ctor_release(x_117, 5); - x_140 = x_117; -} else { - lean_dec_ref(x_117); - x_140 = lean_box(0); -} -x_141 = lean_ctor_get(x_133, 0); -lean_inc(x_141); -x_142 = lean_ctor_get(x_133, 1); -lean_inc(x_142); -x_143 = lean_ctor_get(x_133, 3); -lean_inc(x_143); -if (lean_is_exclusive(x_133)) { - lean_ctor_release(x_133, 0); - lean_ctor_release(x_133, 1); - lean_ctor_release(x_133, 2); - lean_ctor_release(x_133, 3); - x_144 = x_133; -} else { - lean_dec_ref(x_133); - x_144 = lean_box(0); -} -if (lean_is_scalar(x_144)) { - x_145 = lean_alloc_ctor(0, 4, 0); -} else { - x_145 = x_144; -} -lean_ctor_set(x_145, 0, x_141); -lean_ctor_set(x_145, 1, x_142); -lean_ctor_set(x_145, 2, x_114); -lean_ctor_set(x_145, 3, x_143); -if (lean_is_scalar(x_140)) { - x_146 = lean_alloc_ctor(0, 6, 0); -} else { - x_146 = x_140; -} -lean_ctor_set(x_146, 0, x_135); -lean_ctor_set(x_146, 1, x_136); -lean_ctor_set(x_146, 2, x_145); -lean_ctor_set(x_146, 3, x_137); -lean_ctor_set(x_146, 4, x_138); -lean_ctor_set(x_146, 5, x_139); -if (lean_is_scalar(x_26)) { - x_147 = lean_alloc_ctor(0, 2, 0); -} else { - x_147 = x_26; -} -lean_ctor_set(x_147, 0, x_134); -lean_ctor_set(x_147, 1, x_146); -return x_147; -} -} -} -} -else -{ -lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; 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; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; -x_167 = lean_ctor_get(x_25, 2); -x_168 = lean_ctor_get(x_25, 0); -x_169 = lean_ctor_get(x_25, 1); -x_170 = lean_ctor_get(x_25, 3); -x_171 = lean_ctor_get(x_25, 4); -x_172 = lean_ctor_get(x_25, 5); -lean_inc(x_172); -lean_inc(x_171); -lean_inc(x_170); -lean_inc(x_167); -lean_inc(x_169); -lean_inc(x_168); -lean_dec(x_25); -x_173 = lean_ctor_get(x_167, 0); -lean_inc(x_173); -x_174 = lean_ctor_get(x_167, 1); -lean_inc(x_174); -x_175 = lean_ctor_get(x_167, 2); -lean_inc(x_175); -x_176 = lean_ctor_get(x_167, 3); -lean_inc(x_176); -if (lean_is_exclusive(x_167)) { - lean_ctor_release(x_167, 0); - lean_ctor_release(x_167, 1); - lean_ctor_release(x_167, 2); - lean_ctor_release(x_167, 3); - x_177 = x_167; -} else { - lean_dec_ref(x_167); - x_177 = lean_box(0); -} -x_211 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_177)) { - x_212 = lean_alloc_ctor(0, 4, 0); -} else { - x_212 = x_177; -} -lean_ctor_set(x_212, 0, x_173); -lean_ctor_set(x_212, 1, x_174); -lean_ctor_set(x_212, 2, x_211); -lean_ctor_set(x_212, 3, x_176); -x_213 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_213, 0, x_168); -lean_ctor_set(x_213, 1, x_169); -lean_ctor_set(x_213, 2, x_212); -lean_ctor_set(x_213, 3, x_170); -lean_ctor_set(x_213, 4, x_171); -lean_ctor_set(x_213, 5, x_172); -x_214 = lean_ctor_get(x_7, 0); -lean_inc(x_214); -x_215 = lean_ctor_get(x_7, 1); -lean_inc(x_215); -x_216 = lean_ctor_get(x_7, 2); -lean_inc(x_216); -x_217 = lean_ctor_get(x_7, 3); -lean_inc(x_217); -x_218 = lean_ctor_get(x_7, 4); -lean_inc(x_218); +lean_inc(x_119); +lean_inc(x_118); +lean_inc(x_117); +lean_inc(x_116); +lean_dec(x_31); +x_156 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_157 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_157, 0, x_116); +lean_ctor_set(x_157, 1, x_117); +lean_ctor_set(x_157, 2, x_156); +lean_ctor_set(x_157, 3, x_119); +lean_ctor_set(x_157, 4, x_120); +lean_ctor_set(x_25, 2, x_157); +x_158 = lean_ctor_get(x_7, 0); +lean_inc(x_158); +x_159 = lean_ctor_get(x_7, 1); +lean_inc(x_159); +x_160 = lean_ctor_get(x_7, 2); +lean_inc(x_160); +x_161 = lean_ctor_get(x_7, 3); +lean_inc(x_161); +x_162 = lean_ctor_get(x_7, 4); +lean_inc(x_162); if (lean_is_exclusive(x_7)) { lean_ctor_release(x_7, 0); lean_ctor_release(x_7, 1); lean_ctor_release(x_7, 2); lean_ctor_release(x_7, 3); lean_ctor_release(x_7, 4); - x_219 = x_7; + x_163 = x_7; } else { lean_dec_ref(x_7); - x_219 = lean_box(0); + x_163 = lean_box(0); } -x_220 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_220, 0, x_27); -lean_ctor_set(x_220, 1, x_14); -x_221 = lean_array_push(x_216, x_220); -if (lean_is_scalar(x_219)) { +x_164 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_164, 0, x_27); +lean_ctor_set(x_164, 1, x_14); +x_165 = lean_array_push(x_160, x_164); +if (lean_is_scalar(x_163)) { + x_166 = lean_alloc_ctor(0, 5, 0); +} else { + x_166 = x_163; +} +lean_ctor_set(x_166, 0, x_158); +lean_ctor_set(x_166, 1, x_159); +lean_ctor_set(x_166, 2, x_165); +lean_ctor_set(x_166, 3, x_161); +lean_ctor_set(x_166, 4, x_162); +x_167 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_166, x_25); +if (lean_obj_tag(x_167) == 0) +{ +lean_object* x_168; lean_object* x_169; lean_object* x_170; +x_168 = lean_ctor_get(x_167, 0); +lean_inc(x_168); +x_169 = lean_ctor_get(x_167, 1); +lean_inc(x_169); +lean_dec(x_167); +x_170 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_170, 0, x_168); +x_121 = x_170; +x_122 = x_169; +goto block_155; +} +else +{ +lean_object* x_171; lean_object* x_172; lean_object* x_173; +x_171 = lean_ctor_get(x_167, 0); +lean_inc(x_171); +x_172 = lean_ctor_get(x_167, 1); +lean_inc(x_172); +lean_dec(x_167); +x_173 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_173, 0, x_171); +x_121 = x_173; +x_122 = x_172; +goto block_155; +} +block_155: +{ +if (lean_obj_tag(x_121) == 0) +{ +lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; +x_123 = lean_ctor_get(x_122, 2); +lean_inc(x_123); +x_124 = lean_ctor_get(x_121, 0); +lean_inc(x_124); +lean_dec(x_121); +x_125 = lean_ctor_get(x_122, 0); +lean_inc(x_125); +x_126 = lean_ctor_get(x_122, 1); +lean_inc(x_126); +x_127 = lean_ctor_get(x_122, 3); +lean_inc(x_127); +x_128 = lean_ctor_get(x_122, 4); +lean_inc(x_128); +x_129 = lean_ctor_get(x_122, 5); +lean_inc(x_129); +if (lean_is_exclusive(x_122)) { + lean_ctor_release(x_122, 0); + lean_ctor_release(x_122, 1); + lean_ctor_release(x_122, 2); + lean_ctor_release(x_122, 3); + lean_ctor_release(x_122, 4); + lean_ctor_release(x_122, 5); + x_130 = x_122; +} else { + lean_dec_ref(x_122); + x_130 = lean_box(0); +} +x_131 = lean_ctor_get(x_123, 0); +lean_inc(x_131); +x_132 = lean_ctor_get(x_123, 1); +lean_inc(x_132); +x_133 = lean_ctor_get(x_123, 3); +lean_inc(x_133); +x_134 = lean_ctor_get(x_123, 4); +lean_inc(x_134); +if (lean_is_exclusive(x_123)) { + lean_ctor_release(x_123, 0); + lean_ctor_release(x_123, 1); + lean_ctor_release(x_123, 2); + lean_ctor_release(x_123, 3); + lean_ctor_release(x_123, 4); + x_135 = x_123; +} else { + lean_dec_ref(x_123); + x_135 = lean_box(0); +} +if (lean_is_scalar(x_135)) { + x_136 = lean_alloc_ctor(0, 5, 0); +} else { + x_136 = x_135; +} +lean_ctor_set(x_136, 0, x_131); +lean_ctor_set(x_136, 1, x_132); +lean_ctor_set(x_136, 2, x_118); +lean_ctor_set(x_136, 3, x_133); +lean_ctor_set(x_136, 4, x_134); +if (lean_is_scalar(x_130)) { + x_137 = lean_alloc_ctor(0, 6, 0); +} else { + x_137 = x_130; +} +lean_ctor_set(x_137, 0, x_125); +lean_ctor_set(x_137, 1, x_126); +lean_ctor_set(x_137, 2, x_136); +lean_ctor_set(x_137, 3, x_127); +lean_ctor_set(x_137, 4, x_128); +lean_ctor_set(x_137, 5, x_129); +if (lean_is_scalar(x_26)) { + x_138 = lean_alloc_ctor(1, 2, 0); +} else { + x_138 = x_26; + lean_ctor_set_tag(x_138, 1); +} +lean_ctor_set(x_138, 0, x_124); +lean_ctor_set(x_138, 1, x_137); +return x_138; +} +else +{ +lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_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; +x_139 = lean_ctor_get(x_122, 2); +lean_inc(x_139); +x_140 = lean_ctor_get(x_121, 0); +lean_inc(x_140); +lean_dec(x_121); +x_141 = lean_ctor_get(x_122, 0); +lean_inc(x_141); +x_142 = lean_ctor_get(x_122, 1); +lean_inc(x_142); +x_143 = lean_ctor_get(x_122, 3); +lean_inc(x_143); +x_144 = lean_ctor_get(x_122, 4); +lean_inc(x_144); +x_145 = lean_ctor_get(x_122, 5); +lean_inc(x_145); +if (lean_is_exclusive(x_122)) { + lean_ctor_release(x_122, 0); + lean_ctor_release(x_122, 1); + lean_ctor_release(x_122, 2); + lean_ctor_release(x_122, 3); + lean_ctor_release(x_122, 4); + lean_ctor_release(x_122, 5); + x_146 = x_122; +} else { + lean_dec_ref(x_122); + x_146 = lean_box(0); +} +x_147 = lean_ctor_get(x_139, 0); +lean_inc(x_147); +x_148 = lean_ctor_get(x_139, 1); +lean_inc(x_148); +x_149 = lean_ctor_get(x_139, 3); +lean_inc(x_149); +x_150 = lean_ctor_get(x_139, 4); +lean_inc(x_150); +if (lean_is_exclusive(x_139)) { + lean_ctor_release(x_139, 0); + lean_ctor_release(x_139, 1); + lean_ctor_release(x_139, 2); + lean_ctor_release(x_139, 3); + lean_ctor_release(x_139, 4); + x_151 = x_139; +} else { + lean_dec_ref(x_139); + x_151 = lean_box(0); +} +if (lean_is_scalar(x_151)) { + x_152 = lean_alloc_ctor(0, 5, 0); +} else { + x_152 = x_151; +} +lean_ctor_set(x_152, 0, x_147); +lean_ctor_set(x_152, 1, x_148); +lean_ctor_set(x_152, 2, x_118); +lean_ctor_set(x_152, 3, x_149); +lean_ctor_set(x_152, 4, x_150); +if (lean_is_scalar(x_146)) { + x_153 = lean_alloc_ctor(0, 6, 0); +} else { + x_153 = x_146; +} +lean_ctor_set(x_153, 0, x_141); +lean_ctor_set(x_153, 1, x_142); +lean_ctor_set(x_153, 2, x_152); +lean_ctor_set(x_153, 3, x_143); +lean_ctor_set(x_153, 4, x_144); +lean_ctor_set(x_153, 5, x_145); +if (lean_is_scalar(x_26)) { + x_154 = lean_alloc_ctor(0, 2, 0); +} else { + x_154 = x_26; +} +lean_ctor_set(x_154, 0, x_140); +lean_ctor_set(x_154, 1, x_153); +return x_154; +} +} +} +} +else +{ +lean_object* x_174; lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_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; lean_object* x_231; lean_object* x_232; lean_object* x_233; +x_174 = lean_ctor_get(x_25, 2); +x_175 = lean_ctor_get(x_25, 0); +x_176 = lean_ctor_get(x_25, 1); +x_177 = lean_ctor_get(x_25, 3); +x_178 = lean_ctor_get(x_25, 4); +x_179 = lean_ctor_get(x_25, 5); +lean_inc(x_179); +lean_inc(x_178); +lean_inc(x_177); +lean_inc(x_174); +lean_inc(x_176); +lean_inc(x_175); +lean_dec(x_25); +x_180 = lean_ctor_get(x_174, 0); +lean_inc(x_180); +x_181 = lean_ctor_get(x_174, 1); +lean_inc(x_181); +x_182 = lean_ctor_get(x_174, 2); +lean_inc(x_182); +x_183 = lean_ctor_get(x_174, 3); +lean_inc(x_183); +x_184 = lean_ctor_get(x_174, 4); +lean_inc(x_184); +if (lean_is_exclusive(x_174)) { + lean_ctor_release(x_174, 0); + lean_ctor_release(x_174, 1); + lean_ctor_release(x_174, 2); + lean_ctor_release(x_174, 3); + lean_ctor_release(x_174, 4); + x_185 = x_174; +} else { + lean_dec_ref(x_174); + x_185 = lean_box(0); +} +x_221 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_185)) { x_222 = lean_alloc_ctor(0, 5, 0); } else { - x_222 = x_219; + x_222 = x_185; } -lean_ctor_set(x_222, 0, x_214); -lean_ctor_set(x_222, 1, x_215); +lean_ctor_set(x_222, 0, x_180); +lean_ctor_set(x_222, 1, x_181); lean_ctor_set(x_222, 2, x_221); -lean_ctor_set(x_222, 3, x_217); -lean_ctor_set(x_222, 4, x_218); -x_223 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_222, x_213); -if (lean_obj_tag(x_223) == 0) -{ -lean_object* x_224; lean_object* x_225; lean_object* x_226; -x_224 = lean_ctor_get(x_223, 0); +lean_ctor_set(x_222, 3, x_183); +lean_ctor_set(x_222, 4, x_184); +x_223 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_223, 0, x_175); +lean_ctor_set(x_223, 1, x_176); +lean_ctor_set(x_223, 2, x_222); +lean_ctor_set(x_223, 3, x_177); +lean_ctor_set(x_223, 4, x_178); +lean_ctor_set(x_223, 5, x_179); +x_224 = lean_ctor_get(x_7, 0); lean_inc(x_224); -x_225 = lean_ctor_get(x_223, 1); +x_225 = lean_ctor_get(x_7, 1); lean_inc(x_225); -lean_dec(x_223); -x_226 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_226, 0, x_224); -x_178 = x_226; -x_179 = x_225; -goto block_210; -} -else -{ -lean_object* x_227; lean_object* x_228; lean_object* x_229; -x_227 = lean_ctor_get(x_223, 0); +x_226 = lean_ctor_get(x_7, 2); +lean_inc(x_226); +x_227 = lean_ctor_get(x_7, 3); lean_inc(x_227); -x_228 = lean_ctor_get(x_223, 1); +x_228 = lean_ctor_get(x_7, 4); lean_inc(x_228); -lean_dec(x_223); -x_229 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_229, 0, x_227); -x_178 = x_229; -x_179 = x_228; -goto block_210; +if (lean_is_exclusive(x_7)) { + lean_ctor_release(x_7, 0); + lean_ctor_release(x_7, 1); + lean_ctor_release(x_7, 2); + lean_ctor_release(x_7, 3); + lean_ctor_release(x_7, 4); + x_229 = x_7; +} else { + lean_dec_ref(x_7); + x_229 = lean_box(0); } -block_210: +x_230 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_230, 0, x_27); +lean_ctor_set(x_230, 1, x_14); +x_231 = lean_array_push(x_226, x_230); +if (lean_is_scalar(x_229)) { + x_232 = lean_alloc_ctor(0, 5, 0); +} else { + x_232 = x_229; +} +lean_ctor_set(x_232, 0, x_224); +lean_ctor_set(x_232, 1, x_225); +lean_ctor_set(x_232, 2, x_231); +lean_ctor_set(x_232, 3, x_227); +lean_ctor_set(x_232, 4, x_228); +x_233 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_232, x_223); +if (lean_obj_tag(x_233) == 0) { -if (lean_obj_tag(x_178) == 0) -{ -lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; -x_180 = lean_ctor_get(x_179, 2); -lean_inc(x_180); -x_181 = lean_ctor_get(x_178, 0); -lean_inc(x_181); -lean_dec(x_178); -x_182 = lean_ctor_get(x_179, 0); -lean_inc(x_182); -x_183 = lean_ctor_get(x_179, 1); -lean_inc(x_183); -x_184 = lean_ctor_get(x_179, 3); -lean_inc(x_184); -x_185 = lean_ctor_get(x_179, 4); -lean_inc(x_185); -x_186 = lean_ctor_get(x_179, 5); -lean_inc(x_186); -if (lean_is_exclusive(x_179)) { - lean_ctor_release(x_179, 0); - lean_ctor_release(x_179, 1); - lean_ctor_release(x_179, 2); - lean_ctor_release(x_179, 3); - lean_ctor_release(x_179, 4); - lean_ctor_release(x_179, 5); - x_187 = x_179; -} else { - lean_dec_ref(x_179); - x_187 = lean_box(0); -} -x_188 = lean_ctor_get(x_180, 0); -lean_inc(x_188); -x_189 = lean_ctor_get(x_180, 1); -lean_inc(x_189); -x_190 = lean_ctor_get(x_180, 3); -lean_inc(x_190); -if (lean_is_exclusive(x_180)) { - lean_ctor_release(x_180, 0); - lean_ctor_release(x_180, 1); - lean_ctor_release(x_180, 2); - lean_ctor_release(x_180, 3); - x_191 = x_180; -} else { - lean_dec_ref(x_180); - x_191 = lean_box(0); -} -if (lean_is_scalar(x_191)) { - x_192 = lean_alloc_ctor(0, 4, 0); -} else { - x_192 = x_191; -} -lean_ctor_set(x_192, 0, x_188); -lean_ctor_set(x_192, 1, x_189); -lean_ctor_set(x_192, 2, x_175); -lean_ctor_set(x_192, 3, x_190); -if (lean_is_scalar(x_187)) { - x_193 = lean_alloc_ctor(0, 6, 0); -} else { - x_193 = x_187; -} -lean_ctor_set(x_193, 0, x_182); -lean_ctor_set(x_193, 1, x_183); -lean_ctor_set(x_193, 2, x_192); -lean_ctor_set(x_193, 3, x_184); -lean_ctor_set(x_193, 4, x_185); -lean_ctor_set(x_193, 5, x_186); -if (lean_is_scalar(x_26)) { - x_194 = lean_alloc_ctor(1, 2, 0); -} else { - x_194 = x_26; - lean_ctor_set_tag(x_194, 1); -} -lean_ctor_set(x_194, 0, x_181); -lean_ctor_set(x_194, 1, x_193); -return x_194; +lean_object* x_234; lean_object* x_235; lean_object* x_236; +x_234 = lean_ctor_get(x_233, 0); +lean_inc(x_234); +x_235 = lean_ctor_get(x_233, 1); +lean_inc(x_235); +lean_dec(x_233); +x_236 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_236, 0, x_234); +x_186 = x_236; +x_187 = x_235; +goto block_220; } else { -lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; -x_195 = lean_ctor_get(x_179, 2); -lean_inc(x_195); -x_196 = lean_ctor_get(x_178, 0); +lean_object* x_237; lean_object* x_238; lean_object* x_239; +x_237 = lean_ctor_get(x_233, 0); +lean_inc(x_237); +x_238 = lean_ctor_get(x_233, 1); +lean_inc(x_238); +lean_dec(x_233); +x_239 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_239, 0, x_237); +x_186 = x_239; +x_187 = x_238; +goto block_220; +} +block_220: +{ +if (lean_obj_tag(x_186) == 0) +{ +lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; +x_188 = lean_ctor_get(x_187, 2); +lean_inc(x_188); +x_189 = lean_ctor_get(x_186, 0); +lean_inc(x_189); +lean_dec(x_186); +x_190 = lean_ctor_get(x_187, 0); +lean_inc(x_190); +x_191 = lean_ctor_get(x_187, 1); +lean_inc(x_191); +x_192 = lean_ctor_get(x_187, 3); +lean_inc(x_192); +x_193 = lean_ctor_get(x_187, 4); +lean_inc(x_193); +x_194 = lean_ctor_get(x_187, 5); +lean_inc(x_194); +if (lean_is_exclusive(x_187)) { + lean_ctor_release(x_187, 0); + lean_ctor_release(x_187, 1); + lean_ctor_release(x_187, 2); + lean_ctor_release(x_187, 3); + lean_ctor_release(x_187, 4); + lean_ctor_release(x_187, 5); + x_195 = x_187; +} else { + lean_dec_ref(x_187); + x_195 = lean_box(0); +} +x_196 = lean_ctor_get(x_188, 0); lean_inc(x_196); -lean_dec(x_178); -x_197 = lean_ctor_get(x_179, 0); +x_197 = lean_ctor_get(x_188, 1); lean_inc(x_197); -x_198 = lean_ctor_get(x_179, 1); +x_198 = lean_ctor_get(x_188, 3); lean_inc(x_198); -x_199 = lean_ctor_get(x_179, 3); +x_199 = lean_ctor_get(x_188, 4); lean_inc(x_199); -x_200 = lean_ctor_get(x_179, 4); -lean_inc(x_200); -x_201 = lean_ctor_get(x_179, 5); -lean_inc(x_201); -if (lean_is_exclusive(x_179)) { - lean_ctor_release(x_179, 0); - lean_ctor_release(x_179, 1); - lean_ctor_release(x_179, 2); - lean_ctor_release(x_179, 3); - lean_ctor_release(x_179, 4); - lean_ctor_release(x_179, 5); - x_202 = x_179; +if (lean_is_exclusive(x_188)) { + lean_ctor_release(x_188, 0); + lean_ctor_release(x_188, 1); + lean_ctor_release(x_188, 2); + lean_ctor_release(x_188, 3); + lean_ctor_release(x_188, 4); + x_200 = x_188; } else { - lean_dec_ref(x_179); - x_202 = lean_box(0); + lean_dec_ref(x_188); + x_200 = lean_box(0); } -x_203 = lean_ctor_get(x_195, 0); -lean_inc(x_203); -x_204 = lean_ctor_get(x_195, 1); -lean_inc(x_204); -x_205 = lean_ctor_get(x_195, 3); -lean_inc(x_205); -if (lean_is_exclusive(x_195)) { - lean_ctor_release(x_195, 0); - lean_ctor_release(x_195, 1); - lean_ctor_release(x_195, 2); - lean_ctor_release(x_195, 3); - x_206 = x_195; +if (lean_is_scalar(x_200)) { + x_201 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_195); - x_206 = lean_box(0); + x_201 = x_200; } -if (lean_is_scalar(x_206)) { - x_207 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_201, 0, x_196); +lean_ctor_set(x_201, 1, x_197); +lean_ctor_set(x_201, 2, x_182); +lean_ctor_set(x_201, 3, x_198); +lean_ctor_set(x_201, 4, x_199); +if (lean_is_scalar(x_195)) { + x_202 = lean_alloc_ctor(0, 6, 0); } else { - x_207 = x_206; + x_202 = x_195; } -lean_ctor_set(x_207, 0, x_203); -lean_ctor_set(x_207, 1, x_204); -lean_ctor_set(x_207, 2, x_175); -lean_ctor_set(x_207, 3, x_205); -if (lean_is_scalar(x_202)) { - x_208 = lean_alloc_ctor(0, 6, 0); -} else { - x_208 = x_202; -} -lean_ctor_set(x_208, 0, x_197); -lean_ctor_set(x_208, 1, x_198); -lean_ctor_set(x_208, 2, x_207); -lean_ctor_set(x_208, 3, x_199); -lean_ctor_set(x_208, 4, x_200); -lean_ctor_set(x_208, 5, x_201); +lean_ctor_set(x_202, 0, x_190); +lean_ctor_set(x_202, 1, x_191); +lean_ctor_set(x_202, 2, x_201); +lean_ctor_set(x_202, 3, x_192); +lean_ctor_set(x_202, 4, x_193); +lean_ctor_set(x_202, 5, x_194); if (lean_is_scalar(x_26)) { - x_209 = lean_alloc_ctor(0, 2, 0); + x_203 = lean_alloc_ctor(1, 2, 0); } else { - x_209 = x_26; + x_203 = x_26; + lean_ctor_set_tag(x_203, 1); } -lean_ctor_set(x_209, 0, x_196); -lean_ctor_set(x_209, 1, x_208); -return x_209; +lean_ctor_set(x_203, 0, x_189); +lean_ctor_set(x_203, 1, x_202); +return x_203; +} +else +{ +lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; +x_204 = lean_ctor_get(x_187, 2); +lean_inc(x_204); +x_205 = lean_ctor_get(x_186, 0); +lean_inc(x_205); +lean_dec(x_186); +x_206 = lean_ctor_get(x_187, 0); +lean_inc(x_206); +x_207 = lean_ctor_get(x_187, 1); +lean_inc(x_207); +x_208 = lean_ctor_get(x_187, 3); +lean_inc(x_208); +x_209 = lean_ctor_get(x_187, 4); +lean_inc(x_209); +x_210 = lean_ctor_get(x_187, 5); +lean_inc(x_210); +if (lean_is_exclusive(x_187)) { + lean_ctor_release(x_187, 0); + lean_ctor_release(x_187, 1); + lean_ctor_release(x_187, 2); + lean_ctor_release(x_187, 3); + lean_ctor_release(x_187, 4); + lean_ctor_release(x_187, 5); + x_211 = x_187; +} else { + lean_dec_ref(x_187); + x_211 = lean_box(0); +} +x_212 = lean_ctor_get(x_204, 0); +lean_inc(x_212); +x_213 = lean_ctor_get(x_204, 1); +lean_inc(x_213); +x_214 = lean_ctor_get(x_204, 3); +lean_inc(x_214); +x_215 = lean_ctor_get(x_204, 4); +lean_inc(x_215); +if (lean_is_exclusive(x_204)) { + lean_ctor_release(x_204, 0); + lean_ctor_release(x_204, 1); + lean_ctor_release(x_204, 2); + lean_ctor_release(x_204, 3); + lean_ctor_release(x_204, 4); + x_216 = x_204; +} else { + lean_dec_ref(x_204); + x_216 = lean_box(0); +} +if (lean_is_scalar(x_216)) { + x_217 = lean_alloc_ctor(0, 5, 0); +} else { + x_217 = x_216; +} +lean_ctor_set(x_217, 0, x_212); +lean_ctor_set(x_217, 1, x_213); +lean_ctor_set(x_217, 2, x_182); +lean_ctor_set(x_217, 3, x_214); +lean_ctor_set(x_217, 4, x_215); +if (lean_is_scalar(x_211)) { + x_218 = lean_alloc_ctor(0, 6, 0); +} else { + x_218 = x_211; +} +lean_ctor_set(x_218, 0, x_206); +lean_ctor_set(x_218, 1, x_207); +lean_ctor_set(x_218, 2, x_217); +lean_ctor_set(x_218, 3, x_208); +lean_ctor_set(x_218, 4, x_209); +lean_ctor_set(x_218, 5, x_210); +if (lean_is_scalar(x_26)) { + x_219 = lean_alloc_ctor(0, 2, 0); +} else { + x_219 = x_26; +} +lean_ctor_set(x_219, 0, x_205); +lean_ctor_set(x_219, 1, x_218); +return x_219; } } } } default: { -lean_object* x_230; lean_object* x_231; -x_230 = lean_ctor_get(x_19, 1); -lean_inc(x_230); +lean_object* x_240; lean_object* x_241; +x_240 = lean_ctor_get(x_19, 1); +lean_inc(x_240); lean_dec(x_19); lean_inc(x_7); -x_231 = l_Lean_Meta_isClassExpensive___main(x_18, x_7, x_230); -if (lean_obj_tag(x_231) == 0) +x_241 = l_Lean_Meta_isClassExpensive___main(x_18, x_7, x_240); +if (lean_obj_tag(x_241) == 0) { -lean_object* x_232; -x_232 = lean_ctor_get(x_231, 0); -lean_inc(x_232); -if (lean_obj_tag(x_232) == 0) +lean_object* x_242; +x_242 = lean_ctor_get(x_241, 0); +lean_inc(x_242); +if (lean_obj_tag(x_242) == 0) { -lean_object* x_233; lean_object* x_234; lean_object* x_235; +lean_object* x_243; lean_object* x_244; lean_object* x_245; lean_dec(x_14); -x_233 = lean_ctor_get(x_231, 1); -lean_inc(x_233); -lean_dec(x_231); -x_234 = lean_unsigned_to_nat(1u); -x_235 = lean_nat_add(x_6, x_234); +x_243 = lean_ctor_get(x_241, 1); +lean_inc(x_243); +lean_dec(x_241); +x_244 = lean_unsigned_to_nat(1u); +x_245 = lean_nat_add(x_6, x_244); lean_dec(x_6); -x_6 = x_235; -x_8 = x_233; +x_6 = x_245; +x_8 = x_243; goto _start; } else { -lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; uint8_t x_242; -x_237 = lean_ctor_get(x_231, 1); -lean_inc(x_237); -if (lean_is_exclusive(x_231)) { - lean_ctor_release(x_231, 0); - lean_ctor_release(x_231, 1); - x_238 = x_231; +lean_object* x_247; lean_object* x_248; lean_object* x_249; lean_object* x_250; lean_object* x_251; uint8_t x_252; +x_247 = lean_ctor_get(x_241, 1); +lean_inc(x_247); +if (lean_is_exclusive(x_241)) { + lean_ctor_release(x_241, 0); + lean_ctor_release(x_241, 1); + x_248 = x_241; } else { - lean_dec_ref(x_231); - x_238 = lean_box(0); + lean_dec_ref(x_241); + x_248 = lean_box(0); } -x_239 = lean_ctor_get(x_232, 0); -lean_inc(x_239); -lean_dec(x_232); -x_240 = lean_unsigned_to_nat(1u); -x_241 = lean_nat_add(x_6, x_240); -lean_dec(x_6); -x_242 = !lean_is_exclusive(x_237); -if (x_242 == 0) -{ -lean_object* x_243; uint8_t x_244; -x_243 = lean_ctor_get(x_237, 2); -x_244 = !lean_is_exclusive(x_243); -if (x_244 == 0) -{ -lean_object* x_245; lean_object* x_246; lean_object* x_247; lean_object* x_297; uint8_t x_298; -x_245 = lean_ctor_get(x_243, 2); -x_297 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_243, 2, x_297); -x_298 = !lean_is_exclusive(x_7); -if (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_7, 2); -x_300 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_300, 0, x_239); -lean_ctor_set(x_300, 1, x_14); -x_301 = lean_array_push(x_299, x_300); -lean_ctor_set(x_7, 2, x_301); -x_302 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_241, x_7, x_237); -if (lean_obj_tag(x_302) == 0) -{ -lean_object* x_303; lean_object* x_304; lean_object* x_305; -x_303 = lean_ctor_get(x_302, 0); -lean_inc(x_303); -x_304 = lean_ctor_get(x_302, 1); -lean_inc(x_304); -lean_dec(x_302); -x_305 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_305, 0, x_303); -x_246 = x_305; -x_247 = x_304; -goto block_296; -} -else -{ -lean_object* x_306; lean_object* x_307; lean_object* x_308; -x_306 = lean_ctor_get(x_302, 0); -lean_inc(x_306); -x_307 = lean_ctor_get(x_302, 1); -lean_inc(x_307); -lean_dec(x_302); -x_308 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_308, 0, x_306); -x_246 = x_308; -x_247 = x_307; -goto block_296; -} -} -else -{ -lean_object* x_309; lean_object* x_310; lean_object* x_311; lean_object* x_312; lean_object* x_313; lean_object* x_314; lean_object* x_315; lean_object* x_316; lean_object* x_317; -x_309 = lean_ctor_get(x_7, 0); -x_310 = lean_ctor_get(x_7, 1); -x_311 = lean_ctor_get(x_7, 2); -x_312 = lean_ctor_get(x_7, 3); -x_313 = lean_ctor_get(x_7, 4); -lean_inc(x_313); -lean_inc(x_312); -lean_inc(x_311); -lean_inc(x_310); -lean_inc(x_309); -lean_dec(x_7); -x_314 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_314, 0, x_239); -lean_ctor_set(x_314, 1, x_14); -x_315 = lean_array_push(x_311, x_314); -x_316 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_316, 0, x_309); -lean_ctor_set(x_316, 1, x_310); -lean_ctor_set(x_316, 2, x_315); -lean_ctor_set(x_316, 3, x_312); -lean_ctor_set(x_316, 4, x_313); -x_317 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_241, x_316, x_237); -if (lean_obj_tag(x_317) == 0) -{ -lean_object* x_318; lean_object* x_319; lean_object* x_320; -x_318 = lean_ctor_get(x_317, 0); -lean_inc(x_318); -x_319 = lean_ctor_get(x_317, 1); -lean_inc(x_319); -lean_dec(x_317); -x_320 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_320, 0, x_318); -x_246 = x_320; -x_247 = x_319; -goto block_296; -} -else -{ -lean_object* x_321; lean_object* x_322; lean_object* x_323; -x_321 = lean_ctor_get(x_317, 0); -lean_inc(x_321); -x_322 = lean_ctor_get(x_317, 1); -lean_inc(x_322); -lean_dec(x_317); -x_323 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_323, 0, x_321); -x_246 = x_323; -x_247 = x_322; -goto block_296; -} -} -block_296: -{ -if (lean_obj_tag(x_246) == 0) -{ -lean_object* x_248; lean_object* x_249; uint8_t x_250; -x_248 = lean_ctor_get(x_247, 2); -lean_inc(x_248); -x_249 = lean_ctor_get(x_246, 0); +x_249 = lean_ctor_get(x_242, 0); lean_inc(x_249); -lean_dec(x_246); -x_250 = !lean_is_exclusive(x_247); -if (x_250 == 0) -{ -lean_object* x_251; uint8_t x_252; -x_251 = lean_ctor_get(x_247, 2); -lean_dec(x_251); -x_252 = !lean_is_exclusive(x_248); +lean_dec(x_242); +x_250 = lean_unsigned_to_nat(1u); +x_251 = lean_nat_add(x_6, x_250); +lean_dec(x_6); +x_252 = !lean_is_exclusive(x_247); if (x_252 == 0) { -lean_object* x_253; lean_object* x_254; -x_253 = lean_ctor_get(x_248, 2); -lean_dec(x_253); -lean_ctor_set(x_248, 2, x_245); -if (lean_is_scalar(x_238)) { - x_254 = lean_alloc_ctor(1, 2, 0); -} else { - x_254 = x_238; - lean_ctor_set_tag(x_254, 1); -} -lean_ctor_set(x_254, 0, x_249); -lean_ctor_set(x_254, 1, x_247); -return x_254; +lean_object* x_253; uint8_t x_254; +x_253 = lean_ctor_get(x_247, 2); +x_254 = !lean_is_exclusive(x_253); +if (x_254 == 0) +{ +lean_object* x_255; lean_object* x_256; lean_object* x_257; lean_object* x_311; uint8_t x_312; +x_255 = lean_ctor_get(x_253, 2); +x_311 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_253, 2, x_311); +x_312 = !lean_is_exclusive(x_7); +if (x_312 == 0) +{ +lean_object* x_313; lean_object* x_314; lean_object* x_315; lean_object* x_316; +x_313 = lean_ctor_get(x_7, 2); +x_314 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_314, 0, x_249); +lean_ctor_set(x_314, 1, x_14); +x_315 = lean_array_push(x_313, x_314); +lean_ctor_set(x_7, 2, x_315); +x_316 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_251, x_7, x_247); +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); +x_319 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_319, 0, x_317); +x_256 = x_319; +x_257 = x_318; +goto block_310; } else { -lean_object* x_255; lean_object* x_256; lean_object* x_257; lean_object* x_258; lean_object* x_259; -x_255 = lean_ctor_get(x_248, 0); -x_256 = lean_ctor_get(x_248, 1); -x_257 = lean_ctor_get(x_248, 3); -lean_inc(x_257); -lean_inc(x_256); -lean_inc(x_255); -lean_dec(x_248); -x_258 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_258, 0, x_255); -lean_ctor_set(x_258, 1, x_256); -lean_ctor_set(x_258, 2, x_245); -lean_ctor_set(x_258, 3, x_257); -lean_ctor_set(x_247, 2, x_258); -if (lean_is_scalar(x_238)) { - x_259 = lean_alloc_ctor(1, 2, 0); -} else { - x_259 = x_238; - lean_ctor_set_tag(x_259, 1); -} -lean_ctor_set(x_259, 0, x_249); -lean_ctor_set(x_259, 1, x_247); -return x_259; +lean_object* x_320; lean_object* x_321; lean_object* x_322; +x_320 = lean_ctor_get(x_316, 0); +lean_inc(x_320); +x_321 = lean_ctor_get(x_316, 1); +lean_inc(x_321); +lean_dec(x_316); +x_322 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_322, 0, x_320); +x_256 = x_322; +x_257 = x_321; +goto block_310; } } else { -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_260 = lean_ctor_get(x_247, 0); -x_261 = lean_ctor_get(x_247, 1); -x_262 = lean_ctor_get(x_247, 3); -x_263 = lean_ctor_get(x_247, 4); -x_264 = lean_ctor_get(x_247, 5); -lean_inc(x_264); -lean_inc(x_263); -lean_inc(x_262); -lean_inc(x_261); -lean_inc(x_260); -lean_dec(x_247); -x_265 = lean_ctor_get(x_248, 0); -lean_inc(x_265); -x_266 = lean_ctor_get(x_248, 1); -lean_inc(x_266); -x_267 = lean_ctor_get(x_248, 3); +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; +x_323 = lean_ctor_get(x_7, 0); +x_324 = lean_ctor_get(x_7, 1); +x_325 = lean_ctor_get(x_7, 2); +x_326 = lean_ctor_get(x_7, 3); +x_327 = lean_ctor_get(x_7, 4); +lean_inc(x_327); +lean_inc(x_326); +lean_inc(x_325); +lean_inc(x_324); +lean_inc(x_323); +lean_dec(x_7); +x_328 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_328, 0, x_249); +lean_ctor_set(x_328, 1, x_14); +x_329 = lean_array_push(x_325, x_328); +x_330 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_330, 0, x_323); +lean_ctor_set(x_330, 1, x_324); +lean_ctor_set(x_330, 2, x_329); +lean_ctor_set(x_330, 3, x_326); +lean_ctor_set(x_330, 4, x_327); +x_331 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_251, x_330, x_247); +if (lean_obj_tag(x_331) == 0) +{ +lean_object* x_332; lean_object* x_333; lean_object* x_334; +x_332 = lean_ctor_get(x_331, 0); +lean_inc(x_332); +x_333 = lean_ctor_get(x_331, 1); +lean_inc(x_333); +lean_dec(x_331); +x_334 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_334, 0, x_332); +x_256 = x_334; +x_257 = x_333; +goto block_310; +} +else +{ +lean_object* x_335; lean_object* x_336; lean_object* x_337; +x_335 = lean_ctor_get(x_331, 0); +lean_inc(x_335); +x_336 = lean_ctor_get(x_331, 1); +lean_inc(x_336); +lean_dec(x_331); +x_337 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_337, 0, x_335); +x_256 = x_337; +x_257 = x_336; +goto block_310; +} +} +block_310: +{ +if (lean_obj_tag(x_256) == 0) +{ +lean_object* x_258; lean_object* x_259; uint8_t x_260; +x_258 = lean_ctor_get(x_257, 2); +lean_inc(x_258); +x_259 = lean_ctor_get(x_256, 0); +lean_inc(x_259); +lean_dec(x_256); +x_260 = !lean_is_exclusive(x_257); +if (x_260 == 0) +{ +lean_object* x_261; uint8_t x_262; +x_261 = lean_ctor_get(x_257, 2); +lean_dec(x_261); +x_262 = !lean_is_exclusive(x_258); +if (x_262 == 0) +{ +lean_object* x_263; lean_object* x_264; +x_263 = lean_ctor_get(x_258, 2); +lean_dec(x_263); +lean_ctor_set(x_258, 2, x_255); +if (lean_is_scalar(x_248)) { + x_264 = lean_alloc_ctor(1, 2, 0); +} else { + x_264 = x_248; + lean_ctor_set_tag(x_264, 1); +} +lean_ctor_set(x_264, 0, x_259); +lean_ctor_set(x_264, 1, x_257); +return x_264; +} +else +{ +lean_object* x_265; lean_object* x_266; lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_object* x_270; +x_265 = lean_ctor_get(x_258, 0); +x_266 = lean_ctor_get(x_258, 1); +x_267 = lean_ctor_get(x_258, 3); +x_268 = lean_ctor_get(x_258, 4); +lean_inc(x_268); lean_inc(x_267); -if (lean_is_exclusive(x_248)) { - lean_ctor_release(x_248, 0); - lean_ctor_release(x_248, 1); - lean_ctor_release(x_248, 2); - lean_ctor_release(x_248, 3); - x_268 = x_248; -} else { - lean_dec_ref(x_248); - x_268 = lean_box(0); -} -if (lean_is_scalar(x_268)) { - x_269 = lean_alloc_ctor(0, 4, 0); -} else { - x_269 = x_268; -} +lean_inc(x_266); +lean_inc(x_265); +lean_dec(x_258); +x_269 = lean_alloc_ctor(0, 5, 0); lean_ctor_set(x_269, 0, x_265); lean_ctor_set(x_269, 1, x_266); -lean_ctor_set(x_269, 2, x_245); +lean_ctor_set(x_269, 2, x_255); lean_ctor_set(x_269, 3, x_267); -x_270 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_270, 0, x_260); -lean_ctor_set(x_270, 1, x_261); -lean_ctor_set(x_270, 2, x_269); -lean_ctor_set(x_270, 3, x_262); -lean_ctor_set(x_270, 4, x_263); -lean_ctor_set(x_270, 5, x_264); -if (lean_is_scalar(x_238)) { - x_271 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_269, 4, x_268); +lean_ctor_set(x_257, 2, x_269); +if (lean_is_scalar(x_248)) { + x_270 = lean_alloc_ctor(1, 2, 0); } else { - x_271 = x_238; - lean_ctor_set_tag(x_271, 1); + x_270 = x_248; + lean_ctor_set_tag(x_270, 1); } -lean_ctor_set(x_271, 0, x_249); -lean_ctor_set(x_271, 1, x_270); -return x_271; +lean_ctor_set(x_270, 0, x_259); +lean_ctor_set(x_270, 1, x_257); +return x_270; } } else { -lean_object* x_272; lean_object* x_273; uint8_t x_274; -x_272 = lean_ctor_get(x_247, 2); -lean_inc(x_272); -x_273 = lean_ctor_get(x_246, 0); +lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_object* x_276; lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; lean_object* x_281; lean_object* x_282; lean_object* x_283; +x_271 = lean_ctor_get(x_257, 0); +x_272 = lean_ctor_get(x_257, 1); +x_273 = lean_ctor_get(x_257, 3); +x_274 = lean_ctor_get(x_257, 4); +x_275 = lean_ctor_get(x_257, 5); +lean_inc(x_275); +lean_inc(x_274); lean_inc(x_273); -lean_dec(x_246); -x_274 = !lean_is_exclusive(x_247); -if (x_274 == 0) -{ -lean_object* x_275; uint8_t x_276; -x_275 = lean_ctor_get(x_247, 2); -lean_dec(x_275); -x_276 = !lean_is_exclusive(x_272); -if (x_276 == 0) -{ -lean_object* x_277; lean_object* x_278; -x_277 = lean_ctor_get(x_272, 2); -lean_dec(x_277); -lean_ctor_set(x_272, 2, x_245); -if (lean_is_scalar(x_238)) { - x_278 = lean_alloc_ctor(0, 2, 0); -} else { - x_278 = x_238; -} -lean_ctor_set(x_278, 0, x_273); -lean_ctor_set(x_278, 1, x_247); -return x_278; -} -else -{ -lean_object* x_279; lean_object* x_280; lean_object* x_281; lean_object* x_282; lean_object* x_283; -x_279 = lean_ctor_get(x_272, 0); -x_280 = lean_ctor_get(x_272, 1); -x_281 = lean_ctor_get(x_272, 3); -lean_inc(x_281); -lean_inc(x_280); +lean_inc(x_272); +lean_inc(x_271); +lean_dec(x_257); +x_276 = lean_ctor_get(x_258, 0); +lean_inc(x_276); +x_277 = lean_ctor_get(x_258, 1); +lean_inc(x_277); +x_278 = lean_ctor_get(x_258, 3); +lean_inc(x_278); +x_279 = lean_ctor_get(x_258, 4); lean_inc(x_279); -lean_dec(x_272); -x_282 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_282, 0, x_279); -lean_ctor_set(x_282, 1, x_280); -lean_ctor_set(x_282, 2, x_245); -lean_ctor_set(x_282, 3, x_281); -lean_ctor_set(x_247, 2, x_282); -if (lean_is_scalar(x_238)) { - x_283 = lean_alloc_ctor(0, 2, 0); +if (lean_is_exclusive(x_258)) { + lean_ctor_release(x_258, 0); + lean_ctor_release(x_258, 1); + lean_ctor_release(x_258, 2); + lean_ctor_release(x_258, 3); + lean_ctor_release(x_258, 4); + x_280 = x_258; } else { - x_283 = x_238; + lean_dec_ref(x_258); + x_280 = lean_box(0); } -lean_ctor_set(x_283, 0, x_273); -lean_ctor_set(x_283, 1, x_247); +if (lean_is_scalar(x_280)) { + x_281 = lean_alloc_ctor(0, 5, 0); +} else { + x_281 = x_280; +} +lean_ctor_set(x_281, 0, x_276); +lean_ctor_set(x_281, 1, x_277); +lean_ctor_set(x_281, 2, x_255); +lean_ctor_set(x_281, 3, x_278); +lean_ctor_set(x_281, 4, x_279); +x_282 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_282, 0, x_271); +lean_ctor_set(x_282, 1, x_272); +lean_ctor_set(x_282, 2, x_281); +lean_ctor_set(x_282, 3, x_273); +lean_ctor_set(x_282, 4, x_274); +lean_ctor_set(x_282, 5, x_275); +if (lean_is_scalar(x_248)) { + x_283 = lean_alloc_ctor(1, 2, 0); +} else { + x_283 = x_248; + lean_ctor_set_tag(x_283, 1); +} +lean_ctor_set(x_283, 0, x_259); +lean_ctor_set(x_283, 1, x_282); return x_283; } } else { -lean_object* x_284; lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; lean_object* x_289; lean_object* x_290; lean_object* x_291; lean_object* x_292; lean_object* x_293; lean_object* x_294; lean_object* x_295; -x_284 = lean_ctor_get(x_247, 0); -x_285 = lean_ctor_get(x_247, 1); -x_286 = lean_ctor_get(x_247, 3); -x_287 = lean_ctor_get(x_247, 4); -x_288 = lean_ctor_get(x_247, 5); -lean_inc(x_288); -lean_inc(x_287); -lean_inc(x_286); -lean_inc(x_285); +lean_object* x_284; lean_object* x_285; uint8_t x_286; +x_284 = lean_ctor_get(x_257, 2); lean_inc(x_284); -lean_dec(x_247); -x_289 = lean_ctor_get(x_272, 0); -lean_inc(x_289); -x_290 = lean_ctor_get(x_272, 1); -lean_inc(x_290); -x_291 = lean_ctor_get(x_272, 3); +x_285 = lean_ctor_get(x_256, 0); +lean_inc(x_285); +lean_dec(x_256); +x_286 = !lean_is_exclusive(x_257); +if (x_286 == 0) +{ +lean_object* x_287; uint8_t x_288; +x_287 = lean_ctor_get(x_257, 2); +lean_dec(x_287); +x_288 = !lean_is_exclusive(x_284); +if (x_288 == 0) +{ +lean_object* x_289; lean_object* x_290; +x_289 = lean_ctor_get(x_284, 2); +lean_dec(x_289); +lean_ctor_set(x_284, 2, x_255); +if (lean_is_scalar(x_248)) { + x_290 = lean_alloc_ctor(0, 2, 0); +} else { + x_290 = x_248; +} +lean_ctor_set(x_290, 0, x_285); +lean_ctor_set(x_290, 1, x_257); +return x_290; +} +else +{ +lean_object* x_291; lean_object* x_292; lean_object* x_293; lean_object* x_294; lean_object* x_295; lean_object* x_296; +x_291 = lean_ctor_get(x_284, 0); +x_292 = lean_ctor_get(x_284, 1); +x_293 = lean_ctor_get(x_284, 3); +x_294 = lean_ctor_get(x_284, 4); +lean_inc(x_294); +lean_inc(x_293); +lean_inc(x_292); lean_inc(x_291); -if (lean_is_exclusive(x_272)) { - lean_ctor_release(x_272, 0); - lean_ctor_release(x_272, 1); - lean_ctor_release(x_272, 2); - lean_ctor_release(x_272, 3); - x_292 = x_272; +lean_dec(x_284); +x_295 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_295, 0, x_291); +lean_ctor_set(x_295, 1, x_292); +lean_ctor_set(x_295, 2, x_255); +lean_ctor_set(x_295, 3, x_293); +lean_ctor_set(x_295, 4, x_294); +lean_ctor_set(x_257, 2, x_295); +if (lean_is_scalar(x_248)) { + x_296 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_272); - x_292 = lean_box(0); + x_296 = x_248; } -if (lean_is_scalar(x_292)) { - x_293 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_296, 0, x_285); +lean_ctor_set(x_296, 1, x_257); +return x_296; +} +} +else +{ +lean_object* x_297; lean_object* x_298; lean_object* x_299; lean_object* x_300; lean_object* x_301; lean_object* x_302; lean_object* x_303; lean_object* x_304; lean_object* x_305; lean_object* x_306; lean_object* x_307; lean_object* x_308; lean_object* x_309; +x_297 = lean_ctor_get(x_257, 0); +x_298 = lean_ctor_get(x_257, 1); +x_299 = lean_ctor_get(x_257, 3); +x_300 = lean_ctor_get(x_257, 4); +x_301 = lean_ctor_get(x_257, 5); +lean_inc(x_301); +lean_inc(x_300); +lean_inc(x_299); +lean_inc(x_298); +lean_inc(x_297); +lean_dec(x_257); +x_302 = lean_ctor_get(x_284, 0); +lean_inc(x_302); +x_303 = lean_ctor_get(x_284, 1); +lean_inc(x_303); +x_304 = lean_ctor_get(x_284, 3); +lean_inc(x_304); +x_305 = lean_ctor_get(x_284, 4); +lean_inc(x_305); +if (lean_is_exclusive(x_284)) { + lean_ctor_release(x_284, 0); + lean_ctor_release(x_284, 1); + lean_ctor_release(x_284, 2); + lean_ctor_release(x_284, 3); + lean_ctor_release(x_284, 4); + x_306 = x_284; } else { - x_293 = x_292; + lean_dec_ref(x_284); + x_306 = lean_box(0); } -lean_ctor_set(x_293, 0, x_289); -lean_ctor_set(x_293, 1, x_290); -lean_ctor_set(x_293, 2, x_245); -lean_ctor_set(x_293, 3, x_291); -x_294 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_294, 0, x_284); -lean_ctor_set(x_294, 1, x_285); -lean_ctor_set(x_294, 2, x_293); -lean_ctor_set(x_294, 3, x_286); -lean_ctor_set(x_294, 4, x_287); -lean_ctor_set(x_294, 5, x_288); -if (lean_is_scalar(x_238)) { - x_295 = lean_alloc_ctor(0, 2, 0); +if (lean_is_scalar(x_306)) { + x_307 = lean_alloc_ctor(0, 5, 0); } else { - x_295 = x_238; + x_307 = x_306; } -lean_ctor_set(x_295, 0, x_273); -lean_ctor_set(x_295, 1, x_294); -return x_295; +lean_ctor_set(x_307, 0, x_302); +lean_ctor_set(x_307, 1, x_303); +lean_ctor_set(x_307, 2, x_255); +lean_ctor_set(x_307, 3, x_304); +lean_ctor_set(x_307, 4, x_305); +x_308 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_308, 0, x_297); +lean_ctor_set(x_308, 1, x_298); +lean_ctor_set(x_308, 2, x_307); +lean_ctor_set(x_308, 3, x_299); +lean_ctor_set(x_308, 4, x_300); +lean_ctor_set(x_308, 5, x_301); +if (lean_is_scalar(x_248)) { + x_309 = lean_alloc_ctor(0, 2, 0); +} else { + x_309 = x_248; +} +lean_ctor_set(x_309, 0, x_285); +lean_ctor_set(x_309, 1, x_308); +return x_309; } } } } else { -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_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; -x_324 = lean_ctor_get(x_243, 0); -x_325 = lean_ctor_get(x_243, 1); -x_326 = lean_ctor_get(x_243, 2); -x_327 = lean_ctor_get(x_243, 3); -lean_inc(x_327); -lean_inc(x_326); -lean_inc(x_325); -lean_inc(x_324); -lean_dec(x_243); -x_361 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_362 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_362, 0, x_324); -lean_ctor_set(x_362, 1, x_325); -lean_ctor_set(x_362, 2, x_361); -lean_ctor_set(x_362, 3, x_327); -lean_ctor_set(x_237, 2, x_362); -x_363 = lean_ctor_get(x_7, 0); -lean_inc(x_363); -x_364 = lean_ctor_get(x_7, 1); -lean_inc(x_364); -x_365 = lean_ctor_get(x_7, 2); -lean_inc(x_365); -x_366 = lean_ctor_get(x_7, 3); -lean_inc(x_366); -x_367 = lean_ctor_get(x_7, 4); -lean_inc(x_367); +lean_object* x_338; lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; lean_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; +x_338 = lean_ctor_get(x_253, 0); +x_339 = lean_ctor_get(x_253, 1); +x_340 = lean_ctor_get(x_253, 2); +x_341 = lean_ctor_get(x_253, 3); +x_342 = lean_ctor_get(x_253, 4); +lean_inc(x_342); +lean_inc(x_341); +lean_inc(x_340); +lean_inc(x_339); +lean_inc(x_338); +lean_dec(x_253); +x_378 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_379 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_379, 0, x_338); +lean_ctor_set(x_379, 1, x_339); +lean_ctor_set(x_379, 2, x_378); +lean_ctor_set(x_379, 3, x_341); +lean_ctor_set(x_379, 4, x_342); +lean_ctor_set(x_247, 2, x_379); +x_380 = lean_ctor_get(x_7, 0); +lean_inc(x_380); +x_381 = lean_ctor_get(x_7, 1); +lean_inc(x_381); +x_382 = lean_ctor_get(x_7, 2); +lean_inc(x_382); +x_383 = lean_ctor_get(x_7, 3); +lean_inc(x_383); +x_384 = lean_ctor_get(x_7, 4); +lean_inc(x_384); if (lean_is_exclusive(x_7)) { lean_ctor_release(x_7, 0); lean_ctor_release(x_7, 1); lean_ctor_release(x_7, 2); lean_ctor_release(x_7, 3); lean_ctor_release(x_7, 4); - x_368 = x_7; + x_385 = x_7; } else { lean_dec_ref(x_7); - x_368 = lean_box(0); + x_385 = lean_box(0); } -x_369 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_369, 0, x_239); -lean_ctor_set(x_369, 1, x_14); -x_370 = lean_array_push(x_365, x_369); -if (lean_is_scalar(x_368)) { - x_371 = lean_alloc_ctor(0, 5, 0); +x_386 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_386, 0, x_249); +lean_ctor_set(x_386, 1, x_14); +x_387 = lean_array_push(x_382, x_386); +if (lean_is_scalar(x_385)) { + x_388 = lean_alloc_ctor(0, 5, 0); } else { - x_371 = x_368; + x_388 = x_385; } -lean_ctor_set(x_371, 0, x_363); -lean_ctor_set(x_371, 1, x_364); -lean_ctor_set(x_371, 2, x_370); -lean_ctor_set(x_371, 3, x_366); -lean_ctor_set(x_371, 4, x_367); -x_372 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_241, x_371, x_237); -if (lean_obj_tag(x_372) == 0) +lean_ctor_set(x_388, 0, x_380); +lean_ctor_set(x_388, 1, x_381); +lean_ctor_set(x_388, 2, x_387); +lean_ctor_set(x_388, 3, x_383); +lean_ctor_set(x_388, 4, x_384); +x_389 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_251, x_388, x_247); +if (lean_obj_tag(x_389) == 0) { -lean_object* x_373; lean_object* x_374; lean_object* x_375; -x_373 = lean_ctor_get(x_372, 0); -lean_inc(x_373); -x_374 = lean_ctor_get(x_372, 1); -lean_inc(x_374); -lean_dec(x_372); -x_375 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_375, 0, x_373); -x_328 = x_375; -x_329 = x_374; -goto block_360; +lean_object* x_390; lean_object* x_391; lean_object* x_392; +x_390 = lean_ctor_get(x_389, 0); +lean_inc(x_390); +x_391 = lean_ctor_get(x_389, 1); +lean_inc(x_391); +lean_dec(x_389); +x_392 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_392, 0, x_390); +x_343 = x_392; +x_344 = x_391; +goto block_377; } else { -lean_object* x_376; lean_object* x_377; lean_object* x_378; -x_376 = lean_ctor_get(x_372, 0); -lean_inc(x_376); -x_377 = lean_ctor_get(x_372, 1); -lean_inc(x_377); -lean_dec(x_372); -x_378 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_378, 0, x_376); -x_328 = x_378; -x_329 = x_377; -goto block_360; +lean_object* x_393; lean_object* x_394; lean_object* x_395; +x_393 = lean_ctor_get(x_389, 0); +lean_inc(x_393); +x_394 = lean_ctor_get(x_389, 1); +lean_inc(x_394); +lean_dec(x_389); +x_395 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_395, 0, x_393); +x_343 = x_395; +x_344 = x_394; +goto block_377; } -block_360: +block_377: { -if (lean_obj_tag(x_328) == 0) +if (lean_obj_tag(x_343) == 0) { -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; lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; -x_330 = lean_ctor_get(x_329, 2); -lean_inc(x_330); -x_331 = lean_ctor_get(x_328, 0); -lean_inc(x_331); -lean_dec(x_328); -x_332 = lean_ctor_get(x_329, 0); -lean_inc(x_332); -x_333 = lean_ctor_get(x_329, 1); -lean_inc(x_333); -x_334 = lean_ctor_get(x_329, 3); -lean_inc(x_334); -x_335 = lean_ctor_get(x_329, 4); -lean_inc(x_335); -x_336 = lean_ctor_get(x_329, 5); -lean_inc(x_336); -if (lean_is_exclusive(x_329)) { - lean_ctor_release(x_329, 0); - lean_ctor_release(x_329, 1); - lean_ctor_release(x_329, 2); - lean_ctor_release(x_329, 3); - lean_ctor_release(x_329, 4); - lean_ctor_release(x_329, 5); - x_337 = x_329; -} else { - lean_dec_ref(x_329); - x_337 = lean_box(0); -} -x_338 = lean_ctor_get(x_330, 0); -lean_inc(x_338); -x_339 = lean_ctor_get(x_330, 1); -lean_inc(x_339); -x_340 = lean_ctor_get(x_330, 3); -lean_inc(x_340); -if (lean_is_exclusive(x_330)) { - lean_ctor_release(x_330, 0); - lean_ctor_release(x_330, 1); - lean_ctor_release(x_330, 2); - lean_ctor_release(x_330, 3); - x_341 = x_330; -} else { - lean_dec_ref(x_330); - x_341 = lean_box(0); -} -if (lean_is_scalar(x_341)) { - x_342 = lean_alloc_ctor(0, 4, 0); -} else { - x_342 = x_341; -} -lean_ctor_set(x_342, 0, x_338); -lean_ctor_set(x_342, 1, x_339); -lean_ctor_set(x_342, 2, x_326); -lean_ctor_set(x_342, 3, x_340); -if (lean_is_scalar(x_337)) { - x_343 = lean_alloc_ctor(0, 6, 0); -} else { - x_343 = x_337; -} -lean_ctor_set(x_343, 0, x_332); -lean_ctor_set(x_343, 1, x_333); -lean_ctor_set(x_343, 2, x_342); -lean_ctor_set(x_343, 3, x_334); -lean_ctor_set(x_343, 4, x_335); -lean_ctor_set(x_343, 5, x_336); -if (lean_is_scalar(x_238)) { - x_344 = lean_alloc_ctor(1, 2, 0); -} else { - x_344 = x_238; - lean_ctor_set_tag(x_344, 1); -} -lean_ctor_set(x_344, 0, x_331); -lean_ctor_set(x_344, 1, x_343); -return x_344; -} -else -{ -lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; lean_object* x_350; lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; lean_object* x_358; lean_object* x_359; -x_345 = lean_ctor_get(x_329, 2); +lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; lean_object* x_350; lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; lean_object* x_358; lean_object* x_359; lean_object* x_360; +x_345 = lean_ctor_get(x_344, 2); lean_inc(x_345); -x_346 = lean_ctor_get(x_328, 0); +x_346 = lean_ctor_get(x_343, 0); lean_inc(x_346); -lean_dec(x_328); -x_347 = lean_ctor_get(x_329, 0); +lean_dec(x_343); +x_347 = lean_ctor_get(x_344, 0); lean_inc(x_347); -x_348 = lean_ctor_get(x_329, 1); +x_348 = lean_ctor_get(x_344, 1); lean_inc(x_348); -x_349 = lean_ctor_get(x_329, 3); +x_349 = lean_ctor_get(x_344, 3); lean_inc(x_349); -x_350 = lean_ctor_get(x_329, 4); +x_350 = lean_ctor_get(x_344, 4); lean_inc(x_350); -x_351 = lean_ctor_get(x_329, 5); +x_351 = lean_ctor_get(x_344, 5); lean_inc(x_351); -if (lean_is_exclusive(x_329)) { - lean_ctor_release(x_329, 0); - lean_ctor_release(x_329, 1); - lean_ctor_release(x_329, 2); - lean_ctor_release(x_329, 3); - lean_ctor_release(x_329, 4); - lean_ctor_release(x_329, 5); - x_352 = x_329; +if (lean_is_exclusive(x_344)) { + lean_ctor_release(x_344, 0); + lean_ctor_release(x_344, 1); + lean_ctor_release(x_344, 2); + lean_ctor_release(x_344, 3); + lean_ctor_release(x_344, 4); + lean_ctor_release(x_344, 5); + x_352 = x_344; } else { - lean_dec_ref(x_329); + lean_dec_ref(x_344); x_352 = lean_box(0); } x_353 = lean_ctor_get(x_345, 0); @@ -34991,315 +36037,411 @@ x_354 = lean_ctor_get(x_345, 1); lean_inc(x_354); x_355 = lean_ctor_get(x_345, 3); lean_inc(x_355); +x_356 = lean_ctor_get(x_345, 4); +lean_inc(x_356); if (lean_is_exclusive(x_345)) { lean_ctor_release(x_345, 0); lean_ctor_release(x_345, 1); lean_ctor_release(x_345, 2); lean_ctor_release(x_345, 3); - x_356 = x_345; + lean_ctor_release(x_345, 4); + x_357 = x_345; } else { lean_dec_ref(x_345); - x_356 = lean_box(0); + x_357 = lean_box(0); } -if (lean_is_scalar(x_356)) { - x_357 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_357)) { + x_358 = lean_alloc_ctor(0, 5, 0); } else { - x_357 = x_356; + x_358 = x_357; } -lean_ctor_set(x_357, 0, x_353); -lean_ctor_set(x_357, 1, x_354); -lean_ctor_set(x_357, 2, x_326); -lean_ctor_set(x_357, 3, x_355); +lean_ctor_set(x_358, 0, x_353); +lean_ctor_set(x_358, 1, x_354); +lean_ctor_set(x_358, 2, x_340); +lean_ctor_set(x_358, 3, x_355); +lean_ctor_set(x_358, 4, x_356); if (lean_is_scalar(x_352)) { - x_358 = lean_alloc_ctor(0, 6, 0); + x_359 = lean_alloc_ctor(0, 6, 0); } else { - x_358 = x_352; + x_359 = x_352; } -lean_ctor_set(x_358, 0, x_347); -lean_ctor_set(x_358, 1, x_348); -lean_ctor_set(x_358, 2, x_357); -lean_ctor_set(x_358, 3, x_349); -lean_ctor_set(x_358, 4, x_350); -lean_ctor_set(x_358, 5, x_351); -if (lean_is_scalar(x_238)) { - x_359 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_359, 0, x_347); +lean_ctor_set(x_359, 1, x_348); +lean_ctor_set(x_359, 2, x_358); +lean_ctor_set(x_359, 3, x_349); +lean_ctor_set(x_359, 4, x_350); +lean_ctor_set(x_359, 5, x_351); +if (lean_is_scalar(x_248)) { + x_360 = lean_alloc_ctor(1, 2, 0); } else { - x_359 = x_238; + x_360 = x_248; + lean_ctor_set_tag(x_360, 1); } -lean_ctor_set(x_359, 0, x_346); -lean_ctor_set(x_359, 1, x_358); -return x_359; +lean_ctor_set(x_360, 0, x_346); +lean_ctor_set(x_360, 1, x_359); +return x_360; +} +else +{ +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; lean_object* x_374; lean_object* x_375; lean_object* x_376; +x_361 = lean_ctor_get(x_344, 2); +lean_inc(x_361); +x_362 = lean_ctor_get(x_343, 0); +lean_inc(x_362); +lean_dec(x_343); +x_363 = lean_ctor_get(x_344, 0); +lean_inc(x_363); +x_364 = lean_ctor_get(x_344, 1); +lean_inc(x_364); +x_365 = lean_ctor_get(x_344, 3); +lean_inc(x_365); +x_366 = lean_ctor_get(x_344, 4); +lean_inc(x_366); +x_367 = lean_ctor_get(x_344, 5); +lean_inc(x_367); +if (lean_is_exclusive(x_344)) { + lean_ctor_release(x_344, 0); + lean_ctor_release(x_344, 1); + lean_ctor_release(x_344, 2); + lean_ctor_release(x_344, 3); + lean_ctor_release(x_344, 4); + lean_ctor_release(x_344, 5); + x_368 = x_344; +} else { + lean_dec_ref(x_344); + x_368 = lean_box(0); +} +x_369 = lean_ctor_get(x_361, 0); +lean_inc(x_369); +x_370 = lean_ctor_get(x_361, 1); +lean_inc(x_370); +x_371 = lean_ctor_get(x_361, 3); +lean_inc(x_371); +x_372 = lean_ctor_get(x_361, 4); +lean_inc(x_372); +if (lean_is_exclusive(x_361)) { + lean_ctor_release(x_361, 0); + lean_ctor_release(x_361, 1); + lean_ctor_release(x_361, 2); + lean_ctor_release(x_361, 3); + lean_ctor_release(x_361, 4); + x_373 = x_361; +} else { + lean_dec_ref(x_361); + x_373 = lean_box(0); +} +if (lean_is_scalar(x_373)) { + x_374 = lean_alloc_ctor(0, 5, 0); +} else { + x_374 = x_373; +} +lean_ctor_set(x_374, 0, x_369); +lean_ctor_set(x_374, 1, x_370); +lean_ctor_set(x_374, 2, x_340); +lean_ctor_set(x_374, 3, x_371); +lean_ctor_set(x_374, 4, x_372); +if (lean_is_scalar(x_368)) { + x_375 = lean_alloc_ctor(0, 6, 0); +} else { + x_375 = x_368; +} +lean_ctor_set(x_375, 0, x_363); +lean_ctor_set(x_375, 1, x_364); +lean_ctor_set(x_375, 2, x_374); +lean_ctor_set(x_375, 3, x_365); +lean_ctor_set(x_375, 4, x_366); +lean_ctor_set(x_375, 5, x_367); +if (lean_is_scalar(x_248)) { + x_376 = lean_alloc_ctor(0, 2, 0); +} else { + x_376 = x_248; +} +lean_ctor_set(x_376, 0, x_362); +lean_ctor_set(x_376, 1, x_375); +return x_376; } } } } else { -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; lean_object* x_391; lean_object* x_423; lean_object* x_424; lean_object* x_425; lean_object* x_426; lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; lean_object* x_432; lean_object* x_433; lean_object* x_434; lean_object* x_435; -x_379 = lean_ctor_get(x_237, 2); -x_380 = lean_ctor_get(x_237, 0); -x_381 = lean_ctor_get(x_237, 1); -x_382 = lean_ctor_get(x_237, 3); -x_383 = lean_ctor_get(x_237, 4); -x_384 = lean_ctor_get(x_237, 5); -lean_inc(x_384); -lean_inc(x_383); -lean_inc(x_382); -lean_inc(x_379); -lean_inc(x_381); -lean_inc(x_380); -lean_dec(x_237); -x_385 = lean_ctor_get(x_379, 0); -lean_inc(x_385); -x_386 = lean_ctor_get(x_379, 1); -lean_inc(x_386); -x_387 = lean_ctor_get(x_379, 2); -lean_inc(x_387); -x_388 = lean_ctor_get(x_379, 3); -lean_inc(x_388); -if (lean_is_exclusive(x_379)) { - lean_ctor_release(x_379, 0); - lean_ctor_release(x_379, 1); - lean_ctor_release(x_379, 2); - lean_ctor_release(x_379, 3); - x_389 = x_379; +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; lean_object* x_408; lean_object* x_409; lean_object* x_443; lean_object* x_444; lean_object* x_445; lean_object* x_446; lean_object* x_447; lean_object* x_448; lean_object* x_449; lean_object* x_450; lean_object* x_451; lean_object* x_452; lean_object* x_453; lean_object* x_454; lean_object* x_455; +x_396 = lean_ctor_get(x_247, 2); +x_397 = lean_ctor_get(x_247, 0); +x_398 = lean_ctor_get(x_247, 1); +x_399 = lean_ctor_get(x_247, 3); +x_400 = lean_ctor_get(x_247, 4); +x_401 = lean_ctor_get(x_247, 5); +lean_inc(x_401); +lean_inc(x_400); +lean_inc(x_399); +lean_inc(x_396); +lean_inc(x_398); +lean_inc(x_397); +lean_dec(x_247); +x_402 = lean_ctor_get(x_396, 0); +lean_inc(x_402); +x_403 = lean_ctor_get(x_396, 1); +lean_inc(x_403); +x_404 = lean_ctor_get(x_396, 2); +lean_inc(x_404); +x_405 = lean_ctor_get(x_396, 3); +lean_inc(x_405); +x_406 = lean_ctor_get(x_396, 4); +lean_inc(x_406); +if (lean_is_exclusive(x_396)) { + lean_ctor_release(x_396, 0); + lean_ctor_release(x_396, 1); + lean_ctor_release(x_396, 2); + lean_ctor_release(x_396, 3); + lean_ctor_release(x_396, 4); + x_407 = x_396; } else { - lean_dec_ref(x_379); - x_389 = lean_box(0); + lean_dec_ref(x_396); + x_407 = lean_box(0); } -x_423 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_389)) { - x_424 = lean_alloc_ctor(0, 4, 0); +x_443 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_407)) { + x_444 = lean_alloc_ctor(0, 5, 0); } else { - x_424 = x_389; + x_444 = x_407; } -lean_ctor_set(x_424, 0, x_385); -lean_ctor_set(x_424, 1, x_386); -lean_ctor_set(x_424, 2, x_423); -lean_ctor_set(x_424, 3, x_388); -x_425 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_425, 0, x_380); -lean_ctor_set(x_425, 1, x_381); -lean_ctor_set(x_425, 2, x_424); -lean_ctor_set(x_425, 3, x_382); -lean_ctor_set(x_425, 4, x_383); -lean_ctor_set(x_425, 5, x_384); -x_426 = lean_ctor_get(x_7, 0); -lean_inc(x_426); -x_427 = lean_ctor_get(x_7, 1); -lean_inc(x_427); -x_428 = lean_ctor_get(x_7, 2); -lean_inc(x_428); -x_429 = lean_ctor_get(x_7, 3); -lean_inc(x_429); -x_430 = lean_ctor_get(x_7, 4); -lean_inc(x_430); +lean_ctor_set(x_444, 0, x_402); +lean_ctor_set(x_444, 1, x_403); +lean_ctor_set(x_444, 2, x_443); +lean_ctor_set(x_444, 3, x_405); +lean_ctor_set(x_444, 4, x_406); +x_445 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_445, 0, x_397); +lean_ctor_set(x_445, 1, x_398); +lean_ctor_set(x_445, 2, x_444); +lean_ctor_set(x_445, 3, x_399); +lean_ctor_set(x_445, 4, x_400); +lean_ctor_set(x_445, 5, x_401); +x_446 = lean_ctor_get(x_7, 0); +lean_inc(x_446); +x_447 = lean_ctor_get(x_7, 1); +lean_inc(x_447); +x_448 = lean_ctor_get(x_7, 2); +lean_inc(x_448); +x_449 = lean_ctor_get(x_7, 3); +lean_inc(x_449); +x_450 = lean_ctor_get(x_7, 4); +lean_inc(x_450); if (lean_is_exclusive(x_7)) { lean_ctor_release(x_7, 0); lean_ctor_release(x_7, 1); lean_ctor_release(x_7, 2); lean_ctor_release(x_7, 3); lean_ctor_release(x_7, 4); - x_431 = x_7; + x_451 = x_7; } else { lean_dec_ref(x_7); - x_431 = lean_box(0); + x_451 = lean_box(0); } -x_432 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_432, 0, x_239); -lean_ctor_set(x_432, 1, x_14); -x_433 = lean_array_push(x_428, x_432); -if (lean_is_scalar(x_431)) { - x_434 = lean_alloc_ctor(0, 5, 0); +x_452 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_452, 0, x_249); +lean_ctor_set(x_452, 1, x_14); +x_453 = lean_array_push(x_448, x_452); +if (lean_is_scalar(x_451)) { + x_454 = lean_alloc_ctor(0, 5, 0); } else { - x_434 = x_431; + x_454 = x_451; } -lean_ctor_set(x_434, 0, x_426); -lean_ctor_set(x_434, 1, x_427); -lean_ctor_set(x_434, 2, x_433); -lean_ctor_set(x_434, 3, x_429); -lean_ctor_set(x_434, 4, x_430); -x_435 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_241, x_434, x_425); -if (lean_obj_tag(x_435) == 0) +lean_ctor_set(x_454, 0, x_446); +lean_ctor_set(x_454, 1, x_447); +lean_ctor_set(x_454, 2, x_453); +lean_ctor_set(x_454, 3, x_449); +lean_ctor_set(x_454, 4, x_450); +x_455 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_251, x_454, x_445); +if (lean_obj_tag(x_455) == 0) { -lean_object* x_436; lean_object* x_437; lean_object* x_438; -x_436 = lean_ctor_get(x_435, 0); -lean_inc(x_436); -x_437 = lean_ctor_get(x_435, 1); -lean_inc(x_437); -lean_dec(x_435); -x_438 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_438, 0, x_436); -x_390 = x_438; -x_391 = x_437; -goto block_422; +lean_object* x_456; lean_object* x_457; lean_object* x_458; +x_456 = lean_ctor_get(x_455, 0); +lean_inc(x_456); +x_457 = lean_ctor_get(x_455, 1); +lean_inc(x_457); +lean_dec(x_455); +x_458 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_458, 0, x_456); +x_408 = x_458; +x_409 = x_457; +goto block_442; } else { -lean_object* x_439; lean_object* x_440; lean_object* x_441; -x_439 = lean_ctor_get(x_435, 0); -lean_inc(x_439); -x_440 = lean_ctor_get(x_435, 1); -lean_inc(x_440); -lean_dec(x_435); -x_441 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_441, 0, x_439); -x_390 = x_441; -x_391 = x_440; -goto block_422; +lean_object* x_459; lean_object* x_460; lean_object* x_461; +x_459 = lean_ctor_get(x_455, 0); +lean_inc(x_459); +x_460 = lean_ctor_get(x_455, 1); +lean_inc(x_460); +lean_dec(x_455); +x_461 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_461, 0, x_459); +x_408 = x_461; +x_409 = x_460; +goto block_442; } -block_422: +block_442: { -if (lean_obj_tag(x_390) == 0) +if (lean_obj_tag(x_408) == 0) { -lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; lean_object* x_400; lean_object* x_401; lean_object* x_402; lean_object* x_403; lean_object* x_404; lean_object* x_405; lean_object* x_406; -x_392 = lean_ctor_get(x_391, 2); -lean_inc(x_392); -x_393 = lean_ctor_get(x_390, 0); -lean_inc(x_393); -lean_dec(x_390); -x_394 = lean_ctor_get(x_391, 0); -lean_inc(x_394); -x_395 = lean_ctor_get(x_391, 1); -lean_inc(x_395); -x_396 = lean_ctor_get(x_391, 3); -lean_inc(x_396); -x_397 = lean_ctor_get(x_391, 4); -lean_inc(x_397); -x_398 = lean_ctor_get(x_391, 5); -lean_inc(x_398); -if (lean_is_exclusive(x_391)) { - lean_ctor_release(x_391, 0); - lean_ctor_release(x_391, 1); - lean_ctor_release(x_391, 2); - lean_ctor_release(x_391, 3); - lean_ctor_release(x_391, 4); - lean_ctor_release(x_391, 5); - x_399 = x_391; -} else { - lean_dec_ref(x_391); - x_399 = lean_box(0); -} -x_400 = lean_ctor_get(x_392, 0); -lean_inc(x_400); -x_401 = lean_ctor_get(x_392, 1); -lean_inc(x_401); -x_402 = lean_ctor_get(x_392, 3); -lean_inc(x_402); -if (lean_is_exclusive(x_392)) { - lean_ctor_release(x_392, 0); - lean_ctor_release(x_392, 1); - lean_ctor_release(x_392, 2); - lean_ctor_release(x_392, 3); - x_403 = x_392; -} else { - lean_dec_ref(x_392); - x_403 = lean_box(0); -} -if (lean_is_scalar(x_403)) { - x_404 = lean_alloc_ctor(0, 4, 0); -} else { - x_404 = x_403; -} -lean_ctor_set(x_404, 0, x_400); -lean_ctor_set(x_404, 1, x_401); -lean_ctor_set(x_404, 2, x_387); -lean_ctor_set(x_404, 3, x_402); -if (lean_is_scalar(x_399)) { - x_405 = lean_alloc_ctor(0, 6, 0); -} else { - x_405 = x_399; -} -lean_ctor_set(x_405, 0, x_394); -lean_ctor_set(x_405, 1, x_395); -lean_ctor_set(x_405, 2, x_404); -lean_ctor_set(x_405, 3, x_396); -lean_ctor_set(x_405, 4, x_397); -lean_ctor_set(x_405, 5, x_398); -if (lean_is_scalar(x_238)) { - x_406 = lean_alloc_ctor(1, 2, 0); -} else { - x_406 = x_238; - lean_ctor_set_tag(x_406, 1); -} -lean_ctor_set(x_406, 0, x_393); -lean_ctor_set(x_406, 1, x_405); -return x_406; -} -else -{ -lean_object* x_407; lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_object* x_412; lean_object* x_413; lean_object* x_414; lean_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; -x_407 = lean_ctor_get(x_391, 2); -lean_inc(x_407); -x_408 = lean_ctor_get(x_390, 0); -lean_inc(x_408); -lean_dec(x_390); -x_409 = lean_ctor_get(x_391, 0); -lean_inc(x_409); -x_410 = lean_ctor_get(x_391, 1); +lean_object* x_410; 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_410 = lean_ctor_get(x_409, 2); lean_inc(x_410); -x_411 = lean_ctor_get(x_391, 3); +x_411 = lean_ctor_get(x_408, 0); lean_inc(x_411); -x_412 = lean_ctor_get(x_391, 4); +lean_dec(x_408); +x_412 = lean_ctor_get(x_409, 0); lean_inc(x_412); -x_413 = lean_ctor_get(x_391, 5); +x_413 = lean_ctor_get(x_409, 1); lean_inc(x_413); -if (lean_is_exclusive(x_391)) { - lean_ctor_release(x_391, 0); - lean_ctor_release(x_391, 1); - lean_ctor_release(x_391, 2); - lean_ctor_release(x_391, 3); - lean_ctor_release(x_391, 4); - lean_ctor_release(x_391, 5); - x_414 = x_391; -} else { - lean_dec_ref(x_391); - x_414 = lean_box(0); -} -x_415 = lean_ctor_get(x_407, 0); +x_414 = lean_ctor_get(x_409, 3); +lean_inc(x_414); +x_415 = lean_ctor_get(x_409, 4); lean_inc(x_415); -x_416 = lean_ctor_get(x_407, 1); +x_416 = lean_ctor_get(x_409, 5); lean_inc(x_416); -x_417 = lean_ctor_get(x_407, 3); -lean_inc(x_417); -if (lean_is_exclusive(x_407)) { - lean_ctor_release(x_407, 0); - lean_ctor_release(x_407, 1); - lean_ctor_release(x_407, 2); - lean_ctor_release(x_407, 3); - x_418 = x_407; +if (lean_is_exclusive(x_409)) { + lean_ctor_release(x_409, 0); + lean_ctor_release(x_409, 1); + lean_ctor_release(x_409, 2); + lean_ctor_release(x_409, 3); + lean_ctor_release(x_409, 4); + lean_ctor_release(x_409, 5); + x_417 = x_409; } else { - lean_dec_ref(x_407); - x_418 = lean_box(0); + lean_dec_ref(x_409); + x_417 = lean_box(0); } -if (lean_is_scalar(x_418)) { - x_419 = lean_alloc_ctor(0, 4, 0); +x_418 = lean_ctor_get(x_410, 0); +lean_inc(x_418); +x_419 = lean_ctor_get(x_410, 1); +lean_inc(x_419); +x_420 = lean_ctor_get(x_410, 3); +lean_inc(x_420); +x_421 = lean_ctor_get(x_410, 4); +lean_inc(x_421); +if (lean_is_exclusive(x_410)) { + lean_ctor_release(x_410, 0); + lean_ctor_release(x_410, 1); + lean_ctor_release(x_410, 2); + lean_ctor_release(x_410, 3); + lean_ctor_release(x_410, 4); + x_422 = x_410; } else { - x_419 = x_418; + lean_dec_ref(x_410); + x_422 = lean_box(0); } -lean_ctor_set(x_419, 0, x_415); -lean_ctor_set(x_419, 1, x_416); -lean_ctor_set(x_419, 2, x_387); -lean_ctor_set(x_419, 3, x_417); -if (lean_is_scalar(x_414)) { - x_420 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_422)) { + x_423 = lean_alloc_ctor(0, 5, 0); } else { - x_420 = x_414; + x_423 = x_422; } -lean_ctor_set(x_420, 0, x_409); -lean_ctor_set(x_420, 1, x_410); -lean_ctor_set(x_420, 2, x_419); -lean_ctor_set(x_420, 3, x_411); -lean_ctor_set(x_420, 4, x_412); -lean_ctor_set(x_420, 5, x_413); -if (lean_is_scalar(x_238)) { - x_421 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_423, 0, x_418); +lean_ctor_set(x_423, 1, x_419); +lean_ctor_set(x_423, 2, x_404); +lean_ctor_set(x_423, 3, x_420); +lean_ctor_set(x_423, 4, x_421); +if (lean_is_scalar(x_417)) { + x_424 = lean_alloc_ctor(0, 6, 0); } else { - x_421 = x_238; + x_424 = x_417; } -lean_ctor_set(x_421, 0, x_408); -lean_ctor_set(x_421, 1, x_420); -return x_421; +lean_ctor_set(x_424, 0, x_412); +lean_ctor_set(x_424, 1, x_413); +lean_ctor_set(x_424, 2, x_423); +lean_ctor_set(x_424, 3, x_414); +lean_ctor_set(x_424, 4, x_415); +lean_ctor_set(x_424, 5, x_416); +if (lean_is_scalar(x_248)) { + x_425 = lean_alloc_ctor(1, 2, 0); +} else { + x_425 = x_248; + lean_ctor_set_tag(x_425, 1); +} +lean_ctor_set(x_425, 0, x_411); +lean_ctor_set(x_425, 1, x_424); +return x_425; +} +else +{ +lean_object* x_426; lean_object* x_427; 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; +x_426 = lean_ctor_get(x_409, 2); +lean_inc(x_426); +x_427 = lean_ctor_get(x_408, 0); +lean_inc(x_427); +lean_dec(x_408); +x_428 = lean_ctor_get(x_409, 0); +lean_inc(x_428); +x_429 = lean_ctor_get(x_409, 1); +lean_inc(x_429); +x_430 = lean_ctor_get(x_409, 3); +lean_inc(x_430); +x_431 = lean_ctor_get(x_409, 4); +lean_inc(x_431); +x_432 = lean_ctor_get(x_409, 5); +lean_inc(x_432); +if (lean_is_exclusive(x_409)) { + lean_ctor_release(x_409, 0); + lean_ctor_release(x_409, 1); + lean_ctor_release(x_409, 2); + lean_ctor_release(x_409, 3); + lean_ctor_release(x_409, 4); + lean_ctor_release(x_409, 5); + x_433 = x_409; +} else { + lean_dec_ref(x_409); + x_433 = lean_box(0); +} +x_434 = lean_ctor_get(x_426, 0); +lean_inc(x_434); +x_435 = lean_ctor_get(x_426, 1); +lean_inc(x_435); +x_436 = lean_ctor_get(x_426, 3); +lean_inc(x_436); +x_437 = lean_ctor_get(x_426, 4); +lean_inc(x_437); +if (lean_is_exclusive(x_426)) { + lean_ctor_release(x_426, 0); + lean_ctor_release(x_426, 1); + lean_ctor_release(x_426, 2); + lean_ctor_release(x_426, 3); + lean_ctor_release(x_426, 4); + x_438 = x_426; +} else { + lean_dec_ref(x_426); + x_438 = lean_box(0); +} +if (lean_is_scalar(x_438)) { + x_439 = lean_alloc_ctor(0, 5, 0); +} else { + x_439 = x_438; +} +lean_ctor_set(x_439, 0, x_434); +lean_ctor_set(x_439, 1, x_435); +lean_ctor_set(x_439, 2, x_404); +lean_ctor_set(x_439, 3, x_436); +lean_ctor_set(x_439, 4, x_437); +if (lean_is_scalar(x_433)) { + x_440 = lean_alloc_ctor(0, 6, 0); +} else { + x_440 = x_433; +} +lean_ctor_set(x_440, 0, x_428); +lean_ctor_set(x_440, 1, x_429); +lean_ctor_set(x_440, 2, x_439); +lean_ctor_set(x_440, 3, x_430); +lean_ctor_set(x_440, 4, x_431); +lean_ctor_set(x_440, 5, x_432); +if (lean_is_scalar(x_248)) { + x_441 = lean_alloc_ctor(0, 2, 0); +} else { + x_441 = x_248; +} +lean_ctor_set(x_441, 0, x_427); +lean_ctor_set(x_441, 1, x_440); +return x_441; } } } @@ -35307,29 +36449,29 @@ return x_421; } else { -uint8_t x_442; +uint8_t x_462; lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_442 = !lean_is_exclusive(x_231); -if (x_442 == 0) +x_462 = !lean_is_exclusive(x_241); +if (x_462 == 0) { -return x_231; +return x_241; } else { -lean_object* x_443; lean_object* x_444; lean_object* x_445; -x_443 = lean_ctor_get(x_231, 0); -x_444 = lean_ctor_get(x_231, 1); -lean_inc(x_444); -lean_inc(x_443); -lean_dec(x_231); -x_445 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_445, 0, x_443); -lean_ctor_set(x_445, 1, x_444); -return x_445; +lean_object* x_463; lean_object* x_464; lean_object* x_465; +x_463 = lean_ctor_get(x_241, 0); +x_464 = lean_ctor_get(x_241, 1); +lean_inc(x_464); +lean_inc(x_463); +lean_dec(x_241); +x_465 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_465, 0, x_463); +lean_ctor_set(x_465, 1, x_464); +return x_465; } } } @@ -35337,58 +36479,58 @@ return x_445; } else { -uint8_t x_446; +uint8_t x_466; lean_dec(x_18); lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_446 = !lean_is_exclusive(x_19); -if (x_446 == 0) +x_466 = !lean_is_exclusive(x_19); +if (x_466 == 0) { return x_19; } else { -lean_object* x_447; lean_object* x_448; lean_object* x_449; -x_447 = lean_ctor_get(x_19, 0); -x_448 = lean_ctor_get(x_19, 1); -lean_inc(x_448); -lean_inc(x_447); +lean_object* x_467; lean_object* x_468; lean_object* x_469; +x_467 = lean_ctor_get(x_19, 0); +x_468 = lean_ctor_get(x_19, 1); +lean_inc(x_468); +lean_inc(x_467); lean_dec(x_19); -x_449 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_449, 0, x_447); -lean_ctor_set(x_449, 1, x_448); -return x_449; +x_469 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_469, 0, x_467); +lean_ctor_set(x_469, 1, x_468); +return x_469; } } } else { -uint8_t x_450; +uint8_t x_470; lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_450 = !lean_is_exclusive(x_15); -if (x_450 == 0) +x_470 = !lean_is_exclusive(x_15); +if (x_470 == 0) { return x_15; } else { -lean_object* x_451; lean_object* x_452; lean_object* x_453; -x_451 = lean_ctor_get(x_15, 0); -x_452 = lean_ctor_get(x_15, 1); -lean_inc(x_452); -lean_inc(x_451); +lean_object* x_471; lean_object* x_472; lean_object* x_473; +x_471 = lean_ctor_get(x_15, 0); +x_472 = lean_ctor_get(x_15, 1); +lean_inc(x_472); +lean_inc(x_471); lean_dec(x_15); -x_453 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_453, 0, x_451); -lean_ctor_set(x_453, 1, x_452); -return x_453; +x_473 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_473, 0, x_471); +lean_ctor_set(x_473, 1, x_472); +return x_473; } } } @@ -36133,105 +37275,105 @@ x_31 = lean_ctor_get(x_25, 2); x_32 = !lean_is_exclusive(x_31); if (x_32 == 0) { -lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_85; uint8_t x_86; +lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_89; uint8_t x_90; x_33 = lean_ctor_get(x_31, 2); -x_85 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_31, 2, x_85); -x_86 = !lean_is_exclusive(x_7); -if (x_86 == 0) +x_89 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_31, 2, x_89); +x_90 = !lean_is_exclusive(x_7); +if (x_90 == 0) { -lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; -x_87 = lean_ctor_get(x_7, 2); -x_88 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_88, 0, x_27); -lean_ctor_set(x_88, 1, x_14); -x_89 = lean_array_push(x_87, x_88); -lean_ctor_set(x_7, 2, x_89); -x_90 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_Basic_6__lambdaTelescopeAux___main___spec__1___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_7, x_25); -if (lean_obj_tag(x_90) == 0) +lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; +x_91 = lean_ctor_get(x_7, 2); +x_92 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_92, 0, x_27); +lean_ctor_set(x_92, 1, x_14); +x_93 = lean_array_push(x_91, x_92); +lean_ctor_set(x_7, 2, x_93); +x_94 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_Basic_6__lambdaTelescopeAux___main___spec__1___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_7, x_25); +if (lean_obj_tag(x_94) == 0) { -lean_object* x_91; lean_object* x_92; lean_object* x_93; -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_alloc_ctor(1, 1, 0); -lean_ctor_set(x_93, 0, x_91); -x_34 = x_93; -x_35 = x_92; -goto block_84; -} -else -{ -lean_object* x_94; lean_object* x_95; lean_object* x_96; -x_94 = lean_ctor_get(x_90, 0); -lean_inc(x_94); -x_95 = lean_ctor_get(x_90, 1); +lean_object* x_95; lean_object* x_96; lean_object* x_97; +x_95 = lean_ctor_get(x_94, 0); lean_inc(x_95); -lean_dec(x_90); -x_96 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_96, 0, x_94); -x_34 = x_96; -x_35 = x_95; -goto block_84; -} +x_96 = lean_ctor_get(x_94, 1); +lean_inc(x_96); +lean_dec(x_94); +x_97 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_97, 0, x_95); +x_34 = x_97; +x_35 = x_96; +goto block_88; } else { -lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; -x_97 = lean_ctor_get(x_7, 0); -x_98 = lean_ctor_get(x_7, 1); -x_99 = lean_ctor_get(x_7, 2); -x_100 = lean_ctor_get(x_7, 3); -x_101 = lean_ctor_get(x_7, 4); -lean_inc(x_101); -lean_inc(x_100); -lean_inc(x_99); +lean_object* x_98; lean_object* x_99; lean_object* x_100; +x_98 = lean_ctor_get(x_94, 0); lean_inc(x_98); -lean_inc(x_97); -lean_dec(x_7); -x_102 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_102, 0, x_27); -lean_ctor_set(x_102, 1, x_14); -x_103 = lean_array_push(x_99, x_102); -x_104 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_104, 0, x_97); -lean_ctor_set(x_104, 1, x_98); -lean_ctor_set(x_104, 2, x_103); -lean_ctor_set(x_104, 3, x_100); -lean_ctor_set(x_104, 4, x_101); -x_105 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_Basic_6__lambdaTelescopeAux___main___spec__1___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_104, x_25); -if (lean_obj_tag(x_105) == 0) -{ -lean_object* x_106; lean_object* x_107; lean_object* x_108; -x_106 = lean_ctor_get(x_105, 0); -lean_inc(x_106); -x_107 = lean_ctor_get(x_105, 1); -lean_inc(x_107); -lean_dec(x_105); -x_108 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_108, 0, x_106); -x_34 = x_108; -x_35 = x_107; -goto block_84; +x_99 = lean_ctor_get(x_94, 1); +lean_inc(x_99); +lean_dec(x_94); +x_100 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_100, 0, x_98); +x_34 = x_100; +x_35 = x_99; +goto block_88; +} } else { -lean_object* x_109; lean_object* x_110; lean_object* x_111; -x_109 = lean_ctor_get(x_105, 0); -lean_inc(x_109); -x_110 = lean_ctor_get(x_105, 1); +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; +x_101 = lean_ctor_get(x_7, 0); +x_102 = lean_ctor_get(x_7, 1); +x_103 = lean_ctor_get(x_7, 2); +x_104 = lean_ctor_get(x_7, 3); +x_105 = lean_ctor_get(x_7, 4); +lean_inc(x_105); +lean_inc(x_104); +lean_inc(x_103); +lean_inc(x_102); +lean_inc(x_101); +lean_dec(x_7); +x_106 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_106, 0, x_27); +lean_ctor_set(x_106, 1, x_14); +x_107 = lean_array_push(x_103, x_106); +x_108 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_108, 0, x_101); +lean_ctor_set(x_108, 1, x_102); +lean_ctor_set(x_108, 2, x_107); +lean_ctor_set(x_108, 3, x_104); +lean_ctor_set(x_108, 4, x_105); +x_109 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_Basic_6__lambdaTelescopeAux___main___spec__1___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_108, x_25); +if (lean_obj_tag(x_109) == 0) +{ +lean_object* x_110; lean_object* x_111; lean_object* x_112; +x_110 = lean_ctor_get(x_109, 0); lean_inc(x_110); -lean_dec(x_105); -x_111 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_111, 0, x_109); -x_34 = x_111; -x_35 = x_110; -goto block_84; +x_111 = lean_ctor_get(x_109, 1); +lean_inc(x_111); +lean_dec(x_109); +x_112 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_112, 0, x_110); +x_34 = x_112; +x_35 = x_111; +goto block_88; +} +else +{ +lean_object* x_113; lean_object* x_114; lean_object* x_115; +x_113 = lean_ctor_get(x_109, 0); +lean_inc(x_113); +x_114 = lean_ctor_get(x_109, 1); +lean_inc(x_114); +lean_dec(x_109); +x_115 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_115, 0, x_113); +x_34 = x_115; +x_35 = x_114; +goto block_88; } } -block_84: +block_88: { if (lean_obj_tag(x_34) == 0) { @@ -36266,1284 +37408,1262 @@ return x_42; } else { -lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; +lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; x_43 = lean_ctor_get(x_36, 0); x_44 = lean_ctor_get(x_36, 1); x_45 = lean_ctor_get(x_36, 3); +x_46 = lean_ctor_get(x_36, 4); +lean_inc(x_46); lean_inc(x_45); lean_inc(x_44); lean_inc(x_43); lean_dec(x_36); -x_46 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_46, 0, x_43); -lean_ctor_set(x_46, 1, x_44); -lean_ctor_set(x_46, 2, x_33); -lean_ctor_set(x_46, 3, x_45); -lean_ctor_set(x_35, 2, x_46); +x_47 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_47, 0, x_43); +lean_ctor_set(x_47, 1, x_44); +lean_ctor_set(x_47, 2, x_33); +lean_ctor_set(x_47, 3, x_45); +lean_ctor_set(x_47, 4, x_46); +lean_ctor_set(x_35, 2, x_47); if (lean_is_scalar(x_26)) { - x_47 = lean_alloc_ctor(1, 2, 0); + x_48 = lean_alloc_ctor(1, 2, 0); } else { - x_47 = x_26; - lean_ctor_set_tag(x_47, 1); + x_48 = x_26; + lean_ctor_set_tag(x_48, 1); } -lean_ctor_set(x_47, 0, x_37); -lean_ctor_set(x_47, 1, x_35); -return x_47; +lean_ctor_set(x_48, 0, x_37); +lean_ctor_set(x_48, 1, x_35); +return x_48; } } else { -lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; -x_48 = lean_ctor_get(x_35, 0); -x_49 = lean_ctor_get(x_35, 1); -x_50 = lean_ctor_get(x_35, 3); -x_51 = lean_ctor_get(x_35, 4); -x_52 = lean_ctor_get(x_35, 5); +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; +x_49 = lean_ctor_get(x_35, 0); +x_50 = lean_ctor_get(x_35, 1); +x_51 = lean_ctor_get(x_35, 3); +x_52 = lean_ctor_get(x_35, 4); +x_53 = lean_ctor_get(x_35, 5); +lean_inc(x_53); lean_inc(x_52); lean_inc(x_51); lean_inc(x_50); lean_inc(x_49); -lean_inc(x_48); lean_dec(x_35); -x_53 = lean_ctor_get(x_36, 0); -lean_inc(x_53); -x_54 = lean_ctor_get(x_36, 1); +x_54 = lean_ctor_get(x_36, 0); lean_inc(x_54); -x_55 = lean_ctor_get(x_36, 3); +x_55 = lean_ctor_get(x_36, 1); lean_inc(x_55); +x_56 = lean_ctor_get(x_36, 3); +lean_inc(x_56); +x_57 = lean_ctor_get(x_36, 4); +lean_inc(x_57); if (lean_is_exclusive(x_36)) { lean_ctor_release(x_36, 0); lean_ctor_release(x_36, 1); lean_ctor_release(x_36, 2); lean_ctor_release(x_36, 3); - x_56 = x_36; + lean_ctor_release(x_36, 4); + x_58 = x_36; } else { lean_dec_ref(x_36); - x_56 = lean_box(0); + x_58 = lean_box(0); } -if (lean_is_scalar(x_56)) { - x_57 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_58)) { + x_59 = lean_alloc_ctor(0, 5, 0); } else { - x_57 = x_56; + x_59 = x_58; } -lean_ctor_set(x_57, 0, x_53); -lean_ctor_set(x_57, 1, x_54); -lean_ctor_set(x_57, 2, x_33); -lean_ctor_set(x_57, 3, x_55); -x_58 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_58, 0, x_48); -lean_ctor_set(x_58, 1, x_49); -lean_ctor_set(x_58, 2, x_57); -lean_ctor_set(x_58, 3, x_50); -lean_ctor_set(x_58, 4, x_51); -lean_ctor_set(x_58, 5, x_52); +lean_ctor_set(x_59, 0, x_54); +lean_ctor_set(x_59, 1, x_55); +lean_ctor_set(x_59, 2, x_33); +lean_ctor_set(x_59, 3, x_56); +lean_ctor_set(x_59, 4, x_57); +x_60 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_60, 0, x_49); +lean_ctor_set(x_60, 1, x_50); +lean_ctor_set(x_60, 2, x_59); +lean_ctor_set(x_60, 3, x_51); +lean_ctor_set(x_60, 4, x_52); +lean_ctor_set(x_60, 5, x_53); if (lean_is_scalar(x_26)) { - x_59 = lean_alloc_ctor(1, 2, 0); + x_61 = lean_alloc_ctor(1, 2, 0); } else { - x_59 = x_26; - lean_ctor_set_tag(x_59, 1); + x_61 = x_26; + lean_ctor_set_tag(x_61, 1); } -lean_ctor_set(x_59, 0, x_37); -lean_ctor_set(x_59, 1, x_58); -return x_59; +lean_ctor_set(x_61, 0, x_37); +lean_ctor_set(x_61, 1, x_60); +return x_61; } } else { -lean_object* x_60; lean_object* x_61; uint8_t x_62; -x_60 = lean_ctor_get(x_35, 2); -lean_inc(x_60); -x_61 = lean_ctor_get(x_34, 0); -lean_inc(x_61); +lean_object* x_62; lean_object* x_63; uint8_t x_64; +x_62 = lean_ctor_get(x_35, 2); +lean_inc(x_62); +x_63 = lean_ctor_get(x_34, 0); +lean_inc(x_63); lean_dec(x_34); -x_62 = !lean_is_exclusive(x_35); -if (x_62 == 0) -{ -lean_object* x_63; uint8_t x_64; -x_63 = lean_ctor_get(x_35, 2); -lean_dec(x_63); -x_64 = !lean_is_exclusive(x_60); +x_64 = !lean_is_exclusive(x_35); if (x_64 == 0) { -lean_object* x_65; lean_object* x_66; -x_65 = lean_ctor_get(x_60, 2); +lean_object* x_65; uint8_t x_66; +x_65 = lean_ctor_get(x_35, 2); lean_dec(x_65); -lean_ctor_set(x_60, 2, x_33); +x_66 = !lean_is_exclusive(x_62); +if (x_66 == 0) +{ +lean_object* x_67; lean_object* x_68; +x_67 = lean_ctor_get(x_62, 2); +lean_dec(x_67); +lean_ctor_set(x_62, 2, x_33); if (lean_is_scalar(x_26)) { - x_66 = lean_alloc_ctor(0, 2, 0); + x_68 = lean_alloc_ctor(0, 2, 0); } else { - x_66 = x_26; + x_68 = x_26; } -lean_ctor_set(x_66, 0, x_61); -lean_ctor_set(x_66, 1, x_35); -return x_66; +lean_ctor_set(x_68, 0, x_63); +lean_ctor_set(x_68, 1, x_35); +return x_68; } else { -lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; -x_67 = lean_ctor_get(x_60, 0); -x_68 = lean_ctor_get(x_60, 1); -x_69 = lean_ctor_get(x_60, 3); +lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; +x_69 = lean_ctor_get(x_62, 0); +x_70 = lean_ctor_get(x_62, 1); +x_71 = lean_ctor_get(x_62, 3); +x_72 = lean_ctor_get(x_62, 4); +lean_inc(x_72); +lean_inc(x_71); +lean_inc(x_70); lean_inc(x_69); -lean_inc(x_68); -lean_inc(x_67); -lean_dec(x_60); -x_70 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_70, 0, x_67); -lean_ctor_set(x_70, 1, x_68); -lean_ctor_set(x_70, 2, x_33); -lean_ctor_set(x_70, 3, x_69); -lean_ctor_set(x_35, 2, x_70); +lean_dec(x_62); +x_73 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_73, 0, x_69); +lean_ctor_set(x_73, 1, x_70); +lean_ctor_set(x_73, 2, x_33); +lean_ctor_set(x_73, 3, x_71); +lean_ctor_set(x_73, 4, x_72); +lean_ctor_set(x_35, 2, x_73); if (lean_is_scalar(x_26)) { - x_71 = lean_alloc_ctor(0, 2, 0); + x_74 = lean_alloc_ctor(0, 2, 0); } else { - x_71 = x_26; + x_74 = x_26; } -lean_ctor_set(x_71, 0, x_61); -lean_ctor_set(x_71, 1, x_35); -return x_71; +lean_ctor_set(x_74, 0, x_63); +lean_ctor_set(x_74, 1, x_35); +return x_74; } } else { -lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; -x_72 = lean_ctor_get(x_35, 0); -x_73 = lean_ctor_get(x_35, 1); -x_74 = lean_ctor_get(x_35, 3); -x_75 = lean_ctor_get(x_35, 4); -x_76 = lean_ctor_get(x_35, 5); +lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; +x_75 = lean_ctor_get(x_35, 0); +x_76 = lean_ctor_get(x_35, 1); +x_77 = lean_ctor_get(x_35, 3); +x_78 = lean_ctor_get(x_35, 4); +x_79 = lean_ctor_get(x_35, 5); +lean_inc(x_79); +lean_inc(x_78); +lean_inc(x_77); lean_inc(x_76); lean_inc(x_75); -lean_inc(x_74); -lean_inc(x_73); -lean_inc(x_72); lean_dec(x_35); -x_77 = lean_ctor_get(x_60, 0); -lean_inc(x_77); -x_78 = lean_ctor_get(x_60, 1); -lean_inc(x_78); -x_79 = lean_ctor_get(x_60, 3); -lean_inc(x_79); -if (lean_is_exclusive(x_60)) { - lean_ctor_release(x_60, 0); - lean_ctor_release(x_60, 1); - lean_ctor_release(x_60, 2); - lean_ctor_release(x_60, 3); - x_80 = x_60; +x_80 = lean_ctor_get(x_62, 0); +lean_inc(x_80); +x_81 = lean_ctor_get(x_62, 1); +lean_inc(x_81); +x_82 = lean_ctor_get(x_62, 3); +lean_inc(x_82); +x_83 = lean_ctor_get(x_62, 4); +lean_inc(x_83); +if (lean_is_exclusive(x_62)) { + lean_ctor_release(x_62, 0); + lean_ctor_release(x_62, 1); + lean_ctor_release(x_62, 2); + lean_ctor_release(x_62, 3); + lean_ctor_release(x_62, 4); + x_84 = x_62; } else { - lean_dec_ref(x_60); - x_80 = lean_box(0); + lean_dec_ref(x_62); + x_84 = lean_box(0); } -if (lean_is_scalar(x_80)) { - x_81 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_84)) { + x_85 = lean_alloc_ctor(0, 5, 0); } else { - x_81 = x_80; + x_85 = x_84; } -lean_ctor_set(x_81, 0, x_77); -lean_ctor_set(x_81, 1, x_78); -lean_ctor_set(x_81, 2, x_33); -lean_ctor_set(x_81, 3, x_79); -x_82 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_82, 0, x_72); -lean_ctor_set(x_82, 1, x_73); -lean_ctor_set(x_82, 2, x_81); -lean_ctor_set(x_82, 3, x_74); -lean_ctor_set(x_82, 4, x_75); -lean_ctor_set(x_82, 5, x_76); +lean_ctor_set(x_85, 0, x_80); +lean_ctor_set(x_85, 1, x_81); +lean_ctor_set(x_85, 2, x_33); +lean_ctor_set(x_85, 3, x_82); +lean_ctor_set(x_85, 4, x_83); +x_86 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_86, 0, x_75); +lean_ctor_set(x_86, 1, x_76); +lean_ctor_set(x_86, 2, x_85); +lean_ctor_set(x_86, 3, x_77); +lean_ctor_set(x_86, 4, x_78); +lean_ctor_set(x_86, 5, x_79); if (lean_is_scalar(x_26)) { - x_83 = lean_alloc_ctor(0, 2, 0); + x_87 = lean_alloc_ctor(0, 2, 0); } else { - x_83 = x_26; + x_87 = x_26; } -lean_ctor_set(x_83, 0, x_61); -lean_ctor_set(x_83, 1, x_82); -return x_83; +lean_ctor_set(x_87, 0, x_63); +lean_ctor_set(x_87, 1, x_86); +return x_87; } } } } else { -lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_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; -x_112 = lean_ctor_get(x_31, 0); -x_113 = lean_ctor_get(x_31, 1); -x_114 = lean_ctor_get(x_31, 2); -x_115 = lean_ctor_get(x_31, 3); -lean_inc(x_115); -lean_inc(x_114); -lean_inc(x_113); -lean_inc(x_112); -lean_dec(x_31); -x_149 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_150 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_150, 0, x_112); -lean_ctor_set(x_150, 1, x_113); -lean_ctor_set(x_150, 2, x_149); -lean_ctor_set(x_150, 3, x_115); -lean_ctor_set(x_25, 2, x_150); -x_151 = lean_ctor_get(x_7, 0); -lean_inc(x_151); -x_152 = lean_ctor_get(x_7, 1); -lean_inc(x_152); -x_153 = lean_ctor_get(x_7, 2); -lean_inc(x_153); -x_154 = lean_ctor_get(x_7, 3); -lean_inc(x_154); -x_155 = lean_ctor_get(x_7, 4); -lean_inc(x_155); -if (lean_is_exclusive(x_7)) { - lean_ctor_release(x_7, 0); - lean_ctor_release(x_7, 1); - lean_ctor_release(x_7, 2); - lean_ctor_release(x_7, 3); - lean_ctor_release(x_7, 4); - x_156 = x_7; -} else { - lean_dec_ref(x_7); - x_156 = lean_box(0); -} -x_157 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_157, 0, x_27); -lean_ctor_set(x_157, 1, x_14); -x_158 = lean_array_push(x_153, x_157); -if (lean_is_scalar(x_156)) { - x_159 = lean_alloc_ctor(0, 5, 0); -} else { - x_159 = x_156; -} -lean_ctor_set(x_159, 0, x_151); -lean_ctor_set(x_159, 1, x_152); -lean_ctor_set(x_159, 2, x_158); -lean_ctor_set(x_159, 3, x_154); -lean_ctor_set(x_159, 4, x_155); -x_160 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_Basic_6__lambdaTelescopeAux___main___spec__1___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_159, x_25); -if (lean_obj_tag(x_160) == 0) -{ -lean_object* x_161; lean_object* x_162; lean_object* x_163; -x_161 = lean_ctor_get(x_160, 0); -lean_inc(x_161); -x_162 = lean_ctor_get(x_160, 1); -lean_inc(x_162); -lean_dec(x_160); -x_163 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_163, 0, x_161); -x_116 = x_163; -x_117 = x_162; -goto block_148; -} -else -{ -lean_object* x_164; lean_object* x_165; lean_object* x_166; -x_164 = lean_ctor_get(x_160, 0); -lean_inc(x_164); -x_165 = lean_ctor_get(x_160, 1); -lean_inc(x_165); -lean_dec(x_160); -x_166 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_166, 0, x_164); -x_116 = x_166; -x_117 = x_165; -goto block_148; -} -block_148: -{ -if (lean_obj_tag(x_116) == 0) -{ -lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; -x_118 = lean_ctor_get(x_117, 2); -lean_inc(x_118); -x_119 = lean_ctor_get(x_116, 0); -lean_inc(x_119); -lean_dec(x_116); -x_120 = lean_ctor_get(x_117, 0); +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_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; +x_116 = lean_ctor_get(x_31, 0); +x_117 = lean_ctor_get(x_31, 1); +x_118 = lean_ctor_get(x_31, 2); +x_119 = lean_ctor_get(x_31, 3); +x_120 = lean_ctor_get(x_31, 4); lean_inc(x_120); -x_121 = lean_ctor_get(x_117, 1); -lean_inc(x_121); -x_122 = lean_ctor_get(x_117, 3); -lean_inc(x_122); -x_123 = lean_ctor_get(x_117, 4); -lean_inc(x_123); -x_124 = lean_ctor_get(x_117, 5); -lean_inc(x_124); -if (lean_is_exclusive(x_117)) { - lean_ctor_release(x_117, 0); - lean_ctor_release(x_117, 1); - lean_ctor_release(x_117, 2); - lean_ctor_release(x_117, 3); - lean_ctor_release(x_117, 4); - lean_ctor_release(x_117, 5); - x_125 = x_117; -} else { - lean_dec_ref(x_117); - x_125 = lean_box(0); -} -x_126 = lean_ctor_get(x_118, 0); -lean_inc(x_126); -x_127 = lean_ctor_get(x_118, 1); -lean_inc(x_127); -x_128 = lean_ctor_get(x_118, 3); -lean_inc(x_128); -if (lean_is_exclusive(x_118)) { - lean_ctor_release(x_118, 0); - lean_ctor_release(x_118, 1); - lean_ctor_release(x_118, 2); - lean_ctor_release(x_118, 3); - x_129 = x_118; -} else { - lean_dec_ref(x_118); - x_129 = lean_box(0); -} -if (lean_is_scalar(x_129)) { - x_130 = lean_alloc_ctor(0, 4, 0); -} else { - x_130 = x_129; -} -lean_ctor_set(x_130, 0, x_126); -lean_ctor_set(x_130, 1, x_127); -lean_ctor_set(x_130, 2, x_114); -lean_ctor_set(x_130, 3, x_128); -if (lean_is_scalar(x_125)) { - x_131 = lean_alloc_ctor(0, 6, 0); -} else { - x_131 = x_125; -} -lean_ctor_set(x_131, 0, x_120); -lean_ctor_set(x_131, 1, x_121); -lean_ctor_set(x_131, 2, x_130); -lean_ctor_set(x_131, 3, x_122); -lean_ctor_set(x_131, 4, x_123); -lean_ctor_set(x_131, 5, x_124); -if (lean_is_scalar(x_26)) { - x_132 = lean_alloc_ctor(1, 2, 0); -} else { - x_132 = x_26; - lean_ctor_set_tag(x_132, 1); -} -lean_ctor_set(x_132, 0, x_119); -lean_ctor_set(x_132, 1, x_131); -return x_132; -} -else -{ -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; -x_133 = lean_ctor_get(x_117, 2); -lean_inc(x_133); -x_134 = lean_ctor_get(x_116, 0); -lean_inc(x_134); -lean_dec(x_116); -x_135 = lean_ctor_get(x_117, 0); -lean_inc(x_135); -x_136 = lean_ctor_get(x_117, 1); -lean_inc(x_136); -x_137 = lean_ctor_get(x_117, 3); -lean_inc(x_137); -x_138 = lean_ctor_get(x_117, 4); -lean_inc(x_138); -x_139 = lean_ctor_get(x_117, 5); -lean_inc(x_139); -if (lean_is_exclusive(x_117)) { - lean_ctor_release(x_117, 0); - lean_ctor_release(x_117, 1); - lean_ctor_release(x_117, 2); - lean_ctor_release(x_117, 3); - lean_ctor_release(x_117, 4); - lean_ctor_release(x_117, 5); - x_140 = x_117; -} else { - lean_dec_ref(x_117); - x_140 = lean_box(0); -} -x_141 = lean_ctor_get(x_133, 0); -lean_inc(x_141); -x_142 = lean_ctor_get(x_133, 1); -lean_inc(x_142); -x_143 = lean_ctor_get(x_133, 3); -lean_inc(x_143); -if (lean_is_exclusive(x_133)) { - lean_ctor_release(x_133, 0); - lean_ctor_release(x_133, 1); - lean_ctor_release(x_133, 2); - lean_ctor_release(x_133, 3); - x_144 = x_133; -} else { - lean_dec_ref(x_133); - x_144 = lean_box(0); -} -if (lean_is_scalar(x_144)) { - x_145 = lean_alloc_ctor(0, 4, 0); -} else { - x_145 = x_144; -} -lean_ctor_set(x_145, 0, x_141); -lean_ctor_set(x_145, 1, x_142); -lean_ctor_set(x_145, 2, x_114); -lean_ctor_set(x_145, 3, x_143); -if (lean_is_scalar(x_140)) { - x_146 = lean_alloc_ctor(0, 6, 0); -} else { - x_146 = x_140; -} -lean_ctor_set(x_146, 0, x_135); -lean_ctor_set(x_146, 1, x_136); -lean_ctor_set(x_146, 2, x_145); -lean_ctor_set(x_146, 3, x_137); -lean_ctor_set(x_146, 4, x_138); -lean_ctor_set(x_146, 5, x_139); -if (lean_is_scalar(x_26)) { - x_147 = lean_alloc_ctor(0, 2, 0); -} else { - x_147 = x_26; -} -lean_ctor_set(x_147, 0, x_134); -lean_ctor_set(x_147, 1, x_146); -return x_147; -} -} -} -} -else -{ -lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; 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; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; -x_167 = lean_ctor_get(x_25, 2); -x_168 = lean_ctor_get(x_25, 0); -x_169 = lean_ctor_get(x_25, 1); -x_170 = lean_ctor_get(x_25, 3); -x_171 = lean_ctor_get(x_25, 4); -x_172 = lean_ctor_get(x_25, 5); -lean_inc(x_172); -lean_inc(x_171); -lean_inc(x_170); -lean_inc(x_167); -lean_inc(x_169); -lean_inc(x_168); -lean_dec(x_25); -x_173 = lean_ctor_get(x_167, 0); -lean_inc(x_173); -x_174 = lean_ctor_get(x_167, 1); -lean_inc(x_174); -x_175 = lean_ctor_get(x_167, 2); -lean_inc(x_175); -x_176 = lean_ctor_get(x_167, 3); -lean_inc(x_176); -if (lean_is_exclusive(x_167)) { - lean_ctor_release(x_167, 0); - lean_ctor_release(x_167, 1); - lean_ctor_release(x_167, 2); - lean_ctor_release(x_167, 3); - x_177 = x_167; -} else { - lean_dec_ref(x_167); - x_177 = lean_box(0); -} -x_211 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_177)) { - x_212 = lean_alloc_ctor(0, 4, 0); -} else { - x_212 = x_177; -} -lean_ctor_set(x_212, 0, x_173); -lean_ctor_set(x_212, 1, x_174); -lean_ctor_set(x_212, 2, x_211); -lean_ctor_set(x_212, 3, x_176); -x_213 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_213, 0, x_168); -lean_ctor_set(x_213, 1, x_169); -lean_ctor_set(x_213, 2, x_212); -lean_ctor_set(x_213, 3, x_170); -lean_ctor_set(x_213, 4, x_171); -lean_ctor_set(x_213, 5, x_172); -x_214 = lean_ctor_get(x_7, 0); -lean_inc(x_214); -x_215 = lean_ctor_get(x_7, 1); -lean_inc(x_215); -x_216 = lean_ctor_get(x_7, 2); -lean_inc(x_216); -x_217 = lean_ctor_get(x_7, 3); -lean_inc(x_217); -x_218 = lean_ctor_get(x_7, 4); -lean_inc(x_218); +lean_inc(x_119); +lean_inc(x_118); +lean_inc(x_117); +lean_inc(x_116); +lean_dec(x_31); +x_156 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_157 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_157, 0, x_116); +lean_ctor_set(x_157, 1, x_117); +lean_ctor_set(x_157, 2, x_156); +lean_ctor_set(x_157, 3, x_119); +lean_ctor_set(x_157, 4, x_120); +lean_ctor_set(x_25, 2, x_157); +x_158 = lean_ctor_get(x_7, 0); +lean_inc(x_158); +x_159 = lean_ctor_get(x_7, 1); +lean_inc(x_159); +x_160 = lean_ctor_get(x_7, 2); +lean_inc(x_160); +x_161 = lean_ctor_get(x_7, 3); +lean_inc(x_161); +x_162 = lean_ctor_get(x_7, 4); +lean_inc(x_162); if (lean_is_exclusive(x_7)) { lean_ctor_release(x_7, 0); lean_ctor_release(x_7, 1); lean_ctor_release(x_7, 2); lean_ctor_release(x_7, 3); lean_ctor_release(x_7, 4); - x_219 = x_7; + x_163 = x_7; } else { lean_dec_ref(x_7); - x_219 = lean_box(0); + x_163 = lean_box(0); } -x_220 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_220, 0, x_27); -lean_ctor_set(x_220, 1, x_14); -x_221 = lean_array_push(x_216, x_220); -if (lean_is_scalar(x_219)) { +x_164 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_164, 0, x_27); +lean_ctor_set(x_164, 1, x_14); +x_165 = lean_array_push(x_160, x_164); +if (lean_is_scalar(x_163)) { + x_166 = lean_alloc_ctor(0, 5, 0); +} else { + x_166 = x_163; +} +lean_ctor_set(x_166, 0, x_158); +lean_ctor_set(x_166, 1, x_159); +lean_ctor_set(x_166, 2, x_165); +lean_ctor_set(x_166, 3, x_161); +lean_ctor_set(x_166, 4, x_162); +x_167 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_Basic_6__lambdaTelescopeAux___main___spec__1___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_166, x_25); +if (lean_obj_tag(x_167) == 0) +{ +lean_object* x_168; lean_object* x_169; lean_object* x_170; +x_168 = lean_ctor_get(x_167, 0); +lean_inc(x_168); +x_169 = lean_ctor_get(x_167, 1); +lean_inc(x_169); +lean_dec(x_167); +x_170 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_170, 0, x_168); +x_121 = x_170; +x_122 = x_169; +goto block_155; +} +else +{ +lean_object* x_171; lean_object* x_172; lean_object* x_173; +x_171 = lean_ctor_get(x_167, 0); +lean_inc(x_171); +x_172 = lean_ctor_get(x_167, 1); +lean_inc(x_172); +lean_dec(x_167); +x_173 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_173, 0, x_171); +x_121 = x_173; +x_122 = x_172; +goto block_155; +} +block_155: +{ +if (lean_obj_tag(x_121) == 0) +{ +lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; +x_123 = lean_ctor_get(x_122, 2); +lean_inc(x_123); +x_124 = lean_ctor_get(x_121, 0); +lean_inc(x_124); +lean_dec(x_121); +x_125 = lean_ctor_get(x_122, 0); +lean_inc(x_125); +x_126 = lean_ctor_get(x_122, 1); +lean_inc(x_126); +x_127 = lean_ctor_get(x_122, 3); +lean_inc(x_127); +x_128 = lean_ctor_get(x_122, 4); +lean_inc(x_128); +x_129 = lean_ctor_get(x_122, 5); +lean_inc(x_129); +if (lean_is_exclusive(x_122)) { + lean_ctor_release(x_122, 0); + lean_ctor_release(x_122, 1); + lean_ctor_release(x_122, 2); + lean_ctor_release(x_122, 3); + lean_ctor_release(x_122, 4); + lean_ctor_release(x_122, 5); + x_130 = x_122; +} else { + lean_dec_ref(x_122); + x_130 = lean_box(0); +} +x_131 = lean_ctor_get(x_123, 0); +lean_inc(x_131); +x_132 = lean_ctor_get(x_123, 1); +lean_inc(x_132); +x_133 = lean_ctor_get(x_123, 3); +lean_inc(x_133); +x_134 = lean_ctor_get(x_123, 4); +lean_inc(x_134); +if (lean_is_exclusive(x_123)) { + lean_ctor_release(x_123, 0); + lean_ctor_release(x_123, 1); + lean_ctor_release(x_123, 2); + lean_ctor_release(x_123, 3); + lean_ctor_release(x_123, 4); + x_135 = x_123; +} else { + lean_dec_ref(x_123); + x_135 = lean_box(0); +} +if (lean_is_scalar(x_135)) { + x_136 = lean_alloc_ctor(0, 5, 0); +} else { + x_136 = x_135; +} +lean_ctor_set(x_136, 0, x_131); +lean_ctor_set(x_136, 1, x_132); +lean_ctor_set(x_136, 2, x_118); +lean_ctor_set(x_136, 3, x_133); +lean_ctor_set(x_136, 4, x_134); +if (lean_is_scalar(x_130)) { + x_137 = lean_alloc_ctor(0, 6, 0); +} else { + x_137 = x_130; +} +lean_ctor_set(x_137, 0, x_125); +lean_ctor_set(x_137, 1, x_126); +lean_ctor_set(x_137, 2, x_136); +lean_ctor_set(x_137, 3, x_127); +lean_ctor_set(x_137, 4, x_128); +lean_ctor_set(x_137, 5, x_129); +if (lean_is_scalar(x_26)) { + x_138 = lean_alloc_ctor(1, 2, 0); +} else { + x_138 = x_26; + lean_ctor_set_tag(x_138, 1); +} +lean_ctor_set(x_138, 0, x_124); +lean_ctor_set(x_138, 1, x_137); +return x_138; +} +else +{ +lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_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; +x_139 = lean_ctor_get(x_122, 2); +lean_inc(x_139); +x_140 = lean_ctor_get(x_121, 0); +lean_inc(x_140); +lean_dec(x_121); +x_141 = lean_ctor_get(x_122, 0); +lean_inc(x_141); +x_142 = lean_ctor_get(x_122, 1); +lean_inc(x_142); +x_143 = lean_ctor_get(x_122, 3); +lean_inc(x_143); +x_144 = lean_ctor_get(x_122, 4); +lean_inc(x_144); +x_145 = lean_ctor_get(x_122, 5); +lean_inc(x_145); +if (lean_is_exclusive(x_122)) { + lean_ctor_release(x_122, 0); + lean_ctor_release(x_122, 1); + lean_ctor_release(x_122, 2); + lean_ctor_release(x_122, 3); + lean_ctor_release(x_122, 4); + lean_ctor_release(x_122, 5); + x_146 = x_122; +} else { + lean_dec_ref(x_122); + x_146 = lean_box(0); +} +x_147 = lean_ctor_get(x_139, 0); +lean_inc(x_147); +x_148 = lean_ctor_get(x_139, 1); +lean_inc(x_148); +x_149 = lean_ctor_get(x_139, 3); +lean_inc(x_149); +x_150 = lean_ctor_get(x_139, 4); +lean_inc(x_150); +if (lean_is_exclusive(x_139)) { + lean_ctor_release(x_139, 0); + lean_ctor_release(x_139, 1); + lean_ctor_release(x_139, 2); + lean_ctor_release(x_139, 3); + lean_ctor_release(x_139, 4); + x_151 = x_139; +} else { + lean_dec_ref(x_139); + x_151 = lean_box(0); +} +if (lean_is_scalar(x_151)) { + x_152 = lean_alloc_ctor(0, 5, 0); +} else { + x_152 = x_151; +} +lean_ctor_set(x_152, 0, x_147); +lean_ctor_set(x_152, 1, x_148); +lean_ctor_set(x_152, 2, x_118); +lean_ctor_set(x_152, 3, x_149); +lean_ctor_set(x_152, 4, x_150); +if (lean_is_scalar(x_146)) { + x_153 = lean_alloc_ctor(0, 6, 0); +} else { + x_153 = x_146; +} +lean_ctor_set(x_153, 0, x_141); +lean_ctor_set(x_153, 1, x_142); +lean_ctor_set(x_153, 2, x_152); +lean_ctor_set(x_153, 3, x_143); +lean_ctor_set(x_153, 4, x_144); +lean_ctor_set(x_153, 5, x_145); +if (lean_is_scalar(x_26)) { + x_154 = lean_alloc_ctor(0, 2, 0); +} else { + x_154 = x_26; +} +lean_ctor_set(x_154, 0, x_140); +lean_ctor_set(x_154, 1, x_153); +return x_154; +} +} +} +} +else +{ +lean_object* x_174; lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_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; lean_object* x_231; lean_object* x_232; lean_object* x_233; +x_174 = lean_ctor_get(x_25, 2); +x_175 = lean_ctor_get(x_25, 0); +x_176 = lean_ctor_get(x_25, 1); +x_177 = lean_ctor_get(x_25, 3); +x_178 = lean_ctor_get(x_25, 4); +x_179 = lean_ctor_get(x_25, 5); +lean_inc(x_179); +lean_inc(x_178); +lean_inc(x_177); +lean_inc(x_174); +lean_inc(x_176); +lean_inc(x_175); +lean_dec(x_25); +x_180 = lean_ctor_get(x_174, 0); +lean_inc(x_180); +x_181 = lean_ctor_get(x_174, 1); +lean_inc(x_181); +x_182 = lean_ctor_get(x_174, 2); +lean_inc(x_182); +x_183 = lean_ctor_get(x_174, 3); +lean_inc(x_183); +x_184 = lean_ctor_get(x_174, 4); +lean_inc(x_184); +if (lean_is_exclusive(x_174)) { + lean_ctor_release(x_174, 0); + lean_ctor_release(x_174, 1); + lean_ctor_release(x_174, 2); + lean_ctor_release(x_174, 3); + lean_ctor_release(x_174, 4); + x_185 = x_174; +} else { + lean_dec_ref(x_174); + x_185 = lean_box(0); +} +x_221 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_185)) { x_222 = lean_alloc_ctor(0, 5, 0); } else { - x_222 = x_219; + x_222 = x_185; } -lean_ctor_set(x_222, 0, x_214); -lean_ctor_set(x_222, 1, x_215); +lean_ctor_set(x_222, 0, x_180); +lean_ctor_set(x_222, 1, x_181); lean_ctor_set(x_222, 2, x_221); -lean_ctor_set(x_222, 3, x_217); -lean_ctor_set(x_222, 4, x_218); -x_223 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_Basic_6__lambdaTelescopeAux___main___spec__1___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_222, x_213); -if (lean_obj_tag(x_223) == 0) -{ -lean_object* x_224; lean_object* x_225; lean_object* x_226; -x_224 = lean_ctor_get(x_223, 0); +lean_ctor_set(x_222, 3, x_183); +lean_ctor_set(x_222, 4, x_184); +x_223 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_223, 0, x_175); +lean_ctor_set(x_223, 1, x_176); +lean_ctor_set(x_223, 2, x_222); +lean_ctor_set(x_223, 3, x_177); +lean_ctor_set(x_223, 4, x_178); +lean_ctor_set(x_223, 5, x_179); +x_224 = lean_ctor_get(x_7, 0); lean_inc(x_224); -x_225 = lean_ctor_get(x_223, 1); +x_225 = lean_ctor_get(x_7, 1); lean_inc(x_225); -lean_dec(x_223); -x_226 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_226, 0, x_224); -x_178 = x_226; -x_179 = x_225; -goto block_210; -} -else -{ -lean_object* x_227; lean_object* x_228; lean_object* x_229; -x_227 = lean_ctor_get(x_223, 0); +x_226 = lean_ctor_get(x_7, 2); +lean_inc(x_226); +x_227 = lean_ctor_get(x_7, 3); lean_inc(x_227); -x_228 = lean_ctor_get(x_223, 1); +x_228 = lean_ctor_get(x_7, 4); lean_inc(x_228); -lean_dec(x_223); -x_229 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_229, 0, x_227); -x_178 = x_229; -x_179 = x_228; -goto block_210; +if (lean_is_exclusive(x_7)) { + lean_ctor_release(x_7, 0); + lean_ctor_release(x_7, 1); + lean_ctor_release(x_7, 2); + lean_ctor_release(x_7, 3); + lean_ctor_release(x_7, 4); + x_229 = x_7; +} else { + lean_dec_ref(x_7); + x_229 = lean_box(0); } -block_210: +x_230 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_230, 0, x_27); +lean_ctor_set(x_230, 1, x_14); +x_231 = lean_array_push(x_226, x_230); +if (lean_is_scalar(x_229)) { + x_232 = lean_alloc_ctor(0, 5, 0); +} else { + x_232 = x_229; +} +lean_ctor_set(x_232, 0, x_224); +lean_ctor_set(x_232, 1, x_225); +lean_ctor_set(x_232, 2, x_231); +lean_ctor_set(x_232, 3, x_227); +lean_ctor_set(x_232, 4, x_228); +x_233 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_Basic_6__lambdaTelescopeAux___main___spec__1___rarg(x_1, x_2, x_3, x_4, x_5, x_29, x_232, x_223); +if (lean_obj_tag(x_233) == 0) { -if (lean_obj_tag(x_178) == 0) -{ -lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; -x_180 = lean_ctor_get(x_179, 2); -lean_inc(x_180); -x_181 = lean_ctor_get(x_178, 0); -lean_inc(x_181); -lean_dec(x_178); -x_182 = lean_ctor_get(x_179, 0); -lean_inc(x_182); -x_183 = lean_ctor_get(x_179, 1); -lean_inc(x_183); -x_184 = lean_ctor_get(x_179, 3); -lean_inc(x_184); -x_185 = lean_ctor_get(x_179, 4); -lean_inc(x_185); -x_186 = lean_ctor_get(x_179, 5); -lean_inc(x_186); -if (lean_is_exclusive(x_179)) { - lean_ctor_release(x_179, 0); - lean_ctor_release(x_179, 1); - lean_ctor_release(x_179, 2); - lean_ctor_release(x_179, 3); - lean_ctor_release(x_179, 4); - lean_ctor_release(x_179, 5); - x_187 = x_179; -} else { - lean_dec_ref(x_179); - x_187 = lean_box(0); -} -x_188 = lean_ctor_get(x_180, 0); -lean_inc(x_188); -x_189 = lean_ctor_get(x_180, 1); -lean_inc(x_189); -x_190 = lean_ctor_get(x_180, 3); -lean_inc(x_190); -if (lean_is_exclusive(x_180)) { - lean_ctor_release(x_180, 0); - lean_ctor_release(x_180, 1); - lean_ctor_release(x_180, 2); - lean_ctor_release(x_180, 3); - x_191 = x_180; -} else { - lean_dec_ref(x_180); - x_191 = lean_box(0); -} -if (lean_is_scalar(x_191)) { - x_192 = lean_alloc_ctor(0, 4, 0); -} else { - x_192 = x_191; -} -lean_ctor_set(x_192, 0, x_188); -lean_ctor_set(x_192, 1, x_189); -lean_ctor_set(x_192, 2, x_175); -lean_ctor_set(x_192, 3, x_190); -if (lean_is_scalar(x_187)) { - x_193 = lean_alloc_ctor(0, 6, 0); -} else { - x_193 = x_187; -} -lean_ctor_set(x_193, 0, x_182); -lean_ctor_set(x_193, 1, x_183); -lean_ctor_set(x_193, 2, x_192); -lean_ctor_set(x_193, 3, x_184); -lean_ctor_set(x_193, 4, x_185); -lean_ctor_set(x_193, 5, x_186); -if (lean_is_scalar(x_26)) { - x_194 = lean_alloc_ctor(1, 2, 0); -} else { - x_194 = x_26; - lean_ctor_set_tag(x_194, 1); -} -lean_ctor_set(x_194, 0, x_181); -lean_ctor_set(x_194, 1, x_193); -return x_194; +lean_object* x_234; lean_object* x_235; lean_object* x_236; +x_234 = lean_ctor_get(x_233, 0); +lean_inc(x_234); +x_235 = lean_ctor_get(x_233, 1); +lean_inc(x_235); +lean_dec(x_233); +x_236 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_236, 0, x_234); +x_186 = x_236; +x_187 = x_235; +goto block_220; } else { -lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; -x_195 = lean_ctor_get(x_179, 2); -lean_inc(x_195); -x_196 = lean_ctor_get(x_178, 0); +lean_object* x_237; lean_object* x_238; lean_object* x_239; +x_237 = lean_ctor_get(x_233, 0); +lean_inc(x_237); +x_238 = lean_ctor_get(x_233, 1); +lean_inc(x_238); +lean_dec(x_233); +x_239 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_239, 0, x_237); +x_186 = x_239; +x_187 = x_238; +goto block_220; +} +block_220: +{ +if (lean_obj_tag(x_186) == 0) +{ +lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; +x_188 = lean_ctor_get(x_187, 2); +lean_inc(x_188); +x_189 = lean_ctor_get(x_186, 0); +lean_inc(x_189); +lean_dec(x_186); +x_190 = lean_ctor_get(x_187, 0); +lean_inc(x_190); +x_191 = lean_ctor_get(x_187, 1); +lean_inc(x_191); +x_192 = lean_ctor_get(x_187, 3); +lean_inc(x_192); +x_193 = lean_ctor_get(x_187, 4); +lean_inc(x_193); +x_194 = lean_ctor_get(x_187, 5); +lean_inc(x_194); +if (lean_is_exclusive(x_187)) { + lean_ctor_release(x_187, 0); + lean_ctor_release(x_187, 1); + lean_ctor_release(x_187, 2); + lean_ctor_release(x_187, 3); + lean_ctor_release(x_187, 4); + lean_ctor_release(x_187, 5); + x_195 = x_187; +} else { + lean_dec_ref(x_187); + x_195 = lean_box(0); +} +x_196 = lean_ctor_get(x_188, 0); lean_inc(x_196); -lean_dec(x_178); -x_197 = lean_ctor_get(x_179, 0); +x_197 = lean_ctor_get(x_188, 1); lean_inc(x_197); -x_198 = lean_ctor_get(x_179, 1); +x_198 = lean_ctor_get(x_188, 3); lean_inc(x_198); -x_199 = lean_ctor_get(x_179, 3); +x_199 = lean_ctor_get(x_188, 4); lean_inc(x_199); -x_200 = lean_ctor_get(x_179, 4); -lean_inc(x_200); -x_201 = lean_ctor_get(x_179, 5); -lean_inc(x_201); -if (lean_is_exclusive(x_179)) { - lean_ctor_release(x_179, 0); - lean_ctor_release(x_179, 1); - lean_ctor_release(x_179, 2); - lean_ctor_release(x_179, 3); - lean_ctor_release(x_179, 4); - lean_ctor_release(x_179, 5); - x_202 = x_179; +if (lean_is_exclusive(x_188)) { + lean_ctor_release(x_188, 0); + lean_ctor_release(x_188, 1); + lean_ctor_release(x_188, 2); + lean_ctor_release(x_188, 3); + lean_ctor_release(x_188, 4); + x_200 = x_188; } else { - lean_dec_ref(x_179); - x_202 = lean_box(0); + lean_dec_ref(x_188); + x_200 = lean_box(0); } -x_203 = lean_ctor_get(x_195, 0); -lean_inc(x_203); -x_204 = lean_ctor_get(x_195, 1); -lean_inc(x_204); -x_205 = lean_ctor_get(x_195, 3); -lean_inc(x_205); -if (lean_is_exclusive(x_195)) { - lean_ctor_release(x_195, 0); - lean_ctor_release(x_195, 1); - lean_ctor_release(x_195, 2); - lean_ctor_release(x_195, 3); - x_206 = x_195; +if (lean_is_scalar(x_200)) { + x_201 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_195); - x_206 = lean_box(0); + x_201 = x_200; } -if (lean_is_scalar(x_206)) { - x_207 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_201, 0, x_196); +lean_ctor_set(x_201, 1, x_197); +lean_ctor_set(x_201, 2, x_182); +lean_ctor_set(x_201, 3, x_198); +lean_ctor_set(x_201, 4, x_199); +if (lean_is_scalar(x_195)) { + x_202 = lean_alloc_ctor(0, 6, 0); } else { - x_207 = x_206; + x_202 = x_195; } -lean_ctor_set(x_207, 0, x_203); -lean_ctor_set(x_207, 1, x_204); -lean_ctor_set(x_207, 2, x_175); -lean_ctor_set(x_207, 3, x_205); -if (lean_is_scalar(x_202)) { - x_208 = lean_alloc_ctor(0, 6, 0); -} else { - x_208 = x_202; -} -lean_ctor_set(x_208, 0, x_197); -lean_ctor_set(x_208, 1, x_198); -lean_ctor_set(x_208, 2, x_207); -lean_ctor_set(x_208, 3, x_199); -lean_ctor_set(x_208, 4, x_200); -lean_ctor_set(x_208, 5, x_201); +lean_ctor_set(x_202, 0, x_190); +lean_ctor_set(x_202, 1, x_191); +lean_ctor_set(x_202, 2, x_201); +lean_ctor_set(x_202, 3, x_192); +lean_ctor_set(x_202, 4, x_193); +lean_ctor_set(x_202, 5, x_194); if (lean_is_scalar(x_26)) { - x_209 = lean_alloc_ctor(0, 2, 0); + x_203 = lean_alloc_ctor(1, 2, 0); } else { - x_209 = x_26; + x_203 = x_26; + lean_ctor_set_tag(x_203, 1); } -lean_ctor_set(x_209, 0, x_196); -lean_ctor_set(x_209, 1, x_208); -return x_209; +lean_ctor_set(x_203, 0, x_189); +lean_ctor_set(x_203, 1, x_202); +return x_203; +} +else +{ +lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; +x_204 = lean_ctor_get(x_187, 2); +lean_inc(x_204); +x_205 = lean_ctor_get(x_186, 0); +lean_inc(x_205); +lean_dec(x_186); +x_206 = lean_ctor_get(x_187, 0); +lean_inc(x_206); +x_207 = lean_ctor_get(x_187, 1); +lean_inc(x_207); +x_208 = lean_ctor_get(x_187, 3); +lean_inc(x_208); +x_209 = lean_ctor_get(x_187, 4); +lean_inc(x_209); +x_210 = lean_ctor_get(x_187, 5); +lean_inc(x_210); +if (lean_is_exclusive(x_187)) { + lean_ctor_release(x_187, 0); + lean_ctor_release(x_187, 1); + lean_ctor_release(x_187, 2); + lean_ctor_release(x_187, 3); + lean_ctor_release(x_187, 4); + lean_ctor_release(x_187, 5); + x_211 = x_187; +} else { + lean_dec_ref(x_187); + x_211 = lean_box(0); +} +x_212 = lean_ctor_get(x_204, 0); +lean_inc(x_212); +x_213 = lean_ctor_get(x_204, 1); +lean_inc(x_213); +x_214 = lean_ctor_get(x_204, 3); +lean_inc(x_214); +x_215 = lean_ctor_get(x_204, 4); +lean_inc(x_215); +if (lean_is_exclusive(x_204)) { + lean_ctor_release(x_204, 0); + lean_ctor_release(x_204, 1); + lean_ctor_release(x_204, 2); + lean_ctor_release(x_204, 3); + lean_ctor_release(x_204, 4); + x_216 = x_204; +} else { + lean_dec_ref(x_204); + x_216 = lean_box(0); +} +if (lean_is_scalar(x_216)) { + x_217 = lean_alloc_ctor(0, 5, 0); +} else { + x_217 = x_216; +} +lean_ctor_set(x_217, 0, x_212); +lean_ctor_set(x_217, 1, x_213); +lean_ctor_set(x_217, 2, x_182); +lean_ctor_set(x_217, 3, x_214); +lean_ctor_set(x_217, 4, x_215); +if (lean_is_scalar(x_211)) { + x_218 = lean_alloc_ctor(0, 6, 0); +} else { + x_218 = x_211; +} +lean_ctor_set(x_218, 0, x_206); +lean_ctor_set(x_218, 1, x_207); +lean_ctor_set(x_218, 2, x_217); +lean_ctor_set(x_218, 3, x_208); +lean_ctor_set(x_218, 4, x_209); +lean_ctor_set(x_218, 5, x_210); +if (lean_is_scalar(x_26)) { + x_219 = lean_alloc_ctor(0, 2, 0); +} else { + x_219 = x_26; +} +lean_ctor_set(x_219, 0, x_205); +lean_ctor_set(x_219, 1, x_218); +return x_219; } } } } default: { -lean_object* x_230; lean_object* x_231; -x_230 = lean_ctor_get(x_19, 1); -lean_inc(x_230); +lean_object* x_240; lean_object* x_241; +x_240 = lean_ctor_get(x_19, 1); +lean_inc(x_240); lean_dec(x_19); lean_inc(x_7); -x_231 = l_Lean_Meta_isClassExpensive___main(x_18, x_7, x_230); -if (lean_obj_tag(x_231) == 0) +x_241 = l_Lean_Meta_isClassExpensive___main(x_18, x_7, x_240); +if (lean_obj_tag(x_241) == 0) { -lean_object* x_232; -x_232 = lean_ctor_get(x_231, 0); -lean_inc(x_232); -if (lean_obj_tag(x_232) == 0) +lean_object* x_242; +x_242 = lean_ctor_get(x_241, 0); +lean_inc(x_242); +if (lean_obj_tag(x_242) == 0) { -lean_object* x_233; lean_object* x_234; lean_object* x_235; +lean_object* x_243; lean_object* x_244; lean_object* x_245; lean_dec(x_14); -x_233 = lean_ctor_get(x_231, 1); -lean_inc(x_233); -lean_dec(x_231); -x_234 = lean_unsigned_to_nat(1u); -x_235 = lean_nat_add(x_6, x_234); +x_243 = lean_ctor_get(x_241, 1); +lean_inc(x_243); +lean_dec(x_241); +x_244 = lean_unsigned_to_nat(1u); +x_245 = lean_nat_add(x_6, x_244); lean_dec(x_6); -x_6 = x_235; -x_8 = x_233; +x_6 = x_245; +x_8 = x_243; goto _start; } else { -lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; uint8_t x_242; -x_237 = lean_ctor_get(x_231, 1); -lean_inc(x_237); -if (lean_is_exclusive(x_231)) { - lean_ctor_release(x_231, 0); - lean_ctor_release(x_231, 1); - x_238 = x_231; +lean_object* x_247; lean_object* x_248; lean_object* x_249; lean_object* x_250; lean_object* x_251; uint8_t x_252; +x_247 = lean_ctor_get(x_241, 1); +lean_inc(x_247); +if (lean_is_exclusive(x_241)) { + lean_ctor_release(x_241, 0); + lean_ctor_release(x_241, 1); + x_248 = x_241; } else { - lean_dec_ref(x_231); - x_238 = lean_box(0); + lean_dec_ref(x_241); + x_248 = lean_box(0); } -x_239 = lean_ctor_get(x_232, 0); -lean_inc(x_239); -lean_dec(x_232); -x_240 = lean_unsigned_to_nat(1u); -x_241 = lean_nat_add(x_6, x_240); -lean_dec(x_6); -x_242 = !lean_is_exclusive(x_237); -if (x_242 == 0) -{ -lean_object* x_243; uint8_t x_244; -x_243 = lean_ctor_get(x_237, 2); -x_244 = !lean_is_exclusive(x_243); -if (x_244 == 0) -{ -lean_object* x_245; lean_object* x_246; lean_object* x_247; lean_object* x_297; uint8_t x_298; -x_245 = lean_ctor_get(x_243, 2); -x_297 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_243, 2, x_297); -x_298 = !lean_is_exclusive(x_7); -if (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_7, 2); -x_300 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_300, 0, x_239); -lean_ctor_set(x_300, 1, x_14); -x_301 = lean_array_push(x_299, x_300); -lean_ctor_set(x_7, 2, x_301); -x_302 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_Basic_6__lambdaTelescopeAux___main___spec__1___rarg(x_1, x_2, x_3, x_4, x_5, x_241, x_7, x_237); -if (lean_obj_tag(x_302) == 0) -{ -lean_object* x_303; lean_object* x_304; lean_object* x_305; -x_303 = lean_ctor_get(x_302, 0); -lean_inc(x_303); -x_304 = lean_ctor_get(x_302, 1); -lean_inc(x_304); -lean_dec(x_302); -x_305 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_305, 0, x_303); -x_246 = x_305; -x_247 = x_304; -goto block_296; -} -else -{ -lean_object* x_306; lean_object* x_307; lean_object* x_308; -x_306 = lean_ctor_get(x_302, 0); -lean_inc(x_306); -x_307 = lean_ctor_get(x_302, 1); -lean_inc(x_307); -lean_dec(x_302); -x_308 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_308, 0, x_306); -x_246 = x_308; -x_247 = x_307; -goto block_296; -} -} -else -{ -lean_object* x_309; lean_object* x_310; lean_object* x_311; lean_object* x_312; lean_object* x_313; lean_object* x_314; lean_object* x_315; lean_object* x_316; lean_object* x_317; -x_309 = lean_ctor_get(x_7, 0); -x_310 = lean_ctor_get(x_7, 1); -x_311 = lean_ctor_get(x_7, 2); -x_312 = lean_ctor_get(x_7, 3); -x_313 = lean_ctor_get(x_7, 4); -lean_inc(x_313); -lean_inc(x_312); -lean_inc(x_311); -lean_inc(x_310); -lean_inc(x_309); -lean_dec(x_7); -x_314 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_314, 0, x_239); -lean_ctor_set(x_314, 1, x_14); -x_315 = lean_array_push(x_311, x_314); -x_316 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_316, 0, x_309); -lean_ctor_set(x_316, 1, x_310); -lean_ctor_set(x_316, 2, x_315); -lean_ctor_set(x_316, 3, x_312); -lean_ctor_set(x_316, 4, x_313); -x_317 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_Basic_6__lambdaTelescopeAux___main___spec__1___rarg(x_1, x_2, x_3, x_4, x_5, x_241, x_316, x_237); -if (lean_obj_tag(x_317) == 0) -{ -lean_object* x_318; lean_object* x_319; lean_object* x_320; -x_318 = lean_ctor_get(x_317, 0); -lean_inc(x_318); -x_319 = lean_ctor_get(x_317, 1); -lean_inc(x_319); -lean_dec(x_317); -x_320 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_320, 0, x_318); -x_246 = x_320; -x_247 = x_319; -goto block_296; -} -else -{ -lean_object* x_321; lean_object* x_322; lean_object* x_323; -x_321 = lean_ctor_get(x_317, 0); -lean_inc(x_321); -x_322 = lean_ctor_get(x_317, 1); -lean_inc(x_322); -lean_dec(x_317); -x_323 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_323, 0, x_321); -x_246 = x_323; -x_247 = x_322; -goto block_296; -} -} -block_296: -{ -if (lean_obj_tag(x_246) == 0) -{ -lean_object* x_248; lean_object* x_249; uint8_t x_250; -x_248 = lean_ctor_get(x_247, 2); -lean_inc(x_248); -x_249 = lean_ctor_get(x_246, 0); +x_249 = lean_ctor_get(x_242, 0); lean_inc(x_249); -lean_dec(x_246); -x_250 = !lean_is_exclusive(x_247); -if (x_250 == 0) -{ -lean_object* x_251; uint8_t x_252; -x_251 = lean_ctor_get(x_247, 2); -lean_dec(x_251); -x_252 = !lean_is_exclusive(x_248); +lean_dec(x_242); +x_250 = lean_unsigned_to_nat(1u); +x_251 = lean_nat_add(x_6, x_250); +lean_dec(x_6); +x_252 = !lean_is_exclusive(x_247); if (x_252 == 0) { -lean_object* x_253; lean_object* x_254; -x_253 = lean_ctor_get(x_248, 2); -lean_dec(x_253); -lean_ctor_set(x_248, 2, x_245); -if (lean_is_scalar(x_238)) { - x_254 = lean_alloc_ctor(1, 2, 0); -} else { - x_254 = x_238; - lean_ctor_set_tag(x_254, 1); -} -lean_ctor_set(x_254, 0, x_249); -lean_ctor_set(x_254, 1, x_247); -return x_254; +lean_object* x_253; uint8_t x_254; +x_253 = lean_ctor_get(x_247, 2); +x_254 = !lean_is_exclusive(x_253); +if (x_254 == 0) +{ +lean_object* x_255; lean_object* x_256; lean_object* x_257; lean_object* x_311; uint8_t x_312; +x_255 = lean_ctor_get(x_253, 2); +x_311 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_253, 2, x_311); +x_312 = !lean_is_exclusive(x_7); +if (x_312 == 0) +{ +lean_object* x_313; lean_object* x_314; lean_object* x_315; lean_object* x_316; +x_313 = lean_ctor_get(x_7, 2); +x_314 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_314, 0, x_249); +lean_ctor_set(x_314, 1, x_14); +x_315 = lean_array_push(x_313, x_314); +lean_ctor_set(x_7, 2, x_315); +x_316 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_Basic_6__lambdaTelescopeAux___main___spec__1___rarg(x_1, x_2, x_3, x_4, x_5, x_251, x_7, x_247); +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); +x_319 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_319, 0, x_317); +x_256 = x_319; +x_257 = x_318; +goto block_310; } else { -lean_object* x_255; lean_object* x_256; lean_object* x_257; lean_object* x_258; lean_object* x_259; -x_255 = lean_ctor_get(x_248, 0); -x_256 = lean_ctor_get(x_248, 1); -x_257 = lean_ctor_get(x_248, 3); -lean_inc(x_257); -lean_inc(x_256); -lean_inc(x_255); -lean_dec(x_248); -x_258 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_258, 0, x_255); -lean_ctor_set(x_258, 1, x_256); -lean_ctor_set(x_258, 2, x_245); -lean_ctor_set(x_258, 3, x_257); -lean_ctor_set(x_247, 2, x_258); -if (lean_is_scalar(x_238)) { - x_259 = lean_alloc_ctor(1, 2, 0); -} else { - x_259 = x_238; - lean_ctor_set_tag(x_259, 1); -} -lean_ctor_set(x_259, 0, x_249); -lean_ctor_set(x_259, 1, x_247); -return x_259; +lean_object* x_320; lean_object* x_321; lean_object* x_322; +x_320 = lean_ctor_get(x_316, 0); +lean_inc(x_320); +x_321 = lean_ctor_get(x_316, 1); +lean_inc(x_321); +lean_dec(x_316); +x_322 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_322, 0, x_320); +x_256 = x_322; +x_257 = x_321; +goto block_310; } } else { -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_260 = lean_ctor_get(x_247, 0); -x_261 = lean_ctor_get(x_247, 1); -x_262 = lean_ctor_get(x_247, 3); -x_263 = lean_ctor_get(x_247, 4); -x_264 = lean_ctor_get(x_247, 5); -lean_inc(x_264); -lean_inc(x_263); -lean_inc(x_262); -lean_inc(x_261); -lean_inc(x_260); -lean_dec(x_247); -x_265 = lean_ctor_get(x_248, 0); -lean_inc(x_265); -x_266 = lean_ctor_get(x_248, 1); -lean_inc(x_266); -x_267 = lean_ctor_get(x_248, 3); +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; +x_323 = lean_ctor_get(x_7, 0); +x_324 = lean_ctor_get(x_7, 1); +x_325 = lean_ctor_get(x_7, 2); +x_326 = lean_ctor_get(x_7, 3); +x_327 = lean_ctor_get(x_7, 4); +lean_inc(x_327); +lean_inc(x_326); +lean_inc(x_325); +lean_inc(x_324); +lean_inc(x_323); +lean_dec(x_7); +x_328 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_328, 0, x_249); +lean_ctor_set(x_328, 1, x_14); +x_329 = lean_array_push(x_325, x_328); +x_330 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_330, 0, x_323); +lean_ctor_set(x_330, 1, x_324); +lean_ctor_set(x_330, 2, x_329); +lean_ctor_set(x_330, 3, x_326); +lean_ctor_set(x_330, 4, x_327); +x_331 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_Basic_6__lambdaTelescopeAux___main___spec__1___rarg(x_1, x_2, x_3, x_4, x_5, x_251, x_330, x_247); +if (lean_obj_tag(x_331) == 0) +{ +lean_object* x_332; lean_object* x_333; lean_object* x_334; +x_332 = lean_ctor_get(x_331, 0); +lean_inc(x_332); +x_333 = lean_ctor_get(x_331, 1); +lean_inc(x_333); +lean_dec(x_331); +x_334 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_334, 0, x_332); +x_256 = x_334; +x_257 = x_333; +goto block_310; +} +else +{ +lean_object* x_335; lean_object* x_336; lean_object* x_337; +x_335 = lean_ctor_get(x_331, 0); +lean_inc(x_335); +x_336 = lean_ctor_get(x_331, 1); +lean_inc(x_336); +lean_dec(x_331); +x_337 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_337, 0, x_335); +x_256 = x_337; +x_257 = x_336; +goto block_310; +} +} +block_310: +{ +if (lean_obj_tag(x_256) == 0) +{ +lean_object* x_258; lean_object* x_259; uint8_t x_260; +x_258 = lean_ctor_get(x_257, 2); +lean_inc(x_258); +x_259 = lean_ctor_get(x_256, 0); +lean_inc(x_259); +lean_dec(x_256); +x_260 = !lean_is_exclusive(x_257); +if (x_260 == 0) +{ +lean_object* x_261; uint8_t x_262; +x_261 = lean_ctor_get(x_257, 2); +lean_dec(x_261); +x_262 = !lean_is_exclusive(x_258); +if (x_262 == 0) +{ +lean_object* x_263; lean_object* x_264; +x_263 = lean_ctor_get(x_258, 2); +lean_dec(x_263); +lean_ctor_set(x_258, 2, x_255); +if (lean_is_scalar(x_248)) { + x_264 = lean_alloc_ctor(1, 2, 0); +} else { + x_264 = x_248; + lean_ctor_set_tag(x_264, 1); +} +lean_ctor_set(x_264, 0, x_259); +lean_ctor_set(x_264, 1, x_257); +return x_264; +} +else +{ +lean_object* x_265; lean_object* x_266; lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_object* x_270; +x_265 = lean_ctor_get(x_258, 0); +x_266 = lean_ctor_get(x_258, 1); +x_267 = lean_ctor_get(x_258, 3); +x_268 = lean_ctor_get(x_258, 4); +lean_inc(x_268); lean_inc(x_267); -if (lean_is_exclusive(x_248)) { - lean_ctor_release(x_248, 0); - lean_ctor_release(x_248, 1); - lean_ctor_release(x_248, 2); - lean_ctor_release(x_248, 3); - x_268 = x_248; -} else { - lean_dec_ref(x_248); - x_268 = lean_box(0); -} -if (lean_is_scalar(x_268)) { - x_269 = lean_alloc_ctor(0, 4, 0); -} else { - x_269 = x_268; -} +lean_inc(x_266); +lean_inc(x_265); +lean_dec(x_258); +x_269 = lean_alloc_ctor(0, 5, 0); lean_ctor_set(x_269, 0, x_265); lean_ctor_set(x_269, 1, x_266); -lean_ctor_set(x_269, 2, x_245); +lean_ctor_set(x_269, 2, x_255); lean_ctor_set(x_269, 3, x_267); -x_270 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_270, 0, x_260); -lean_ctor_set(x_270, 1, x_261); -lean_ctor_set(x_270, 2, x_269); -lean_ctor_set(x_270, 3, x_262); -lean_ctor_set(x_270, 4, x_263); -lean_ctor_set(x_270, 5, x_264); -if (lean_is_scalar(x_238)) { - x_271 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_269, 4, x_268); +lean_ctor_set(x_257, 2, x_269); +if (lean_is_scalar(x_248)) { + x_270 = lean_alloc_ctor(1, 2, 0); } else { - x_271 = x_238; - lean_ctor_set_tag(x_271, 1); + x_270 = x_248; + lean_ctor_set_tag(x_270, 1); } -lean_ctor_set(x_271, 0, x_249); -lean_ctor_set(x_271, 1, x_270); -return x_271; +lean_ctor_set(x_270, 0, x_259); +lean_ctor_set(x_270, 1, x_257); +return x_270; } } else { -lean_object* x_272; lean_object* x_273; uint8_t x_274; -x_272 = lean_ctor_get(x_247, 2); -lean_inc(x_272); -x_273 = lean_ctor_get(x_246, 0); +lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_object* x_276; lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; lean_object* x_281; lean_object* x_282; lean_object* x_283; +x_271 = lean_ctor_get(x_257, 0); +x_272 = lean_ctor_get(x_257, 1); +x_273 = lean_ctor_get(x_257, 3); +x_274 = lean_ctor_get(x_257, 4); +x_275 = lean_ctor_get(x_257, 5); +lean_inc(x_275); +lean_inc(x_274); lean_inc(x_273); -lean_dec(x_246); -x_274 = !lean_is_exclusive(x_247); -if (x_274 == 0) -{ -lean_object* x_275; uint8_t x_276; -x_275 = lean_ctor_get(x_247, 2); -lean_dec(x_275); -x_276 = !lean_is_exclusive(x_272); -if (x_276 == 0) -{ -lean_object* x_277; lean_object* x_278; -x_277 = lean_ctor_get(x_272, 2); -lean_dec(x_277); -lean_ctor_set(x_272, 2, x_245); -if (lean_is_scalar(x_238)) { - x_278 = lean_alloc_ctor(0, 2, 0); -} else { - x_278 = x_238; -} -lean_ctor_set(x_278, 0, x_273); -lean_ctor_set(x_278, 1, x_247); -return x_278; -} -else -{ -lean_object* x_279; lean_object* x_280; lean_object* x_281; lean_object* x_282; lean_object* x_283; -x_279 = lean_ctor_get(x_272, 0); -x_280 = lean_ctor_get(x_272, 1); -x_281 = lean_ctor_get(x_272, 3); -lean_inc(x_281); -lean_inc(x_280); +lean_inc(x_272); +lean_inc(x_271); +lean_dec(x_257); +x_276 = lean_ctor_get(x_258, 0); +lean_inc(x_276); +x_277 = lean_ctor_get(x_258, 1); +lean_inc(x_277); +x_278 = lean_ctor_get(x_258, 3); +lean_inc(x_278); +x_279 = lean_ctor_get(x_258, 4); lean_inc(x_279); -lean_dec(x_272); -x_282 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_282, 0, x_279); -lean_ctor_set(x_282, 1, x_280); -lean_ctor_set(x_282, 2, x_245); -lean_ctor_set(x_282, 3, x_281); -lean_ctor_set(x_247, 2, x_282); -if (lean_is_scalar(x_238)) { - x_283 = lean_alloc_ctor(0, 2, 0); +if (lean_is_exclusive(x_258)) { + lean_ctor_release(x_258, 0); + lean_ctor_release(x_258, 1); + lean_ctor_release(x_258, 2); + lean_ctor_release(x_258, 3); + lean_ctor_release(x_258, 4); + x_280 = x_258; } else { - x_283 = x_238; + lean_dec_ref(x_258); + x_280 = lean_box(0); } -lean_ctor_set(x_283, 0, x_273); -lean_ctor_set(x_283, 1, x_247); +if (lean_is_scalar(x_280)) { + x_281 = lean_alloc_ctor(0, 5, 0); +} else { + x_281 = x_280; +} +lean_ctor_set(x_281, 0, x_276); +lean_ctor_set(x_281, 1, x_277); +lean_ctor_set(x_281, 2, x_255); +lean_ctor_set(x_281, 3, x_278); +lean_ctor_set(x_281, 4, x_279); +x_282 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_282, 0, x_271); +lean_ctor_set(x_282, 1, x_272); +lean_ctor_set(x_282, 2, x_281); +lean_ctor_set(x_282, 3, x_273); +lean_ctor_set(x_282, 4, x_274); +lean_ctor_set(x_282, 5, x_275); +if (lean_is_scalar(x_248)) { + x_283 = lean_alloc_ctor(1, 2, 0); +} else { + x_283 = x_248; + lean_ctor_set_tag(x_283, 1); +} +lean_ctor_set(x_283, 0, x_259); +lean_ctor_set(x_283, 1, x_282); return x_283; } } else { -lean_object* x_284; lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; lean_object* x_289; lean_object* x_290; lean_object* x_291; lean_object* x_292; lean_object* x_293; lean_object* x_294; lean_object* x_295; -x_284 = lean_ctor_get(x_247, 0); -x_285 = lean_ctor_get(x_247, 1); -x_286 = lean_ctor_get(x_247, 3); -x_287 = lean_ctor_get(x_247, 4); -x_288 = lean_ctor_get(x_247, 5); -lean_inc(x_288); -lean_inc(x_287); -lean_inc(x_286); -lean_inc(x_285); +lean_object* x_284; lean_object* x_285; uint8_t x_286; +x_284 = lean_ctor_get(x_257, 2); lean_inc(x_284); -lean_dec(x_247); -x_289 = lean_ctor_get(x_272, 0); -lean_inc(x_289); -x_290 = lean_ctor_get(x_272, 1); -lean_inc(x_290); -x_291 = lean_ctor_get(x_272, 3); +x_285 = lean_ctor_get(x_256, 0); +lean_inc(x_285); +lean_dec(x_256); +x_286 = !lean_is_exclusive(x_257); +if (x_286 == 0) +{ +lean_object* x_287; uint8_t x_288; +x_287 = lean_ctor_get(x_257, 2); +lean_dec(x_287); +x_288 = !lean_is_exclusive(x_284); +if (x_288 == 0) +{ +lean_object* x_289; lean_object* x_290; +x_289 = lean_ctor_get(x_284, 2); +lean_dec(x_289); +lean_ctor_set(x_284, 2, x_255); +if (lean_is_scalar(x_248)) { + x_290 = lean_alloc_ctor(0, 2, 0); +} else { + x_290 = x_248; +} +lean_ctor_set(x_290, 0, x_285); +lean_ctor_set(x_290, 1, x_257); +return x_290; +} +else +{ +lean_object* x_291; lean_object* x_292; lean_object* x_293; lean_object* x_294; lean_object* x_295; lean_object* x_296; +x_291 = lean_ctor_get(x_284, 0); +x_292 = lean_ctor_get(x_284, 1); +x_293 = lean_ctor_get(x_284, 3); +x_294 = lean_ctor_get(x_284, 4); +lean_inc(x_294); +lean_inc(x_293); +lean_inc(x_292); lean_inc(x_291); -if (lean_is_exclusive(x_272)) { - lean_ctor_release(x_272, 0); - lean_ctor_release(x_272, 1); - lean_ctor_release(x_272, 2); - lean_ctor_release(x_272, 3); - x_292 = x_272; +lean_dec(x_284); +x_295 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_295, 0, x_291); +lean_ctor_set(x_295, 1, x_292); +lean_ctor_set(x_295, 2, x_255); +lean_ctor_set(x_295, 3, x_293); +lean_ctor_set(x_295, 4, x_294); +lean_ctor_set(x_257, 2, x_295); +if (lean_is_scalar(x_248)) { + x_296 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_272); - x_292 = lean_box(0); + x_296 = x_248; } -if (lean_is_scalar(x_292)) { - x_293 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_296, 0, x_285); +lean_ctor_set(x_296, 1, x_257); +return x_296; +} +} +else +{ +lean_object* x_297; lean_object* x_298; lean_object* x_299; lean_object* x_300; lean_object* x_301; lean_object* x_302; lean_object* x_303; lean_object* x_304; lean_object* x_305; lean_object* x_306; lean_object* x_307; lean_object* x_308; lean_object* x_309; +x_297 = lean_ctor_get(x_257, 0); +x_298 = lean_ctor_get(x_257, 1); +x_299 = lean_ctor_get(x_257, 3); +x_300 = lean_ctor_get(x_257, 4); +x_301 = lean_ctor_get(x_257, 5); +lean_inc(x_301); +lean_inc(x_300); +lean_inc(x_299); +lean_inc(x_298); +lean_inc(x_297); +lean_dec(x_257); +x_302 = lean_ctor_get(x_284, 0); +lean_inc(x_302); +x_303 = lean_ctor_get(x_284, 1); +lean_inc(x_303); +x_304 = lean_ctor_get(x_284, 3); +lean_inc(x_304); +x_305 = lean_ctor_get(x_284, 4); +lean_inc(x_305); +if (lean_is_exclusive(x_284)) { + lean_ctor_release(x_284, 0); + lean_ctor_release(x_284, 1); + lean_ctor_release(x_284, 2); + lean_ctor_release(x_284, 3); + lean_ctor_release(x_284, 4); + x_306 = x_284; } else { - x_293 = x_292; + lean_dec_ref(x_284); + x_306 = lean_box(0); } -lean_ctor_set(x_293, 0, x_289); -lean_ctor_set(x_293, 1, x_290); -lean_ctor_set(x_293, 2, x_245); -lean_ctor_set(x_293, 3, x_291); -x_294 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_294, 0, x_284); -lean_ctor_set(x_294, 1, x_285); -lean_ctor_set(x_294, 2, x_293); -lean_ctor_set(x_294, 3, x_286); -lean_ctor_set(x_294, 4, x_287); -lean_ctor_set(x_294, 5, x_288); -if (lean_is_scalar(x_238)) { - x_295 = lean_alloc_ctor(0, 2, 0); +if (lean_is_scalar(x_306)) { + x_307 = lean_alloc_ctor(0, 5, 0); } else { - x_295 = x_238; + x_307 = x_306; } -lean_ctor_set(x_295, 0, x_273); -lean_ctor_set(x_295, 1, x_294); -return x_295; +lean_ctor_set(x_307, 0, x_302); +lean_ctor_set(x_307, 1, x_303); +lean_ctor_set(x_307, 2, x_255); +lean_ctor_set(x_307, 3, x_304); +lean_ctor_set(x_307, 4, x_305); +x_308 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_308, 0, x_297); +lean_ctor_set(x_308, 1, x_298); +lean_ctor_set(x_308, 2, x_307); +lean_ctor_set(x_308, 3, x_299); +lean_ctor_set(x_308, 4, x_300); +lean_ctor_set(x_308, 5, x_301); +if (lean_is_scalar(x_248)) { + x_309 = lean_alloc_ctor(0, 2, 0); +} else { + x_309 = x_248; +} +lean_ctor_set(x_309, 0, x_285); +lean_ctor_set(x_309, 1, x_308); +return x_309; } } } } else { -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_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; -x_324 = lean_ctor_get(x_243, 0); -x_325 = lean_ctor_get(x_243, 1); -x_326 = lean_ctor_get(x_243, 2); -x_327 = lean_ctor_get(x_243, 3); -lean_inc(x_327); -lean_inc(x_326); -lean_inc(x_325); -lean_inc(x_324); -lean_dec(x_243); -x_361 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_362 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_362, 0, x_324); -lean_ctor_set(x_362, 1, x_325); -lean_ctor_set(x_362, 2, x_361); -lean_ctor_set(x_362, 3, x_327); -lean_ctor_set(x_237, 2, x_362); -x_363 = lean_ctor_get(x_7, 0); -lean_inc(x_363); -x_364 = lean_ctor_get(x_7, 1); -lean_inc(x_364); -x_365 = lean_ctor_get(x_7, 2); -lean_inc(x_365); -x_366 = lean_ctor_get(x_7, 3); -lean_inc(x_366); -x_367 = lean_ctor_get(x_7, 4); -lean_inc(x_367); +lean_object* x_338; lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; lean_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; +x_338 = lean_ctor_get(x_253, 0); +x_339 = lean_ctor_get(x_253, 1); +x_340 = lean_ctor_get(x_253, 2); +x_341 = lean_ctor_get(x_253, 3); +x_342 = lean_ctor_get(x_253, 4); +lean_inc(x_342); +lean_inc(x_341); +lean_inc(x_340); +lean_inc(x_339); +lean_inc(x_338); +lean_dec(x_253); +x_378 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_379 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_379, 0, x_338); +lean_ctor_set(x_379, 1, x_339); +lean_ctor_set(x_379, 2, x_378); +lean_ctor_set(x_379, 3, x_341); +lean_ctor_set(x_379, 4, x_342); +lean_ctor_set(x_247, 2, x_379); +x_380 = lean_ctor_get(x_7, 0); +lean_inc(x_380); +x_381 = lean_ctor_get(x_7, 1); +lean_inc(x_381); +x_382 = lean_ctor_get(x_7, 2); +lean_inc(x_382); +x_383 = lean_ctor_get(x_7, 3); +lean_inc(x_383); +x_384 = lean_ctor_get(x_7, 4); +lean_inc(x_384); if (lean_is_exclusive(x_7)) { lean_ctor_release(x_7, 0); lean_ctor_release(x_7, 1); lean_ctor_release(x_7, 2); lean_ctor_release(x_7, 3); lean_ctor_release(x_7, 4); - x_368 = x_7; + x_385 = x_7; } else { lean_dec_ref(x_7); - x_368 = lean_box(0); + x_385 = lean_box(0); } -x_369 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_369, 0, x_239); -lean_ctor_set(x_369, 1, x_14); -x_370 = lean_array_push(x_365, x_369); -if (lean_is_scalar(x_368)) { - x_371 = lean_alloc_ctor(0, 5, 0); +x_386 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_386, 0, x_249); +lean_ctor_set(x_386, 1, x_14); +x_387 = lean_array_push(x_382, x_386); +if (lean_is_scalar(x_385)) { + x_388 = lean_alloc_ctor(0, 5, 0); } else { - x_371 = x_368; + x_388 = x_385; } -lean_ctor_set(x_371, 0, x_363); -lean_ctor_set(x_371, 1, x_364); -lean_ctor_set(x_371, 2, x_370); -lean_ctor_set(x_371, 3, x_366); -lean_ctor_set(x_371, 4, x_367); -x_372 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_Basic_6__lambdaTelescopeAux___main___spec__1___rarg(x_1, x_2, x_3, x_4, x_5, x_241, x_371, x_237); -if (lean_obj_tag(x_372) == 0) +lean_ctor_set(x_388, 0, x_380); +lean_ctor_set(x_388, 1, x_381); +lean_ctor_set(x_388, 2, x_387); +lean_ctor_set(x_388, 3, x_383); +lean_ctor_set(x_388, 4, x_384); +x_389 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_Basic_6__lambdaTelescopeAux___main___spec__1___rarg(x_1, x_2, x_3, x_4, x_5, x_251, x_388, x_247); +if (lean_obj_tag(x_389) == 0) { -lean_object* x_373; lean_object* x_374; lean_object* x_375; -x_373 = lean_ctor_get(x_372, 0); -lean_inc(x_373); -x_374 = lean_ctor_get(x_372, 1); -lean_inc(x_374); -lean_dec(x_372); -x_375 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_375, 0, x_373); -x_328 = x_375; -x_329 = x_374; -goto block_360; +lean_object* x_390; lean_object* x_391; lean_object* x_392; +x_390 = lean_ctor_get(x_389, 0); +lean_inc(x_390); +x_391 = lean_ctor_get(x_389, 1); +lean_inc(x_391); +lean_dec(x_389); +x_392 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_392, 0, x_390); +x_343 = x_392; +x_344 = x_391; +goto block_377; } else { -lean_object* x_376; lean_object* x_377; lean_object* x_378; -x_376 = lean_ctor_get(x_372, 0); -lean_inc(x_376); -x_377 = lean_ctor_get(x_372, 1); -lean_inc(x_377); -lean_dec(x_372); -x_378 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_378, 0, x_376); -x_328 = x_378; -x_329 = x_377; -goto block_360; +lean_object* x_393; lean_object* x_394; lean_object* x_395; +x_393 = lean_ctor_get(x_389, 0); +lean_inc(x_393); +x_394 = lean_ctor_get(x_389, 1); +lean_inc(x_394); +lean_dec(x_389); +x_395 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_395, 0, x_393); +x_343 = x_395; +x_344 = x_394; +goto block_377; } -block_360: +block_377: { -if (lean_obj_tag(x_328) == 0) +if (lean_obj_tag(x_343) == 0) { -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; lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; -x_330 = lean_ctor_get(x_329, 2); -lean_inc(x_330); -x_331 = lean_ctor_get(x_328, 0); -lean_inc(x_331); -lean_dec(x_328); -x_332 = lean_ctor_get(x_329, 0); -lean_inc(x_332); -x_333 = lean_ctor_get(x_329, 1); -lean_inc(x_333); -x_334 = lean_ctor_get(x_329, 3); -lean_inc(x_334); -x_335 = lean_ctor_get(x_329, 4); -lean_inc(x_335); -x_336 = lean_ctor_get(x_329, 5); -lean_inc(x_336); -if (lean_is_exclusive(x_329)) { - lean_ctor_release(x_329, 0); - lean_ctor_release(x_329, 1); - lean_ctor_release(x_329, 2); - lean_ctor_release(x_329, 3); - lean_ctor_release(x_329, 4); - lean_ctor_release(x_329, 5); - x_337 = x_329; -} else { - lean_dec_ref(x_329); - x_337 = lean_box(0); -} -x_338 = lean_ctor_get(x_330, 0); -lean_inc(x_338); -x_339 = lean_ctor_get(x_330, 1); -lean_inc(x_339); -x_340 = lean_ctor_get(x_330, 3); -lean_inc(x_340); -if (lean_is_exclusive(x_330)) { - lean_ctor_release(x_330, 0); - lean_ctor_release(x_330, 1); - lean_ctor_release(x_330, 2); - lean_ctor_release(x_330, 3); - x_341 = x_330; -} else { - lean_dec_ref(x_330); - x_341 = lean_box(0); -} -if (lean_is_scalar(x_341)) { - x_342 = lean_alloc_ctor(0, 4, 0); -} else { - x_342 = x_341; -} -lean_ctor_set(x_342, 0, x_338); -lean_ctor_set(x_342, 1, x_339); -lean_ctor_set(x_342, 2, x_326); -lean_ctor_set(x_342, 3, x_340); -if (lean_is_scalar(x_337)) { - x_343 = lean_alloc_ctor(0, 6, 0); -} else { - x_343 = x_337; -} -lean_ctor_set(x_343, 0, x_332); -lean_ctor_set(x_343, 1, x_333); -lean_ctor_set(x_343, 2, x_342); -lean_ctor_set(x_343, 3, x_334); -lean_ctor_set(x_343, 4, x_335); -lean_ctor_set(x_343, 5, x_336); -if (lean_is_scalar(x_238)) { - x_344 = lean_alloc_ctor(1, 2, 0); -} else { - x_344 = x_238; - lean_ctor_set_tag(x_344, 1); -} -lean_ctor_set(x_344, 0, x_331); -lean_ctor_set(x_344, 1, x_343); -return x_344; -} -else -{ -lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; lean_object* x_350; lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; lean_object* x_358; lean_object* x_359; -x_345 = lean_ctor_get(x_329, 2); +lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; lean_object* x_350; lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; lean_object* x_358; lean_object* x_359; lean_object* x_360; +x_345 = lean_ctor_get(x_344, 2); lean_inc(x_345); -x_346 = lean_ctor_get(x_328, 0); +x_346 = lean_ctor_get(x_343, 0); lean_inc(x_346); -lean_dec(x_328); -x_347 = lean_ctor_get(x_329, 0); +lean_dec(x_343); +x_347 = lean_ctor_get(x_344, 0); lean_inc(x_347); -x_348 = lean_ctor_get(x_329, 1); +x_348 = lean_ctor_get(x_344, 1); lean_inc(x_348); -x_349 = lean_ctor_get(x_329, 3); +x_349 = lean_ctor_get(x_344, 3); lean_inc(x_349); -x_350 = lean_ctor_get(x_329, 4); +x_350 = lean_ctor_get(x_344, 4); lean_inc(x_350); -x_351 = lean_ctor_get(x_329, 5); +x_351 = lean_ctor_get(x_344, 5); lean_inc(x_351); -if (lean_is_exclusive(x_329)) { - lean_ctor_release(x_329, 0); - lean_ctor_release(x_329, 1); - lean_ctor_release(x_329, 2); - lean_ctor_release(x_329, 3); - lean_ctor_release(x_329, 4); - lean_ctor_release(x_329, 5); - x_352 = x_329; +if (lean_is_exclusive(x_344)) { + lean_ctor_release(x_344, 0); + lean_ctor_release(x_344, 1); + lean_ctor_release(x_344, 2); + lean_ctor_release(x_344, 3); + lean_ctor_release(x_344, 4); + lean_ctor_release(x_344, 5); + x_352 = x_344; } else { - lean_dec_ref(x_329); + lean_dec_ref(x_344); x_352 = lean_box(0); } x_353 = lean_ctor_get(x_345, 0); @@ -37552,315 +38672,411 @@ x_354 = lean_ctor_get(x_345, 1); lean_inc(x_354); x_355 = lean_ctor_get(x_345, 3); lean_inc(x_355); +x_356 = lean_ctor_get(x_345, 4); +lean_inc(x_356); if (lean_is_exclusive(x_345)) { lean_ctor_release(x_345, 0); lean_ctor_release(x_345, 1); lean_ctor_release(x_345, 2); lean_ctor_release(x_345, 3); - x_356 = x_345; + lean_ctor_release(x_345, 4); + x_357 = x_345; } else { lean_dec_ref(x_345); - x_356 = lean_box(0); + x_357 = lean_box(0); } -if (lean_is_scalar(x_356)) { - x_357 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_357)) { + x_358 = lean_alloc_ctor(0, 5, 0); } else { - x_357 = x_356; + x_358 = x_357; } -lean_ctor_set(x_357, 0, x_353); -lean_ctor_set(x_357, 1, x_354); -lean_ctor_set(x_357, 2, x_326); -lean_ctor_set(x_357, 3, x_355); +lean_ctor_set(x_358, 0, x_353); +lean_ctor_set(x_358, 1, x_354); +lean_ctor_set(x_358, 2, x_340); +lean_ctor_set(x_358, 3, x_355); +lean_ctor_set(x_358, 4, x_356); if (lean_is_scalar(x_352)) { - x_358 = lean_alloc_ctor(0, 6, 0); + x_359 = lean_alloc_ctor(0, 6, 0); } else { - x_358 = x_352; + x_359 = x_352; } -lean_ctor_set(x_358, 0, x_347); -lean_ctor_set(x_358, 1, x_348); -lean_ctor_set(x_358, 2, x_357); -lean_ctor_set(x_358, 3, x_349); -lean_ctor_set(x_358, 4, x_350); -lean_ctor_set(x_358, 5, x_351); -if (lean_is_scalar(x_238)) { - x_359 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_359, 0, x_347); +lean_ctor_set(x_359, 1, x_348); +lean_ctor_set(x_359, 2, x_358); +lean_ctor_set(x_359, 3, x_349); +lean_ctor_set(x_359, 4, x_350); +lean_ctor_set(x_359, 5, x_351); +if (lean_is_scalar(x_248)) { + x_360 = lean_alloc_ctor(1, 2, 0); } else { - x_359 = x_238; + x_360 = x_248; + lean_ctor_set_tag(x_360, 1); } -lean_ctor_set(x_359, 0, x_346); -lean_ctor_set(x_359, 1, x_358); -return x_359; +lean_ctor_set(x_360, 0, x_346); +lean_ctor_set(x_360, 1, x_359); +return x_360; +} +else +{ +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; lean_object* x_374; lean_object* x_375; lean_object* x_376; +x_361 = lean_ctor_get(x_344, 2); +lean_inc(x_361); +x_362 = lean_ctor_get(x_343, 0); +lean_inc(x_362); +lean_dec(x_343); +x_363 = lean_ctor_get(x_344, 0); +lean_inc(x_363); +x_364 = lean_ctor_get(x_344, 1); +lean_inc(x_364); +x_365 = lean_ctor_get(x_344, 3); +lean_inc(x_365); +x_366 = lean_ctor_get(x_344, 4); +lean_inc(x_366); +x_367 = lean_ctor_get(x_344, 5); +lean_inc(x_367); +if (lean_is_exclusive(x_344)) { + lean_ctor_release(x_344, 0); + lean_ctor_release(x_344, 1); + lean_ctor_release(x_344, 2); + lean_ctor_release(x_344, 3); + lean_ctor_release(x_344, 4); + lean_ctor_release(x_344, 5); + x_368 = x_344; +} else { + lean_dec_ref(x_344); + x_368 = lean_box(0); +} +x_369 = lean_ctor_get(x_361, 0); +lean_inc(x_369); +x_370 = lean_ctor_get(x_361, 1); +lean_inc(x_370); +x_371 = lean_ctor_get(x_361, 3); +lean_inc(x_371); +x_372 = lean_ctor_get(x_361, 4); +lean_inc(x_372); +if (lean_is_exclusive(x_361)) { + lean_ctor_release(x_361, 0); + lean_ctor_release(x_361, 1); + lean_ctor_release(x_361, 2); + lean_ctor_release(x_361, 3); + lean_ctor_release(x_361, 4); + x_373 = x_361; +} else { + lean_dec_ref(x_361); + x_373 = lean_box(0); +} +if (lean_is_scalar(x_373)) { + x_374 = lean_alloc_ctor(0, 5, 0); +} else { + x_374 = x_373; +} +lean_ctor_set(x_374, 0, x_369); +lean_ctor_set(x_374, 1, x_370); +lean_ctor_set(x_374, 2, x_340); +lean_ctor_set(x_374, 3, x_371); +lean_ctor_set(x_374, 4, x_372); +if (lean_is_scalar(x_368)) { + x_375 = lean_alloc_ctor(0, 6, 0); +} else { + x_375 = x_368; +} +lean_ctor_set(x_375, 0, x_363); +lean_ctor_set(x_375, 1, x_364); +lean_ctor_set(x_375, 2, x_374); +lean_ctor_set(x_375, 3, x_365); +lean_ctor_set(x_375, 4, x_366); +lean_ctor_set(x_375, 5, x_367); +if (lean_is_scalar(x_248)) { + x_376 = lean_alloc_ctor(0, 2, 0); +} else { + x_376 = x_248; +} +lean_ctor_set(x_376, 0, x_362); +lean_ctor_set(x_376, 1, x_375); +return x_376; } } } } else { -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; lean_object* x_391; lean_object* x_423; lean_object* x_424; lean_object* x_425; lean_object* x_426; lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; lean_object* x_432; lean_object* x_433; lean_object* x_434; lean_object* x_435; -x_379 = lean_ctor_get(x_237, 2); -x_380 = lean_ctor_get(x_237, 0); -x_381 = lean_ctor_get(x_237, 1); -x_382 = lean_ctor_get(x_237, 3); -x_383 = lean_ctor_get(x_237, 4); -x_384 = lean_ctor_get(x_237, 5); -lean_inc(x_384); -lean_inc(x_383); -lean_inc(x_382); -lean_inc(x_379); -lean_inc(x_381); -lean_inc(x_380); -lean_dec(x_237); -x_385 = lean_ctor_get(x_379, 0); -lean_inc(x_385); -x_386 = lean_ctor_get(x_379, 1); -lean_inc(x_386); -x_387 = lean_ctor_get(x_379, 2); -lean_inc(x_387); -x_388 = lean_ctor_get(x_379, 3); -lean_inc(x_388); -if (lean_is_exclusive(x_379)) { - lean_ctor_release(x_379, 0); - lean_ctor_release(x_379, 1); - lean_ctor_release(x_379, 2); - lean_ctor_release(x_379, 3); - x_389 = x_379; +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; lean_object* x_408; lean_object* x_409; lean_object* x_443; lean_object* x_444; lean_object* x_445; lean_object* x_446; lean_object* x_447; lean_object* x_448; lean_object* x_449; lean_object* x_450; lean_object* x_451; lean_object* x_452; lean_object* x_453; lean_object* x_454; lean_object* x_455; +x_396 = lean_ctor_get(x_247, 2); +x_397 = lean_ctor_get(x_247, 0); +x_398 = lean_ctor_get(x_247, 1); +x_399 = lean_ctor_get(x_247, 3); +x_400 = lean_ctor_get(x_247, 4); +x_401 = lean_ctor_get(x_247, 5); +lean_inc(x_401); +lean_inc(x_400); +lean_inc(x_399); +lean_inc(x_396); +lean_inc(x_398); +lean_inc(x_397); +lean_dec(x_247); +x_402 = lean_ctor_get(x_396, 0); +lean_inc(x_402); +x_403 = lean_ctor_get(x_396, 1); +lean_inc(x_403); +x_404 = lean_ctor_get(x_396, 2); +lean_inc(x_404); +x_405 = lean_ctor_get(x_396, 3); +lean_inc(x_405); +x_406 = lean_ctor_get(x_396, 4); +lean_inc(x_406); +if (lean_is_exclusive(x_396)) { + lean_ctor_release(x_396, 0); + lean_ctor_release(x_396, 1); + lean_ctor_release(x_396, 2); + lean_ctor_release(x_396, 3); + lean_ctor_release(x_396, 4); + x_407 = x_396; } else { - lean_dec_ref(x_379); - x_389 = lean_box(0); + lean_dec_ref(x_396); + x_407 = lean_box(0); } -x_423 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_389)) { - x_424 = lean_alloc_ctor(0, 4, 0); +x_443 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_407)) { + x_444 = lean_alloc_ctor(0, 5, 0); } else { - x_424 = x_389; + x_444 = x_407; } -lean_ctor_set(x_424, 0, x_385); -lean_ctor_set(x_424, 1, x_386); -lean_ctor_set(x_424, 2, x_423); -lean_ctor_set(x_424, 3, x_388); -x_425 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_425, 0, x_380); -lean_ctor_set(x_425, 1, x_381); -lean_ctor_set(x_425, 2, x_424); -lean_ctor_set(x_425, 3, x_382); -lean_ctor_set(x_425, 4, x_383); -lean_ctor_set(x_425, 5, x_384); -x_426 = lean_ctor_get(x_7, 0); -lean_inc(x_426); -x_427 = lean_ctor_get(x_7, 1); -lean_inc(x_427); -x_428 = lean_ctor_get(x_7, 2); -lean_inc(x_428); -x_429 = lean_ctor_get(x_7, 3); -lean_inc(x_429); -x_430 = lean_ctor_get(x_7, 4); -lean_inc(x_430); +lean_ctor_set(x_444, 0, x_402); +lean_ctor_set(x_444, 1, x_403); +lean_ctor_set(x_444, 2, x_443); +lean_ctor_set(x_444, 3, x_405); +lean_ctor_set(x_444, 4, x_406); +x_445 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_445, 0, x_397); +lean_ctor_set(x_445, 1, x_398); +lean_ctor_set(x_445, 2, x_444); +lean_ctor_set(x_445, 3, x_399); +lean_ctor_set(x_445, 4, x_400); +lean_ctor_set(x_445, 5, x_401); +x_446 = lean_ctor_get(x_7, 0); +lean_inc(x_446); +x_447 = lean_ctor_get(x_7, 1); +lean_inc(x_447); +x_448 = lean_ctor_get(x_7, 2); +lean_inc(x_448); +x_449 = lean_ctor_get(x_7, 3); +lean_inc(x_449); +x_450 = lean_ctor_get(x_7, 4); +lean_inc(x_450); if (lean_is_exclusive(x_7)) { lean_ctor_release(x_7, 0); lean_ctor_release(x_7, 1); lean_ctor_release(x_7, 2); lean_ctor_release(x_7, 3); lean_ctor_release(x_7, 4); - x_431 = x_7; + x_451 = x_7; } else { lean_dec_ref(x_7); - x_431 = lean_box(0); + x_451 = lean_box(0); } -x_432 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_432, 0, x_239); -lean_ctor_set(x_432, 1, x_14); -x_433 = lean_array_push(x_428, x_432); -if (lean_is_scalar(x_431)) { - x_434 = lean_alloc_ctor(0, 5, 0); +x_452 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_452, 0, x_249); +lean_ctor_set(x_452, 1, x_14); +x_453 = lean_array_push(x_448, x_452); +if (lean_is_scalar(x_451)) { + x_454 = lean_alloc_ctor(0, 5, 0); } else { - x_434 = x_431; + x_454 = x_451; } -lean_ctor_set(x_434, 0, x_426); -lean_ctor_set(x_434, 1, x_427); -lean_ctor_set(x_434, 2, x_433); -lean_ctor_set(x_434, 3, x_429); -lean_ctor_set(x_434, 4, x_430); -x_435 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_Basic_6__lambdaTelescopeAux___main___spec__1___rarg(x_1, x_2, x_3, x_4, x_5, x_241, x_434, x_425); -if (lean_obj_tag(x_435) == 0) +lean_ctor_set(x_454, 0, x_446); +lean_ctor_set(x_454, 1, x_447); +lean_ctor_set(x_454, 2, x_453); +lean_ctor_set(x_454, 3, x_449); +lean_ctor_set(x_454, 4, x_450); +x_455 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_Basic_6__lambdaTelescopeAux___main___spec__1___rarg(x_1, x_2, x_3, x_4, x_5, x_251, x_454, x_445); +if (lean_obj_tag(x_455) == 0) { -lean_object* x_436; lean_object* x_437; lean_object* x_438; -x_436 = lean_ctor_get(x_435, 0); -lean_inc(x_436); -x_437 = lean_ctor_get(x_435, 1); -lean_inc(x_437); -lean_dec(x_435); -x_438 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_438, 0, x_436); -x_390 = x_438; -x_391 = x_437; -goto block_422; +lean_object* x_456; lean_object* x_457; lean_object* x_458; +x_456 = lean_ctor_get(x_455, 0); +lean_inc(x_456); +x_457 = lean_ctor_get(x_455, 1); +lean_inc(x_457); +lean_dec(x_455); +x_458 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_458, 0, x_456); +x_408 = x_458; +x_409 = x_457; +goto block_442; } else { -lean_object* x_439; lean_object* x_440; lean_object* x_441; -x_439 = lean_ctor_get(x_435, 0); -lean_inc(x_439); -x_440 = lean_ctor_get(x_435, 1); -lean_inc(x_440); -lean_dec(x_435); -x_441 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_441, 0, x_439); -x_390 = x_441; -x_391 = x_440; -goto block_422; +lean_object* x_459; lean_object* x_460; lean_object* x_461; +x_459 = lean_ctor_get(x_455, 0); +lean_inc(x_459); +x_460 = lean_ctor_get(x_455, 1); +lean_inc(x_460); +lean_dec(x_455); +x_461 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_461, 0, x_459); +x_408 = x_461; +x_409 = x_460; +goto block_442; } -block_422: +block_442: { -if (lean_obj_tag(x_390) == 0) +if (lean_obj_tag(x_408) == 0) { -lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; lean_object* x_400; lean_object* x_401; lean_object* x_402; lean_object* x_403; lean_object* x_404; lean_object* x_405; lean_object* x_406; -x_392 = lean_ctor_get(x_391, 2); -lean_inc(x_392); -x_393 = lean_ctor_get(x_390, 0); -lean_inc(x_393); -lean_dec(x_390); -x_394 = lean_ctor_get(x_391, 0); -lean_inc(x_394); -x_395 = lean_ctor_get(x_391, 1); -lean_inc(x_395); -x_396 = lean_ctor_get(x_391, 3); -lean_inc(x_396); -x_397 = lean_ctor_get(x_391, 4); -lean_inc(x_397); -x_398 = lean_ctor_get(x_391, 5); -lean_inc(x_398); -if (lean_is_exclusive(x_391)) { - lean_ctor_release(x_391, 0); - lean_ctor_release(x_391, 1); - lean_ctor_release(x_391, 2); - lean_ctor_release(x_391, 3); - lean_ctor_release(x_391, 4); - lean_ctor_release(x_391, 5); - x_399 = x_391; -} else { - lean_dec_ref(x_391); - x_399 = lean_box(0); -} -x_400 = lean_ctor_get(x_392, 0); -lean_inc(x_400); -x_401 = lean_ctor_get(x_392, 1); -lean_inc(x_401); -x_402 = lean_ctor_get(x_392, 3); -lean_inc(x_402); -if (lean_is_exclusive(x_392)) { - lean_ctor_release(x_392, 0); - lean_ctor_release(x_392, 1); - lean_ctor_release(x_392, 2); - lean_ctor_release(x_392, 3); - x_403 = x_392; -} else { - lean_dec_ref(x_392); - x_403 = lean_box(0); -} -if (lean_is_scalar(x_403)) { - x_404 = lean_alloc_ctor(0, 4, 0); -} else { - x_404 = x_403; -} -lean_ctor_set(x_404, 0, x_400); -lean_ctor_set(x_404, 1, x_401); -lean_ctor_set(x_404, 2, x_387); -lean_ctor_set(x_404, 3, x_402); -if (lean_is_scalar(x_399)) { - x_405 = lean_alloc_ctor(0, 6, 0); -} else { - x_405 = x_399; -} -lean_ctor_set(x_405, 0, x_394); -lean_ctor_set(x_405, 1, x_395); -lean_ctor_set(x_405, 2, x_404); -lean_ctor_set(x_405, 3, x_396); -lean_ctor_set(x_405, 4, x_397); -lean_ctor_set(x_405, 5, x_398); -if (lean_is_scalar(x_238)) { - x_406 = lean_alloc_ctor(1, 2, 0); -} else { - x_406 = x_238; - lean_ctor_set_tag(x_406, 1); -} -lean_ctor_set(x_406, 0, x_393); -lean_ctor_set(x_406, 1, x_405); -return x_406; -} -else -{ -lean_object* x_407; lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_object* x_412; lean_object* x_413; lean_object* x_414; lean_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; -x_407 = lean_ctor_get(x_391, 2); -lean_inc(x_407); -x_408 = lean_ctor_get(x_390, 0); -lean_inc(x_408); -lean_dec(x_390); -x_409 = lean_ctor_get(x_391, 0); -lean_inc(x_409); -x_410 = lean_ctor_get(x_391, 1); +lean_object* x_410; 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_410 = lean_ctor_get(x_409, 2); lean_inc(x_410); -x_411 = lean_ctor_get(x_391, 3); +x_411 = lean_ctor_get(x_408, 0); lean_inc(x_411); -x_412 = lean_ctor_get(x_391, 4); +lean_dec(x_408); +x_412 = lean_ctor_get(x_409, 0); lean_inc(x_412); -x_413 = lean_ctor_get(x_391, 5); +x_413 = lean_ctor_get(x_409, 1); lean_inc(x_413); -if (lean_is_exclusive(x_391)) { - lean_ctor_release(x_391, 0); - lean_ctor_release(x_391, 1); - lean_ctor_release(x_391, 2); - lean_ctor_release(x_391, 3); - lean_ctor_release(x_391, 4); - lean_ctor_release(x_391, 5); - x_414 = x_391; -} else { - lean_dec_ref(x_391); - x_414 = lean_box(0); -} -x_415 = lean_ctor_get(x_407, 0); +x_414 = lean_ctor_get(x_409, 3); +lean_inc(x_414); +x_415 = lean_ctor_get(x_409, 4); lean_inc(x_415); -x_416 = lean_ctor_get(x_407, 1); +x_416 = lean_ctor_get(x_409, 5); lean_inc(x_416); -x_417 = lean_ctor_get(x_407, 3); -lean_inc(x_417); -if (lean_is_exclusive(x_407)) { - lean_ctor_release(x_407, 0); - lean_ctor_release(x_407, 1); - lean_ctor_release(x_407, 2); - lean_ctor_release(x_407, 3); - x_418 = x_407; +if (lean_is_exclusive(x_409)) { + lean_ctor_release(x_409, 0); + lean_ctor_release(x_409, 1); + lean_ctor_release(x_409, 2); + lean_ctor_release(x_409, 3); + lean_ctor_release(x_409, 4); + lean_ctor_release(x_409, 5); + x_417 = x_409; } else { - lean_dec_ref(x_407); - x_418 = lean_box(0); + lean_dec_ref(x_409); + x_417 = lean_box(0); } -if (lean_is_scalar(x_418)) { - x_419 = lean_alloc_ctor(0, 4, 0); +x_418 = lean_ctor_get(x_410, 0); +lean_inc(x_418); +x_419 = lean_ctor_get(x_410, 1); +lean_inc(x_419); +x_420 = lean_ctor_get(x_410, 3); +lean_inc(x_420); +x_421 = lean_ctor_get(x_410, 4); +lean_inc(x_421); +if (lean_is_exclusive(x_410)) { + lean_ctor_release(x_410, 0); + lean_ctor_release(x_410, 1); + lean_ctor_release(x_410, 2); + lean_ctor_release(x_410, 3); + lean_ctor_release(x_410, 4); + x_422 = x_410; } else { - x_419 = x_418; + lean_dec_ref(x_410); + x_422 = lean_box(0); } -lean_ctor_set(x_419, 0, x_415); -lean_ctor_set(x_419, 1, x_416); -lean_ctor_set(x_419, 2, x_387); -lean_ctor_set(x_419, 3, x_417); -if (lean_is_scalar(x_414)) { - x_420 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_422)) { + x_423 = lean_alloc_ctor(0, 5, 0); } else { - x_420 = x_414; + x_423 = x_422; } -lean_ctor_set(x_420, 0, x_409); -lean_ctor_set(x_420, 1, x_410); -lean_ctor_set(x_420, 2, x_419); -lean_ctor_set(x_420, 3, x_411); -lean_ctor_set(x_420, 4, x_412); -lean_ctor_set(x_420, 5, x_413); -if (lean_is_scalar(x_238)) { - x_421 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_423, 0, x_418); +lean_ctor_set(x_423, 1, x_419); +lean_ctor_set(x_423, 2, x_404); +lean_ctor_set(x_423, 3, x_420); +lean_ctor_set(x_423, 4, x_421); +if (lean_is_scalar(x_417)) { + x_424 = lean_alloc_ctor(0, 6, 0); } else { - x_421 = x_238; + x_424 = x_417; } -lean_ctor_set(x_421, 0, x_408); -lean_ctor_set(x_421, 1, x_420); -return x_421; +lean_ctor_set(x_424, 0, x_412); +lean_ctor_set(x_424, 1, x_413); +lean_ctor_set(x_424, 2, x_423); +lean_ctor_set(x_424, 3, x_414); +lean_ctor_set(x_424, 4, x_415); +lean_ctor_set(x_424, 5, x_416); +if (lean_is_scalar(x_248)) { + x_425 = lean_alloc_ctor(1, 2, 0); +} else { + x_425 = x_248; + lean_ctor_set_tag(x_425, 1); +} +lean_ctor_set(x_425, 0, x_411); +lean_ctor_set(x_425, 1, x_424); +return x_425; +} +else +{ +lean_object* x_426; lean_object* x_427; 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; +x_426 = lean_ctor_get(x_409, 2); +lean_inc(x_426); +x_427 = lean_ctor_get(x_408, 0); +lean_inc(x_427); +lean_dec(x_408); +x_428 = lean_ctor_get(x_409, 0); +lean_inc(x_428); +x_429 = lean_ctor_get(x_409, 1); +lean_inc(x_429); +x_430 = lean_ctor_get(x_409, 3); +lean_inc(x_430); +x_431 = lean_ctor_get(x_409, 4); +lean_inc(x_431); +x_432 = lean_ctor_get(x_409, 5); +lean_inc(x_432); +if (lean_is_exclusive(x_409)) { + lean_ctor_release(x_409, 0); + lean_ctor_release(x_409, 1); + lean_ctor_release(x_409, 2); + lean_ctor_release(x_409, 3); + lean_ctor_release(x_409, 4); + lean_ctor_release(x_409, 5); + x_433 = x_409; +} else { + lean_dec_ref(x_409); + x_433 = lean_box(0); +} +x_434 = lean_ctor_get(x_426, 0); +lean_inc(x_434); +x_435 = lean_ctor_get(x_426, 1); +lean_inc(x_435); +x_436 = lean_ctor_get(x_426, 3); +lean_inc(x_436); +x_437 = lean_ctor_get(x_426, 4); +lean_inc(x_437); +if (lean_is_exclusive(x_426)) { + lean_ctor_release(x_426, 0); + lean_ctor_release(x_426, 1); + lean_ctor_release(x_426, 2); + lean_ctor_release(x_426, 3); + lean_ctor_release(x_426, 4); + x_438 = x_426; +} else { + lean_dec_ref(x_426); + x_438 = lean_box(0); +} +if (lean_is_scalar(x_438)) { + x_439 = lean_alloc_ctor(0, 5, 0); +} else { + x_439 = x_438; +} +lean_ctor_set(x_439, 0, x_434); +lean_ctor_set(x_439, 1, x_435); +lean_ctor_set(x_439, 2, x_404); +lean_ctor_set(x_439, 3, x_436); +lean_ctor_set(x_439, 4, x_437); +if (lean_is_scalar(x_433)) { + x_440 = lean_alloc_ctor(0, 6, 0); +} else { + x_440 = x_433; +} +lean_ctor_set(x_440, 0, x_428); +lean_ctor_set(x_440, 1, x_429); +lean_ctor_set(x_440, 2, x_439); +lean_ctor_set(x_440, 3, x_430); +lean_ctor_set(x_440, 4, x_431); +lean_ctor_set(x_440, 5, x_432); +if (lean_is_scalar(x_248)) { + x_441 = lean_alloc_ctor(0, 2, 0); +} else { + x_441 = x_248; +} +lean_ctor_set(x_441, 0, x_427); +lean_ctor_set(x_441, 1, x_440); +return x_441; } } } @@ -37868,29 +39084,29 @@ return x_421; } else { -uint8_t x_442; +uint8_t x_462; lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_442 = !lean_is_exclusive(x_231); -if (x_442 == 0) +x_462 = !lean_is_exclusive(x_241); +if (x_462 == 0) { -return x_231; +return x_241; } else { -lean_object* x_443; lean_object* x_444; lean_object* x_445; -x_443 = lean_ctor_get(x_231, 0); -x_444 = lean_ctor_get(x_231, 1); -lean_inc(x_444); -lean_inc(x_443); -lean_dec(x_231); -x_445 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_445, 0, x_443); -lean_ctor_set(x_445, 1, x_444); -return x_445; +lean_object* x_463; lean_object* x_464; lean_object* x_465; +x_463 = lean_ctor_get(x_241, 0); +x_464 = lean_ctor_get(x_241, 1); +lean_inc(x_464); +lean_inc(x_463); +lean_dec(x_241); +x_465 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_465, 0, x_463); +lean_ctor_set(x_465, 1, x_464); +return x_465; } } } @@ -37898,58 +39114,58 @@ return x_445; } else { -uint8_t x_446; +uint8_t x_466; lean_dec(x_18); lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_446 = !lean_is_exclusive(x_19); -if (x_446 == 0) +x_466 = !lean_is_exclusive(x_19); +if (x_466 == 0) { return x_19; } else { -lean_object* x_447; lean_object* x_448; lean_object* x_449; -x_447 = lean_ctor_get(x_19, 0); -x_448 = lean_ctor_get(x_19, 1); -lean_inc(x_448); -lean_inc(x_447); +lean_object* x_467; lean_object* x_468; lean_object* x_469; +x_467 = lean_ctor_get(x_19, 0); +x_468 = lean_ctor_get(x_19, 1); +lean_inc(x_468); +lean_inc(x_467); lean_dec(x_19); -x_449 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_449, 0, x_447); -lean_ctor_set(x_449, 1, x_448); -return x_449; +x_469 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_469, 0, x_467); +lean_ctor_set(x_469, 1, x_468); +return x_469; } } } else { -uint8_t x_450; +uint8_t x_470; lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); lean_dec(x_1); -x_450 = !lean_is_exclusive(x_15); -if (x_450 == 0) +x_470 = !lean_is_exclusive(x_15); +if (x_470 == 0) { return x_15; } else { -lean_object* x_451; lean_object* x_452; lean_object* x_453; -x_451 = lean_ctor_get(x_15, 0); -x_452 = lean_ctor_get(x_15, 1); -lean_inc(x_452); -lean_inc(x_451); +lean_object* x_471; lean_object* x_472; lean_object* x_473; +x_471 = lean_ctor_get(x_15, 0); +x_472 = lean_ctor_get(x_15, 1); +lean_inc(x_472); +lean_inc(x_471); lean_dec(x_15); -x_453 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_453, 0, x_451); -lean_ctor_set(x_453, 1, x_452); -return x_453; +x_473 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_473, 0, x_471); +lean_ctor_set(x_473, 1, x_472); +return x_473; } } } @@ -39359,107 +40575,107 @@ lean_dec(x_15); x_16 = !lean_is_exclusive(x_12); if (x_16 == 0) { -lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_69; uint8_t x_70; +lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_73; uint8_t x_74; x_17 = lean_ctor_get(x_12, 2); -x_69 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_12, 2, x_69); -x_70 = !lean_is_exclusive(x_4); -if (x_70 == 0) +x_73 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_12, 2, x_73); +x_74 = !lean_is_exclusive(x_4); +if (x_74 == 0) { -lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; -x_71 = lean_ctor_get(x_4, 2); +lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; +x_75 = lean_ctor_get(x_4, 2); lean_inc(x_1); -x_72 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_72, 0, x_13); -lean_ctor_set(x_72, 1, x_1); -x_73 = lean_array_push(x_71, x_72); -lean_ctor_set(x_4, 2, x_73); -x_74 = lean_apply_3(x_3, x_1, x_4, x_10); -if (lean_obj_tag(x_74) == 0) +x_76 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_76, 0, x_13); +lean_ctor_set(x_76, 1, x_1); +x_77 = lean_array_push(x_75, x_76); +lean_ctor_set(x_4, 2, x_77); +x_78 = lean_apply_3(x_3, x_1, x_4, x_10); +if (lean_obj_tag(x_78) == 0) { -lean_object* x_75; lean_object* x_76; lean_object* x_77; -x_75 = lean_ctor_get(x_74, 0); -lean_inc(x_75); -x_76 = lean_ctor_get(x_74, 1); -lean_inc(x_76); -lean_dec(x_74); -x_77 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_77, 0, x_75); -x_18 = x_77; -x_19 = x_76; -goto block_68; -} -else -{ -lean_object* x_78; lean_object* x_79; lean_object* x_80; -x_78 = lean_ctor_get(x_74, 0); -lean_inc(x_78); -x_79 = lean_ctor_get(x_74, 1); +lean_object* x_79; lean_object* x_80; lean_object* x_81; +x_79 = lean_ctor_get(x_78, 0); lean_inc(x_79); -lean_dec(x_74); -x_80 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_80, 0, x_78); -x_18 = x_80; -x_19 = x_79; -goto block_68; +x_80 = lean_ctor_get(x_78, 1); +lean_inc(x_80); +lean_dec(x_78); +x_81 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_81, 0, x_79); +x_18 = x_81; +x_19 = x_80; +goto block_72; +} +else +{ +lean_object* x_82; lean_object* x_83; lean_object* x_84; +x_82 = lean_ctor_get(x_78, 0); +lean_inc(x_82); +x_83 = lean_ctor_get(x_78, 1); +lean_inc(x_83); +lean_dec(x_78); +x_84 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_84, 0, x_82); +x_18 = x_84; +x_19 = x_83; +goto block_72; } } else { -lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; -x_81 = lean_ctor_get(x_4, 0); -x_82 = lean_ctor_get(x_4, 1); -x_83 = lean_ctor_get(x_4, 2); -x_84 = lean_ctor_get(x_4, 3); -x_85 = lean_ctor_get(x_4, 4); +lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; +x_85 = lean_ctor_get(x_4, 0); +x_86 = lean_ctor_get(x_4, 1); +x_87 = lean_ctor_get(x_4, 2); +x_88 = lean_ctor_get(x_4, 3); +x_89 = lean_ctor_get(x_4, 4); +lean_inc(x_89); +lean_inc(x_88); +lean_inc(x_87); +lean_inc(x_86); lean_inc(x_85); -lean_inc(x_84); -lean_inc(x_83); -lean_inc(x_82); -lean_inc(x_81); lean_dec(x_4); lean_inc(x_1); -x_86 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_86, 0, x_13); -lean_ctor_set(x_86, 1, x_1); -x_87 = lean_array_push(x_83, x_86); -x_88 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_88, 0, x_81); -lean_ctor_set(x_88, 1, x_82); -lean_ctor_set(x_88, 2, x_87); -lean_ctor_set(x_88, 3, x_84); -lean_ctor_set(x_88, 4, x_85); -x_89 = lean_apply_3(x_3, x_1, x_88, x_10); -if (lean_obj_tag(x_89) == 0) +x_90 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_90, 0, x_13); +lean_ctor_set(x_90, 1, x_1); +x_91 = lean_array_push(x_87, x_90); +x_92 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_92, 0, x_85); +lean_ctor_set(x_92, 1, x_86); +lean_ctor_set(x_92, 2, x_91); +lean_ctor_set(x_92, 3, x_88); +lean_ctor_set(x_92, 4, x_89); +x_93 = lean_apply_3(x_3, x_1, x_92, x_10); +if (lean_obj_tag(x_93) == 0) { -lean_object* x_90; lean_object* x_91; lean_object* x_92; -x_90 = lean_ctor_get(x_89, 0); -lean_inc(x_90); -x_91 = lean_ctor_get(x_89, 1); -lean_inc(x_91); -lean_dec(x_89); -x_92 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_92, 0, x_90); -x_18 = x_92; -x_19 = x_91; -goto block_68; +lean_object* x_94; lean_object* x_95; lean_object* x_96; +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_alloc_ctor(1, 1, 0); +lean_ctor_set(x_96, 0, x_94); +x_18 = x_96; +x_19 = x_95; +goto block_72; } else { -lean_object* x_93; lean_object* x_94; lean_object* x_95; -x_93 = lean_ctor_get(x_89, 0); -lean_inc(x_93); -x_94 = lean_ctor_get(x_89, 1); -lean_inc(x_94); -lean_dec(x_89); -x_95 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_95, 0, x_93); -x_18 = x_95; -x_19 = x_94; -goto block_68; +lean_object* x_97; lean_object* x_98; lean_object* x_99; +x_97 = lean_ctor_get(x_93, 0); +lean_inc(x_97); +x_98 = lean_ctor_get(x_93, 1); +lean_inc(x_98); +lean_dec(x_93); +x_99 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_99, 0, x_97); +x_18 = x_99; +x_19 = x_98; +goto block_72; } } -block_68: +block_72: { if (lean_obj_tag(x_18) == 0) { @@ -39494,708 +40710,745 @@ return x_26; } else { -lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; +lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; x_27 = lean_ctor_get(x_20, 0); x_28 = lean_ctor_get(x_20, 1); x_29 = lean_ctor_get(x_20, 3); +x_30 = lean_ctor_get(x_20, 4); +lean_inc(x_30); lean_inc(x_29); lean_inc(x_28); lean_inc(x_27); lean_dec(x_20); -x_30 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_30, 0, x_27); -lean_ctor_set(x_30, 1, x_28); -lean_ctor_set(x_30, 2, x_17); -lean_ctor_set(x_30, 3, x_29); -lean_ctor_set(x_19, 2, x_30); +x_31 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_31, 0, x_27); +lean_ctor_set(x_31, 1, x_28); +lean_ctor_set(x_31, 2, x_17); +lean_ctor_set(x_31, 3, x_29); +lean_ctor_set(x_31, 4, x_30); +lean_ctor_set(x_19, 2, x_31); if (lean_is_scalar(x_11)) { - x_31 = lean_alloc_ctor(1, 2, 0); + x_32 = lean_alloc_ctor(1, 2, 0); } else { - x_31 = x_11; - lean_ctor_set_tag(x_31, 1); + x_32 = x_11; + lean_ctor_set_tag(x_32, 1); } -lean_ctor_set(x_31, 0, x_21); -lean_ctor_set(x_31, 1, x_19); -return x_31; +lean_ctor_set(x_32, 0, x_21); +lean_ctor_set(x_32, 1, x_19); +return x_32; } } else { -lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; -x_32 = lean_ctor_get(x_19, 0); -x_33 = lean_ctor_get(x_19, 1); -x_34 = lean_ctor_get(x_19, 3); -x_35 = lean_ctor_get(x_19, 4); -x_36 = lean_ctor_get(x_19, 5); +lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; +x_33 = lean_ctor_get(x_19, 0); +x_34 = lean_ctor_get(x_19, 1); +x_35 = lean_ctor_get(x_19, 3); +x_36 = lean_ctor_get(x_19, 4); +x_37 = lean_ctor_get(x_19, 5); +lean_inc(x_37); lean_inc(x_36); lean_inc(x_35); lean_inc(x_34); lean_inc(x_33); -lean_inc(x_32); lean_dec(x_19); -x_37 = lean_ctor_get(x_20, 0); -lean_inc(x_37); -x_38 = lean_ctor_get(x_20, 1); +x_38 = lean_ctor_get(x_20, 0); lean_inc(x_38); -x_39 = lean_ctor_get(x_20, 3); +x_39 = lean_ctor_get(x_20, 1); lean_inc(x_39); +x_40 = lean_ctor_get(x_20, 3); +lean_inc(x_40); +x_41 = lean_ctor_get(x_20, 4); +lean_inc(x_41); if (lean_is_exclusive(x_20)) { lean_ctor_release(x_20, 0); lean_ctor_release(x_20, 1); lean_ctor_release(x_20, 2); lean_ctor_release(x_20, 3); - x_40 = x_20; + lean_ctor_release(x_20, 4); + x_42 = x_20; } else { lean_dec_ref(x_20); - x_40 = lean_box(0); + x_42 = lean_box(0); } -if (lean_is_scalar(x_40)) { - x_41 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_42)) { + x_43 = lean_alloc_ctor(0, 5, 0); } else { - x_41 = x_40; + x_43 = x_42; } -lean_ctor_set(x_41, 0, x_37); -lean_ctor_set(x_41, 1, x_38); -lean_ctor_set(x_41, 2, x_17); -lean_ctor_set(x_41, 3, x_39); -x_42 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_42, 0, x_32); -lean_ctor_set(x_42, 1, x_33); -lean_ctor_set(x_42, 2, x_41); -lean_ctor_set(x_42, 3, x_34); -lean_ctor_set(x_42, 4, x_35); -lean_ctor_set(x_42, 5, x_36); +lean_ctor_set(x_43, 0, x_38); +lean_ctor_set(x_43, 1, x_39); +lean_ctor_set(x_43, 2, x_17); +lean_ctor_set(x_43, 3, x_40); +lean_ctor_set(x_43, 4, x_41); +x_44 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_44, 0, x_33); +lean_ctor_set(x_44, 1, x_34); +lean_ctor_set(x_44, 2, x_43); +lean_ctor_set(x_44, 3, x_35); +lean_ctor_set(x_44, 4, x_36); +lean_ctor_set(x_44, 5, x_37); if (lean_is_scalar(x_11)) { - x_43 = lean_alloc_ctor(1, 2, 0); + x_45 = lean_alloc_ctor(1, 2, 0); } else { - x_43 = x_11; - lean_ctor_set_tag(x_43, 1); + x_45 = x_11; + lean_ctor_set_tag(x_45, 1); } -lean_ctor_set(x_43, 0, x_21); -lean_ctor_set(x_43, 1, x_42); -return x_43; +lean_ctor_set(x_45, 0, x_21); +lean_ctor_set(x_45, 1, x_44); +return x_45; } } else { -lean_object* x_44; lean_object* x_45; uint8_t x_46; -x_44 = lean_ctor_get(x_19, 2); -lean_inc(x_44); -x_45 = lean_ctor_get(x_18, 0); -lean_inc(x_45); +lean_object* x_46; lean_object* x_47; uint8_t x_48; +x_46 = lean_ctor_get(x_19, 2); +lean_inc(x_46); +x_47 = lean_ctor_get(x_18, 0); +lean_inc(x_47); lean_dec(x_18); -x_46 = !lean_is_exclusive(x_19); -if (x_46 == 0) -{ -lean_object* x_47; uint8_t x_48; -x_47 = lean_ctor_get(x_19, 2); -lean_dec(x_47); -x_48 = !lean_is_exclusive(x_44); +x_48 = !lean_is_exclusive(x_19); if (x_48 == 0) { -lean_object* x_49; lean_object* x_50; -x_49 = lean_ctor_get(x_44, 2); +lean_object* x_49; uint8_t x_50; +x_49 = lean_ctor_get(x_19, 2); lean_dec(x_49); -lean_ctor_set(x_44, 2, x_17); +x_50 = !lean_is_exclusive(x_46); +if (x_50 == 0) +{ +lean_object* x_51; lean_object* x_52; +x_51 = lean_ctor_get(x_46, 2); +lean_dec(x_51); +lean_ctor_set(x_46, 2, x_17); if (lean_is_scalar(x_11)) { - x_50 = lean_alloc_ctor(0, 2, 0); + x_52 = lean_alloc_ctor(0, 2, 0); } else { - x_50 = x_11; + x_52 = x_11; } -lean_ctor_set(x_50, 0, x_45); -lean_ctor_set(x_50, 1, x_19); -return x_50; +lean_ctor_set(x_52, 0, x_47); +lean_ctor_set(x_52, 1, x_19); +return x_52; } else { -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_44, 0); -x_52 = lean_ctor_get(x_44, 1); -x_53 = lean_ctor_get(x_44, 3); +lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; +x_53 = lean_ctor_get(x_46, 0); +x_54 = lean_ctor_get(x_46, 1); +x_55 = lean_ctor_get(x_46, 3); +x_56 = lean_ctor_get(x_46, 4); +lean_inc(x_56); +lean_inc(x_55); +lean_inc(x_54); lean_inc(x_53); -lean_inc(x_52); -lean_inc(x_51); -lean_dec(x_44); -x_54 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_54, 0, x_51); -lean_ctor_set(x_54, 1, x_52); -lean_ctor_set(x_54, 2, x_17); -lean_ctor_set(x_54, 3, x_53); -lean_ctor_set(x_19, 2, x_54); +lean_dec(x_46); +x_57 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_57, 0, x_53); +lean_ctor_set(x_57, 1, x_54); +lean_ctor_set(x_57, 2, x_17); +lean_ctor_set(x_57, 3, x_55); +lean_ctor_set(x_57, 4, x_56); +lean_ctor_set(x_19, 2, x_57); if (lean_is_scalar(x_11)) { - x_55 = lean_alloc_ctor(0, 2, 0); + x_58 = lean_alloc_ctor(0, 2, 0); } else { - x_55 = x_11; + x_58 = x_11; } -lean_ctor_set(x_55, 0, x_45); -lean_ctor_set(x_55, 1, x_19); -return x_55; +lean_ctor_set(x_58, 0, x_47); +lean_ctor_set(x_58, 1, x_19); +return x_58; } } else { -lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; -x_56 = lean_ctor_get(x_19, 0); -x_57 = lean_ctor_get(x_19, 1); -x_58 = lean_ctor_get(x_19, 3); -x_59 = lean_ctor_get(x_19, 4); -x_60 = lean_ctor_get(x_19, 5); +lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; +x_59 = lean_ctor_get(x_19, 0); +x_60 = lean_ctor_get(x_19, 1); +x_61 = lean_ctor_get(x_19, 3); +x_62 = lean_ctor_get(x_19, 4); +x_63 = lean_ctor_get(x_19, 5); +lean_inc(x_63); +lean_inc(x_62); +lean_inc(x_61); lean_inc(x_60); lean_inc(x_59); -lean_inc(x_58); -lean_inc(x_57); -lean_inc(x_56); lean_dec(x_19); -x_61 = lean_ctor_get(x_44, 0); -lean_inc(x_61); -x_62 = lean_ctor_get(x_44, 1); -lean_inc(x_62); -x_63 = lean_ctor_get(x_44, 3); -lean_inc(x_63); -if (lean_is_exclusive(x_44)) { - lean_ctor_release(x_44, 0); - lean_ctor_release(x_44, 1); - lean_ctor_release(x_44, 2); - lean_ctor_release(x_44, 3); - x_64 = x_44; +x_64 = lean_ctor_get(x_46, 0); +lean_inc(x_64); +x_65 = lean_ctor_get(x_46, 1); +lean_inc(x_65); +x_66 = lean_ctor_get(x_46, 3); +lean_inc(x_66); +x_67 = lean_ctor_get(x_46, 4); +lean_inc(x_67); +if (lean_is_exclusive(x_46)) { + lean_ctor_release(x_46, 0); + lean_ctor_release(x_46, 1); + lean_ctor_release(x_46, 2); + lean_ctor_release(x_46, 3); + lean_ctor_release(x_46, 4); + x_68 = x_46; } else { - lean_dec_ref(x_44); - x_64 = lean_box(0); + lean_dec_ref(x_46); + x_68 = lean_box(0); } -if (lean_is_scalar(x_64)) { - x_65 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_68)) { + x_69 = lean_alloc_ctor(0, 5, 0); } else { - x_65 = x_64; + x_69 = x_68; } -lean_ctor_set(x_65, 0, x_61); -lean_ctor_set(x_65, 1, x_62); -lean_ctor_set(x_65, 2, x_17); -lean_ctor_set(x_65, 3, x_63); -x_66 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_66, 0, x_56); -lean_ctor_set(x_66, 1, x_57); -lean_ctor_set(x_66, 2, x_65); -lean_ctor_set(x_66, 3, x_58); -lean_ctor_set(x_66, 4, x_59); -lean_ctor_set(x_66, 5, x_60); +lean_ctor_set(x_69, 0, x_64); +lean_ctor_set(x_69, 1, x_65); +lean_ctor_set(x_69, 2, x_17); +lean_ctor_set(x_69, 3, x_66); +lean_ctor_set(x_69, 4, x_67); +x_70 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_70, 0, x_59); +lean_ctor_set(x_70, 1, x_60); +lean_ctor_set(x_70, 2, x_69); +lean_ctor_set(x_70, 3, x_61); +lean_ctor_set(x_70, 4, x_62); +lean_ctor_set(x_70, 5, x_63); if (lean_is_scalar(x_11)) { - x_67 = lean_alloc_ctor(0, 2, 0); + x_71 = lean_alloc_ctor(0, 2, 0); } else { - x_67 = x_11; + x_71 = x_11; } -lean_ctor_set(x_67, 0, x_45); -lean_ctor_set(x_67, 1, x_66); -return x_67; +lean_ctor_set(x_71, 0, x_47); +lean_ctor_set(x_71, 1, x_70); +return x_71; } } } } else { -lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_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; -x_96 = lean_ctor_get(x_12, 0); -x_97 = lean_ctor_get(x_12, 1); -x_98 = lean_ctor_get(x_12, 2); -x_99 = lean_ctor_get(x_12, 3); -lean_inc(x_99); -lean_inc(x_98); -lean_inc(x_97); -lean_inc(x_96); +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_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; +x_100 = lean_ctor_get(x_12, 0); +x_101 = lean_ctor_get(x_12, 1); +x_102 = lean_ctor_get(x_12, 2); +x_103 = lean_ctor_get(x_12, 3); +x_104 = lean_ctor_get(x_12, 4); +lean_inc(x_104); +lean_inc(x_103); +lean_inc(x_102); +lean_inc(x_101); +lean_inc(x_100); lean_dec(x_12); -x_133 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_134 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_134, 0, x_96); -lean_ctor_set(x_134, 1, x_97); -lean_ctor_set(x_134, 2, x_133); -lean_ctor_set(x_134, 3, x_99); -lean_ctor_set(x_10, 2, x_134); -x_135 = lean_ctor_get(x_4, 0); -lean_inc(x_135); -x_136 = lean_ctor_get(x_4, 1); -lean_inc(x_136); -x_137 = lean_ctor_get(x_4, 2); -lean_inc(x_137); -x_138 = lean_ctor_get(x_4, 3); -lean_inc(x_138); -x_139 = lean_ctor_get(x_4, 4); -lean_inc(x_139); +x_140 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_141 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_141, 0, x_100); +lean_ctor_set(x_141, 1, x_101); +lean_ctor_set(x_141, 2, x_140); +lean_ctor_set(x_141, 3, x_103); +lean_ctor_set(x_141, 4, x_104); +lean_ctor_set(x_10, 2, x_141); +x_142 = lean_ctor_get(x_4, 0); +lean_inc(x_142); +x_143 = lean_ctor_get(x_4, 1); +lean_inc(x_143); +x_144 = lean_ctor_get(x_4, 2); +lean_inc(x_144); +x_145 = lean_ctor_get(x_4, 3); +lean_inc(x_145); +x_146 = lean_ctor_get(x_4, 4); +lean_inc(x_146); if (lean_is_exclusive(x_4)) { lean_ctor_release(x_4, 0); lean_ctor_release(x_4, 1); lean_ctor_release(x_4, 2); lean_ctor_release(x_4, 3); lean_ctor_release(x_4, 4); - x_140 = x_4; + x_147 = x_4; } else { lean_dec_ref(x_4); - x_140 = lean_box(0); + x_147 = lean_box(0); } lean_inc(x_1); -x_141 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_141, 0, x_13); -lean_ctor_set(x_141, 1, x_1); -x_142 = lean_array_push(x_137, x_141); -if (lean_is_scalar(x_140)) { - x_143 = lean_alloc_ctor(0, 5, 0); +x_148 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_148, 0, x_13); +lean_ctor_set(x_148, 1, x_1); +x_149 = lean_array_push(x_144, x_148); +if (lean_is_scalar(x_147)) { + x_150 = lean_alloc_ctor(0, 5, 0); } else { - x_143 = x_140; + x_150 = x_147; } -lean_ctor_set(x_143, 0, x_135); -lean_ctor_set(x_143, 1, x_136); -lean_ctor_set(x_143, 2, x_142); -lean_ctor_set(x_143, 3, x_138); -lean_ctor_set(x_143, 4, x_139); -x_144 = lean_apply_3(x_3, x_1, x_143, x_10); -if (lean_obj_tag(x_144) == 0) +lean_ctor_set(x_150, 0, x_142); +lean_ctor_set(x_150, 1, x_143); +lean_ctor_set(x_150, 2, x_149); +lean_ctor_set(x_150, 3, x_145); +lean_ctor_set(x_150, 4, x_146); +x_151 = lean_apply_3(x_3, x_1, x_150, x_10); +if (lean_obj_tag(x_151) == 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); -x_147 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_147, 0, x_145); -x_100 = x_147; -x_101 = x_146; -goto block_132; -} -else -{ -lean_object* x_148; lean_object* x_149; lean_object* x_150; -x_148 = lean_ctor_get(x_144, 0); -lean_inc(x_148); -x_149 = lean_ctor_get(x_144, 1); -lean_inc(x_149); -lean_dec(x_144); -x_150 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_150, 0, x_148); -x_100 = x_150; -x_101 = x_149; -goto block_132; -} -block_132: -{ -if (lean_obj_tag(x_100) == 0) -{ -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; -x_102 = lean_ctor_get(x_101, 2); -lean_inc(x_102); -x_103 = lean_ctor_get(x_100, 0); -lean_inc(x_103); -lean_dec(x_100); -x_104 = lean_ctor_get(x_101, 0); -lean_inc(x_104); -x_105 = lean_ctor_get(x_101, 1); -lean_inc(x_105); -x_106 = lean_ctor_get(x_101, 3); -lean_inc(x_106); -x_107 = lean_ctor_get(x_101, 4); -lean_inc(x_107); -x_108 = lean_ctor_get(x_101, 5); -lean_inc(x_108); -if (lean_is_exclusive(x_101)) { - lean_ctor_release(x_101, 0); - lean_ctor_release(x_101, 1); - lean_ctor_release(x_101, 2); - lean_ctor_release(x_101, 3); - lean_ctor_release(x_101, 4); - lean_ctor_release(x_101, 5); - x_109 = x_101; -} else { - lean_dec_ref(x_101); - x_109 = lean_box(0); -} -x_110 = lean_ctor_get(x_102, 0); -lean_inc(x_110); -x_111 = lean_ctor_get(x_102, 1); -lean_inc(x_111); -x_112 = lean_ctor_get(x_102, 3); -lean_inc(x_112); -if (lean_is_exclusive(x_102)) { - lean_ctor_release(x_102, 0); - lean_ctor_release(x_102, 1); - lean_ctor_release(x_102, 2); - lean_ctor_release(x_102, 3); - x_113 = x_102; -} else { - lean_dec_ref(x_102); - x_113 = lean_box(0); -} -if (lean_is_scalar(x_113)) { - x_114 = lean_alloc_ctor(0, 4, 0); -} else { - x_114 = x_113; -} -lean_ctor_set(x_114, 0, x_110); -lean_ctor_set(x_114, 1, x_111); -lean_ctor_set(x_114, 2, x_98); -lean_ctor_set(x_114, 3, x_112); -if (lean_is_scalar(x_109)) { - x_115 = lean_alloc_ctor(0, 6, 0); -} else { - x_115 = x_109; -} -lean_ctor_set(x_115, 0, x_104); -lean_ctor_set(x_115, 1, x_105); -lean_ctor_set(x_115, 2, x_114); -lean_ctor_set(x_115, 3, x_106); -lean_ctor_set(x_115, 4, x_107); -lean_ctor_set(x_115, 5, x_108); -if (lean_is_scalar(x_11)) { - x_116 = lean_alloc_ctor(1, 2, 0); -} else { - x_116 = x_11; - lean_ctor_set_tag(x_116, 1); -} -lean_ctor_set(x_116, 0, x_103); -lean_ctor_set(x_116, 1, x_115); -return x_116; -} -else -{ -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; -x_117 = lean_ctor_get(x_101, 2); -lean_inc(x_117); -x_118 = lean_ctor_get(x_100, 0); -lean_inc(x_118); -lean_dec(x_100); -x_119 = lean_ctor_get(x_101, 0); -lean_inc(x_119); -x_120 = lean_ctor_get(x_101, 1); -lean_inc(x_120); -x_121 = lean_ctor_get(x_101, 3); -lean_inc(x_121); -x_122 = lean_ctor_get(x_101, 4); -lean_inc(x_122); -x_123 = lean_ctor_get(x_101, 5); -lean_inc(x_123); -if (lean_is_exclusive(x_101)) { - lean_ctor_release(x_101, 0); - lean_ctor_release(x_101, 1); - lean_ctor_release(x_101, 2); - lean_ctor_release(x_101, 3); - lean_ctor_release(x_101, 4); - lean_ctor_release(x_101, 5); - x_124 = x_101; -} else { - lean_dec_ref(x_101); - x_124 = lean_box(0); -} -x_125 = lean_ctor_get(x_117, 0); -lean_inc(x_125); -x_126 = lean_ctor_get(x_117, 1); -lean_inc(x_126); -x_127 = lean_ctor_get(x_117, 3); -lean_inc(x_127); -if (lean_is_exclusive(x_117)) { - lean_ctor_release(x_117, 0); - lean_ctor_release(x_117, 1); - lean_ctor_release(x_117, 2); - lean_ctor_release(x_117, 3); - x_128 = x_117; -} else { - lean_dec_ref(x_117); - x_128 = lean_box(0); -} -if (lean_is_scalar(x_128)) { - x_129 = lean_alloc_ctor(0, 4, 0); -} else { - x_129 = x_128; -} -lean_ctor_set(x_129, 0, x_125); -lean_ctor_set(x_129, 1, x_126); -lean_ctor_set(x_129, 2, x_98); -lean_ctor_set(x_129, 3, x_127); -if (lean_is_scalar(x_124)) { - x_130 = lean_alloc_ctor(0, 6, 0); -} else { - x_130 = x_124; -} -lean_ctor_set(x_130, 0, x_119); -lean_ctor_set(x_130, 1, x_120); -lean_ctor_set(x_130, 2, x_129); -lean_ctor_set(x_130, 3, x_121); -lean_ctor_set(x_130, 4, x_122); -lean_ctor_set(x_130, 5, x_123); -if (lean_is_scalar(x_11)) { - x_131 = lean_alloc_ctor(0, 2, 0); -} else { - x_131 = x_11; -} -lean_ctor_set(x_131, 0, x_118); -lean_ctor_set(x_131, 1, x_130); -return x_131; -} -} -} -} -else -{ -lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; -x_151 = lean_ctor_get(x_10, 0); -x_152 = lean_ctor_get(x_10, 1); -x_153 = lean_ctor_get(x_10, 3); -x_154 = lean_ctor_get(x_10, 4); -x_155 = lean_ctor_get(x_10, 5); -lean_inc(x_155); -lean_inc(x_154); -lean_inc(x_153); +lean_object* x_152; lean_object* x_153; lean_object* x_154; +x_152 = lean_ctor_get(x_151, 0); lean_inc(x_152); -lean_inc(x_151); -lean_dec(x_10); -x_156 = lean_ctor_get(x_12, 0); +x_153 = lean_ctor_get(x_151, 1); +lean_inc(x_153); +lean_dec(x_151); +x_154 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_154, 0, x_152); +x_105 = x_154; +x_106 = x_153; +goto block_139; +} +else +{ +lean_object* x_155; lean_object* x_156; lean_object* x_157; +x_155 = lean_ctor_get(x_151, 0); +lean_inc(x_155); +x_156 = lean_ctor_get(x_151, 1); lean_inc(x_156); -x_157 = lean_ctor_get(x_12, 1); -lean_inc(x_157); -x_158 = lean_ctor_get(x_12, 2); -lean_inc(x_158); -x_159 = lean_ctor_get(x_12, 3); +lean_dec(x_151); +x_157 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_157, 0, x_155); +x_105 = x_157; +x_106 = x_156; +goto block_139; +} +block_139: +{ +if (lean_obj_tag(x_105) == 0) +{ +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; +x_107 = lean_ctor_get(x_106, 2); +lean_inc(x_107); +x_108 = lean_ctor_get(x_105, 0); +lean_inc(x_108); +lean_dec(x_105); +x_109 = lean_ctor_get(x_106, 0); +lean_inc(x_109); +x_110 = lean_ctor_get(x_106, 1); +lean_inc(x_110); +x_111 = lean_ctor_get(x_106, 3); +lean_inc(x_111); +x_112 = lean_ctor_get(x_106, 4); +lean_inc(x_112); +x_113 = lean_ctor_get(x_106, 5); +lean_inc(x_113); +if (lean_is_exclusive(x_106)) { + lean_ctor_release(x_106, 0); + lean_ctor_release(x_106, 1); + lean_ctor_release(x_106, 2); + lean_ctor_release(x_106, 3); + lean_ctor_release(x_106, 4); + lean_ctor_release(x_106, 5); + x_114 = x_106; +} else { + lean_dec_ref(x_106); + x_114 = lean_box(0); +} +x_115 = lean_ctor_get(x_107, 0); +lean_inc(x_115); +x_116 = lean_ctor_get(x_107, 1); +lean_inc(x_116); +x_117 = lean_ctor_get(x_107, 3); +lean_inc(x_117); +x_118 = lean_ctor_get(x_107, 4); +lean_inc(x_118); +if (lean_is_exclusive(x_107)) { + lean_ctor_release(x_107, 0); + lean_ctor_release(x_107, 1); + lean_ctor_release(x_107, 2); + lean_ctor_release(x_107, 3); + lean_ctor_release(x_107, 4); + x_119 = x_107; +} else { + lean_dec_ref(x_107); + x_119 = lean_box(0); +} +if (lean_is_scalar(x_119)) { + x_120 = lean_alloc_ctor(0, 5, 0); +} else { + x_120 = x_119; +} +lean_ctor_set(x_120, 0, x_115); +lean_ctor_set(x_120, 1, x_116); +lean_ctor_set(x_120, 2, x_102); +lean_ctor_set(x_120, 3, x_117); +lean_ctor_set(x_120, 4, x_118); +if (lean_is_scalar(x_114)) { + x_121 = lean_alloc_ctor(0, 6, 0); +} else { + x_121 = x_114; +} +lean_ctor_set(x_121, 0, x_109); +lean_ctor_set(x_121, 1, x_110); +lean_ctor_set(x_121, 2, x_120); +lean_ctor_set(x_121, 3, x_111); +lean_ctor_set(x_121, 4, x_112); +lean_ctor_set(x_121, 5, x_113); +if (lean_is_scalar(x_11)) { + x_122 = lean_alloc_ctor(1, 2, 0); +} else { + x_122 = x_11; + lean_ctor_set_tag(x_122, 1); +} +lean_ctor_set(x_122, 0, x_108); +lean_ctor_set(x_122, 1, x_121); +return x_122; +} +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; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; +x_123 = lean_ctor_get(x_106, 2); +lean_inc(x_123); +x_124 = lean_ctor_get(x_105, 0); +lean_inc(x_124); +lean_dec(x_105); +x_125 = lean_ctor_get(x_106, 0); +lean_inc(x_125); +x_126 = lean_ctor_get(x_106, 1); +lean_inc(x_126); +x_127 = lean_ctor_get(x_106, 3); +lean_inc(x_127); +x_128 = lean_ctor_get(x_106, 4); +lean_inc(x_128); +x_129 = lean_ctor_get(x_106, 5); +lean_inc(x_129); +if (lean_is_exclusive(x_106)) { + lean_ctor_release(x_106, 0); + lean_ctor_release(x_106, 1); + lean_ctor_release(x_106, 2); + lean_ctor_release(x_106, 3); + lean_ctor_release(x_106, 4); + lean_ctor_release(x_106, 5); + x_130 = x_106; +} else { + lean_dec_ref(x_106); + x_130 = lean_box(0); +} +x_131 = lean_ctor_get(x_123, 0); +lean_inc(x_131); +x_132 = lean_ctor_get(x_123, 1); +lean_inc(x_132); +x_133 = lean_ctor_get(x_123, 3); +lean_inc(x_133); +x_134 = lean_ctor_get(x_123, 4); +lean_inc(x_134); +if (lean_is_exclusive(x_123)) { + lean_ctor_release(x_123, 0); + lean_ctor_release(x_123, 1); + lean_ctor_release(x_123, 2); + lean_ctor_release(x_123, 3); + lean_ctor_release(x_123, 4); + x_135 = x_123; +} else { + lean_dec_ref(x_123); + x_135 = lean_box(0); +} +if (lean_is_scalar(x_135)) { + x_136 = lean_alloc_ctor(0, 5, 0); +} else { + x_136 = x_135; +} +lean_ctor_set(x_136, 0, x_131); +lean_ctor_set(x_136, 1, x_132); +lean_ctor_set(x_136, 2, x_102); +lean_ctor_set(x_136, 3, x_133); +lean_ctor_set(x_136, 4, x_134); +if (lean_is_scalar(x_130)) { + x_137 = lean_alloc_ctor(0, 6, 0); +} else { + x_137 = x_130; +} +lean_ctor_set(x_137, 0, x_125); +lean_ctor_set(x_137, 1, x_126); +lean_ctor_set(x_137, 2, x_136); +lean_ctor_set(x_137, 3, x_127); +lean_ctor_set(x_137, 4, x_128); +lean_ctor_set(x_137, 5, x_129); +if (lean_is_scalar(x_11)) { + x_138 = lean_alloc_ctor(0, 2, 0); +} else { + x_138 = x_11; +} +lean_ctor_set(x_138, 0, x_124); +lean_ctor_set(x_138, 1, x_137); +return x_138; +} +} +} +} +else +{ +lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; +x_158 = lean_ctor_get(x_10, 0); +x_159 = lean_ctor_get(x_10, 1); +x_160 = lean_ctor_get(x_10, 3); +x_161 = lean_ctor_get(x_10, 4); +x_162 = lean_ctor_get(x_10, 5); +lean_inc(x_162); +lean_inc(x_161); +lean_inc(x_160); lean_inc(x_159); +lean_inc(x_158); +lean_dec(x_10); +x_163 = lean_ctor_get(x_12, 0); +lean_inc(x_163); +x_164 = lean_ctor_get(x_12, 1); +lean_inc(x_164); +x_165 = lean_ctor_get(x_12, 2); +lean_inc(x_165); +x_166 = lean_ctor_get(x_12, 3); +lean_inc(x_166); +x_167 = lean_ctor_get(x_12, 4); +lean_inc(x_167); if (lean_is_exclusive(x_12)) { lean_ctor_release(x_12, 0); lean_ctor_release(x_12, 1); lean_ctor_release(x_12, 2); lean_ctor_release(x_12, 3); - x_160 = x_12; + lean_ctor_release(x_12, 4); + x_168 = x_12; } else { lean_dec_ref(x_12); - x_160 = lean_box(0); + x_168 = lean_box(0); } -x_194 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_160)) { - x_195 = lean_alloc_ctor(0, 4, 0); +x_204 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_168)) { + x_205 = lean_alloc_ctor(0, 5, 0); } else { - x_195 = x_160; + x_205 = x_168; } -lean_ctor_set(x_195, 0, x_156); -lean_ctor_set(x_195, 1, x_157); -lean_ctor_set(x_195, 2, x_194); -lean_ctor_set(x_195, 3, x_159); -x_196 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_196, 0, x_151); -lean_ctor_set(x_196, 1, x_152); -lean_ctor_set(x_196, 2, x_195); -lean_ctor_set(x_196, 3, x_153); -lean_ctor_set(x_196, 4, x_154); -lean_ctor_set(x_196, 5, x_155); -x_197 = lean_ctor_get(x_4, 0); -lean_inc(x_197); -x_198 = lean_ctor_get(x_4, 1); -lean_inc(x_198); -x_199 = lean_ctor_get(x_4, 2); -lean_inc(x_199); -x_200 = lean_ctor_get(x_4, 3); -lean_inc(x_200); -x_201 = lean_ctor_get(x_4, 4); -lean_inc(x_201); +lean_ctor_set(x_205, 0, x_163); +lean_ctor_set(x_205, 1, x_164); +lean_ctor_set(x_205, 2, x_204); +lean_ctor_set(x_205, 3, x_166); +lean_ctor_set(x_205, 4, x_167); +x_206 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_206, 0, x_158); +lean_ctor_set(x_206, 1, x_159); +lean_ctor_set(x_206, 2, x_205); +lean_ctor_set(x_206, 3, x_160); +lean_ctor_set(x_206, 4, x_161); +lean_ctor_set(x_206, 5, x_162); +x_207 = lean_ctor_get(x_4, 0); +lean_inc(x_207); +x_208 = lean_ctor_get(x_4, 1); +lean_inc(x_208); +x_209 = lean_ctor_get(x_4, 2); +lean_inc(x_209); +x_210 = lean_ctor_get(x_4, 3); +lean_inc(x_210); +x_211 = lean_ctor_get(x_4, 4); +lean_inc(x_211); if (lean_is_exclusive(x_4)) { lean_ctor_release(x_4, 0); lean_ctor_release(x_4, 1); lean_ctor_release(x_4, 2); lean_ctor_release(x_4, 3); lean_ctor_release(x_4, 4); - x_202 = x_4; + x_212 = x_4; } else { lean_dec_ref(x_4); - x_202 = lean_box(0); + x_212 = lean_box(0); } lean_inc(x_1); -x_203 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_203, 0, x_13); -lean_ctor_set(x_203, 1, x_1); -x_204 = lean_array_push(x_199, x_203); -if (lean_is_scalar(x_202)) { - x_205 = lean_alloc_ctor(0, 5, 0); +x_213 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_213, 0, x_13); +lean_ctor_set(x_213, 1, x_1); +x_214 = lean_array_push(x_209, x_213); +if (lean_is_scalar(x_212)) { + x_215 = lean_alloc_ctor(0, 5, 0); } else { - x_205 = x_202; + x_215 = x_212; } -lean_ctor_set(x_205, 0, x_197); -lean_ctor_set(x_205, 1, x_198); -lean_ctor_set(x_205, 2, x_204); -lean_ctor_set(x_205, 3, x_200); -lean_ctor_set(x_205, 4, x_201); -x_206 = lean_apply_3(x_3, x_1, x_205, x_196); -if (lean_obj_tag(x_206) == 0) +lean_ctor_set(x_215, 0, x_207); +lean_ctor_set(x_215, 1, x_208); +lean_ctor_set(x_215, 2, x_214); +lean_ctor_set(x_215, 3, x_210); +lean_ctor_set(x_215, 4, x_211); +x_216 = lean_apply_3(x_3, x_1, x_215, x_206); +if (lean_obj_tag(x_216) == 0) { -lean_object* x_207; lean_object* x_208; lean_object* x_209; -x_207 = lean_ctor_get(x_206, 0); -lean_inc(x_207); -x_208 = lean_ctor_get(x_206, 1); -lean_inc(x_208); -lean_dec(x_206); -x_209 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_209, 0, x_207); -x_161 = x_209; -x_162 = x_208; -goto block_193; +lean_object* x_217; lean_object* x_218; lean_object* x_219; +x_217 = lean_ctor_get(x_216, 0); +lean_inc(x_217); +x_218 = lean_ctor_get(x_216, 1); +lean_inc(x_218); +lean_dec(x_216); +x_219 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_219, 0, x_217); +x_169 = x_219; +x_170 = x_218; +goto block_203; } else { -lean_object* x_210; lean_object* x_211; lean_object* x_212; -x_210 = lean_ctor_get(x_206, 0); -lean_inc(x_210); -x_211 = lean_ctor_get(x_206, 1); -lean_inc(x_211); -lean_dec(x_206); -x_212 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_212, 0, x_210); -x_161 = x_212; -x_162 = x_211; -goto block_193; +lean_object* x_220; lean_object* x_221; lean_object* x_222; +x_220 = lean_ctor_get(x_216, 0); +lean_inc(x_220); +x_221 = lean_ctor_get(x_216, 1); +lean_inc(x_221); +lean_dec(x_216); +x_222 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_222, 0, x_220); +x_169 = x_222; +x_170 = x_221; +goto block_203; } -block_193: +block_203: { -if (lean_obj_tag(x_161) == 0) +if (lean_obj_tag(x_169) == 0) { -lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; lean_object* x_173; lean_object* x_174; lean_object* x_175; lean_object* x_176; lean_object* x_177; -x_163 = lean_ctor_get(x_162, 2); -lean_inc(x_163); -x_164 = lean_ctor_get(x_161, 0); -lean_inc(x_164); -lean_dec(x_161); -x_165 = lean_ctor_get(x_162, 0); -lean_inc(x_165); -x_166 = lean_ctor_get(x_162, 1); -lean_inc(x_166); -x_167 = lean_ctor_get(x_162, 3); -lean_inc(x_167); -x_168 = lean_ctor_get(x_162, 4); -lean_inc(x_168); -x_169 = lean_ctor_get(x_162, 5); -lean_inc(x_169); -if (lean_is_exclusive(x_162)) { - lean_ctor_release(x_162, 0); - lean_ctor_release(x_162, 1); - lean_ctor_release(x_162, 2); - lean_ctor_release(x_162, 3); - lean_ctor_release(x_162, 4); - lean_ctor_release(x_162, 5); - x_170 = x_162; -} else { - lean_dec_ref(x_162); - x_170 = lean_box(0); -} -x_171 = lean_ctor_get(x_163, 0); +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; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; +x_171 = lean_ctor_get(x_170, 2); lean_inc(x_171); -x_172 = lean_ctor_get(x_163, 1); +x_172 = lean_ctor_get(x_169, 0); lean_inc(x_172); -x_173 = lean_ctor_get(x_163, 3); +lean_dec(x_169); +x_173 = lean_ctor_get(x_170, 0); lean_inc(x_173); -if (lean_is_exclusive(x_163)) { - lean_ctor_release(x_163, 0); - lean_ctor_release(x_163, 1); - lean_ctor_release(x_163, 2); - lean_ctor_release(x_163, 3); - x_174 = x_163; +x_174 = lean_ctor_get(x_170, 1); +lean_inc(x_174); +x_175 = lean_ctor_get(x_170, 3); +lean_inc(x_175); +x_176 = lean_ctor_get(x_170, 4); +lean_inc(x_176); +x_177 = lean_ctor_get(x_170, 5); +lean_inc(x_177); +if (lean_is_exclusive(x_170)) { + lean_ctor_release(x_170, 0); + lean_ctor_release(x_170, 1); + lean_ctor_release(x_170, 2); + lean_ctor_release(x_170, 3); + lean_ctor_release(x_170, 4); + lean_ctor_release(x_170, 5); + x_178 = x_170; } else { - lean_dec_ref(x_163); - x_174 = lean_box(0); + lean_dec_ref(x_170); + x_178 = lean_box(0); } -if (lean_is_scalar(x_174)) { - x_175 = lean_alloc_ctor(0, 4, 0); -} else { - x_175 = x_174; -} -lean_ctor_set(x_175, 0, x_171); -lean_ctor_set(x_175, 1, x_172); -lean_ctor_set(x_175, 2, x_158); -lean_ctor_set(x_175, 3, x_173); -if (lean_is_scalar(x_170)) { - x_176 = lean_alloc_ctor(0, 6, 0); -} else { - x_176 = x_170; -} -lean_ctor_set(x_176, 0, x_165); -lean_ctor_set(x_176, 1, x_166); -lean_ctor_set(x_176, 2, x_175); -lean_ctor_set(x_176, 3, x_167); -lean_ctor_set(x_176, 4, x_168); -lean_ctor_set(x_176, 5, x_169); -if (lean_is_scalar(x_11)) { - x_177 = lean_alloc_ctor(1, 2, 0); -} else { - x_177 = x_11; - lean_ctor_set_tag(x_177, 1); -} -lean_ctor_set(x_177, 0, x_164); -lean_ctor_set(x_177, 1, x_176); -return x_177; -} -else -{ -lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; -x_178 = lean_ctor_get(x_162, 2); -lean_inc(x_178); -x_179 = lean_ctor_get(x_161, 0); +x_179 = lean_ctor_get(x_171, 0); lean_inc(x_179); -lean_dec(x_161); -x_180 = lean_ctor_get(x_162, 0); +x_180 = lean_ctor_get(x_171, 1); lean_inc(x_180); -x_181 = lean_ctor_get(x_162, 1); +x_181 = lean_ctor_get(x_171, 3); lean_inc(x_181); -x_182 = lean_ctor_get(x_162, 3); +x_182 = lean_ctor_get(x_171, 4); lean_inc(x_182); -x_183 = lean_ctor_get(x_162, 4); -lean_inc(x_183); -x_184 = lean_ctor_get(x_162, 5); -lean_inc(x_184); -if (lean_is_exclusive(x_162)) { - lean_ctor_release(x_162, 0); - lean_ctor_release(x_162, 1); - lean_ctor_release(x_162, 2); - lean_ctor_release(x_162, 3); - lean_ctor_release(x_162, 4); - lean_ctor_release(x_162, 5); - x_185 = x_162; +if (lean_is_exclusive(x_171)) { + lean_ctor_release(x_171, 0); + lean_ctor_release(x_171, 1); + lean_ctor_release(x_171, 2); + lean_ctor_release(x_171, 3); + lean_ctor_release(x_171, 4); + x_183 = x_171; } else { - lean_dec_ref(x_162); - x_185 = lean_box(0); + lean_dec_ref(x_171); + x_183 = lean_box(0); } -x_186 = lean_ctor_get(x_178, 0); -lean_inc(x_186); -x_187 = lean_ctor_get(x_178, 1); -lean_inc(x_187); -x_188 = lean_ctor_get(x_178, 3); -lean_inc(x_188); -if (lean_is_exclusive(x_178)) { - lean_ctor_release(x_178, 0); - lean_ctor_release(x_178, 1); - lean_ctor_release(x_178, 2); - lean_ctor_release(x_178, 3); - x_189 = x_178; +if (lean_is_scalar(x_183)) { + x_184 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_178); - x_189 = lean_box(0); + x_184 = x_183; } -if (lean_is_scalar(x_189)) { - x_190 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_184, 0, x_179); +lean_ctor_set(x_184, 1, x_180); +lean_ctor_set(x_184, 2, x_165); +lean_ctor_set(x_184, 3, x_181); +lean_ctor_set(x_184, 4, x_182); +if (lean_is_scalar(x_178)) { + x_185 = lean_alloc_ctor(0, 6, 0); } else { - x_190 = x_189; + x_185 = x_178; } -lean_ctor_set(x_190, 0, x_186); -lean_ctor_set(x_190, 1, x_187); -lean_ctor_set(x_190, 2, x_158); -lean_ctor_set(x_190, 3, x_188); -if (lean_is_scalar(x_185)) { - x_191 = lean_alloc_ctor(0, 6, 0); -} else { - x_191 = x_185; -} -lean_ctor_set(x_191, 0, x_180); -lean_ctor_set(x_191, 1, x_181); -lean_ctor_set(x_191, 2, x_190); -lean_ctor_set(x_191, 3, x_182); -lean_ctor_set(x_191, 4, x_183); -lean_ctor_set(x_191, 5, x_184); +lean_ctor_set(x_185, 0, x_173); +lean_ctor_set(x_185, 1, x_174); +lean_ctor_set(x_185, 2, x_184); +lean_ctor_set(x_185, 3, x_175); +lean_ctor_set(x_185, 4, x_176); +lean_ctor_set(x_185, 5, x_177); if (lean_is_scalar(x_11)) { - x_192 = lean_alloc_ctor(0, 2, 0); + x_186 = lean_alloc_ctor(1, 2, 0); } else { - x_192 = x_11; + x_186 = x_11; + lean_ctor_set_tag(x_186, 1); } -lean_ctor_set(x_192, 0, x_179); -lean_ctor_set(x_192, 1, x_191); -return x_192; +lean_ctor_set(x_186, 0, x_172); +lean_ctor_set(x_186, 1, x_185); +return x_186; +} +else +{ +lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; +x_187 = lean_ctor_get(x_170, 2); +lean_inc(x_187); +x_188 = lean_ctor_get(x_169, 0); +lean_inc(x_188); +lean_dec(x_169); +x_189 = lean_ctor_get(x_170, 0); +lean_inc(x_189); +x_190 = lean_ctor_get(x_170, 1); +lean_inc(x_190); +x_191 = lean_ctor_get(x_170, 3); +lean_inc(x_191); +x_192 = lean_ctor_get(x_170, 4); +lean_inc(x_192); +x_193 = lean_ctor_get(x_170, 5); +lean_inc(x_193); +if (lean_is_exclusive(x_170)) { + lean_ctor_release(x_170, 0); + lean_ctor_release(x_170, 1); + lean_ctor_release(x_170, 2); + lean_ctor_release(x_170, 3); + lean_ctor_release(x_170, 4); + lean_ctor_release(x_170, 5); + x_194 = x_170; +} else { + lean_dec_ref(x_170); + x_194 = lean_box(0); +} +x_195 = lean_ctor_get(x_187, 0); +lean_inc(x_195); +x_196 = lean_ctor_get(x_187, 1); +lean_inc(x_196); +x_197 = lean_ctor_get(x_187, 3); +lean_inc(x_197); +x_198 = lean_ctor_get(x_187, 4); +lean_inc(x_198); +if (lean_is_exclusive(x_187)) { + lean_ctor_release(x_187, 0); + lean_ctor_release(x_187, 1); + lean_ctor_release(x_187, 2); + lean_ctor_release(x_187, 3); + lean_ctor_release(x_187, 4); + x_199 = x_187; +} else { + lean_dec_ref(x_187); + x_199 = lean_box(0); +} +if (lean_is_scalar(x_199)) { + x_200 = lean_alloc_ctor(0, 5, 0); +} else { + x_200 = x_199; +} +lean_ctor_set(x_200, 0, x_195); +lean_ctor_set(x_200, 1, x_196); +lean_ctor_set(x_200, 2, x_165); +lean_ctor_set(x_200, 3, x_197); +lean_ctor_set(x_200, 4, x_198); +if (lean_is_scalar(x_194)) { + x_201 = lean_alloc_ctor(0, 6, 0); +} else { + x_201 = x_194; +} +lean_ctor_set(x_201, 0, x_189); +lean_ctor_set(x_201, 1, x_190); +lean_ctor_set(x_201, 2, x_200); +lean_ctor_set(x_201, 3, x_191); +lean_ctor_set(x_201, 4, x_192); +lean_ctor_set(x_201, 5, x_193); +if (lean_is_scalar(x_11)) { + x_202 = lean_alloc_ctor(0, 2, 0); +} else { + x_202 = x_11; +} +lean_ctor_set(x_202, 0, x_188); +lean_ctor_set(x_202, 1, x_201); +return x_202; } } } @@ -40203,27 +41456,27 @@ return x_192; } else { -uint8_t x_213; +uint8_t x_223; lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_213 = !lean_is_exclusive(x_6); -if (x_213 == 0) +x_223 = !lean_is_exclusive(x_6); +if (x_223 == 0) { return x_6; } else { -lean_object* x_214; lean_object* x_215; lean_object* x_216; -x_214 = lean_ctor_get(x_6, 0); -x_215 = lean_ctor_get(x_6, 1); -lean_inc(x_215); -lean_inc(x_214); +lean_object* x_224; lean_object* x_225; lean_object* x_226; +x_224 = lean_ctor_get(x_6, 0); +x_225 = lean_ctor_get(x_6, 1); +lean_inc(x_225); +lean_inc(x_224); lean_dec(x_6); -x_216 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_216, 0, x_214); -lean_ctor_set(x_216, 1, x_215); -return x_216; +x_226 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_226, 0, x_224); +lean_ctor_set(x_226, 1, x_225); +return x_226; } } } @@ -40314,51 +41567,51 @@ lean_dec(x_27); x_28 = !lean_is_exclusive(x_24); if (x_28 == 0) { -lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; +lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; x_29 = lean_ctor_get(x_24, 2); -x_81 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_24, 2, x_81); +x_85 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_24, 2, x_85); lean_inc(x_17); -x_82 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_82, 0, x_25); -lean_ctor_set(x_82, 1, x_17); -x_83 = lean_array_push(x_13, x_82); -x_84 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_84, 0, x_11); -lean_ctor_set(x_84, 1, x_16); -lean_ctor_set(x_84, 2, x_83); -lean_ctor_set(x_84, 3, x_14); -lean_ctor_set(x_84, 4, x_15); -x_85 = lean_apply_3(x_4, x_17, x_84, x_22); -if (lean_obj_tag(x_85) == 0) +x_86 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_86, 0, x_25); +lean_ctor_set(x_86, 1, x_17); +x_87 = lean_array_push(x_13, x_86); +x_88 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_88, 0, x_11); +lean_ctor_set(x_88, 1, x_16); +lean_ctor_set(x_88, 2, x_87); +lean_ctor_set(x_88, 3, x_14); +lean_ctor_set(x_88, 4, x_15); +x_89 = lean_apply_3(x_4, x_17, x_88, x_22); +if (lean_obj_tag(x_89) == 0) { -lean_object* x_86; lean_object* x_87; lean_object* x_88; -x_86 = lean_ctor_get(x_85, 0); -lean_inc(x_86); -x_87 = lean_ctor_get(x_85, 1); -lean_inc(x_87); -lean_dec(x_85); -x_88 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_88, 0, x_86); -x_30 = x_88; -x_31 = x_87; -goto block_80; +lean_object* x_90; lean_object* x_91; lean_object* x_92; +x_90 = lean_ctor_get(x_89, 0); +lean_inc(x_90); +x_91 = lean_ctor_get(x_89, 1); +lean_inc(x_91); +lean_dec(x_89); +x_92 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_92, 0, x_90); +x_30 = x_92; +x_31 = x_91; +goto block_84; } else { -lean_object* x_89; lean_object* x_90; lean_object* x_91; -x_89 = lean_ctor_get(x_85, 0); -lean_inc(x_89); -x_90 = lean_ctor_get(x_85, 1); -lean_inc(x_90); -lean_dec(x_85); -x_91 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_91, 0, x_89); -x_30 = x_91; -x_31 = x_90; -goto block_80; +lean_object* x_93; lean_object* x_94; lean_object* x_95; +x_93 = lean_ctor_get(x_89, 0); +lean_inc(x_93); +x_94 = lean_ctor_get(x_89, 1); +lean_inc(x_94); +lean_dec(x_89); +x_95 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_95, 0, x_93); +x_30 = x_95; +x_31 = x_94; +goto block_84; } -block_80: +block_84: { if (lean_obj_tag(x_30) == 0) { @@ -40393,658 +41646,695 @@ return x_38; } else { -lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; +lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; x_39 = lean_ctor_get(x_32, 0); x_40 = lean_ctor_get(x_32, 1); x_41 = lean_ctor_get(x_32, 3); +x_42 = lean_ctor_get(x_32, 4); +lean_inc(x_42); lean_inc(x_41); lean_inc(x_40); lean_inc(x_39); lean_dec(x_32); -x_42 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_42, 0, x_39); -lean_ctor_set(x_42, 1, x_40); -lean_ctor_set(x_42, 2, x_29); -lean_ctor_set(x_42, 3, x_41); -lean_ctor_set(x_31, 2, x_42); +x_43 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_43, 0, x_39); +lean_ctor_set(x_43, 1, x_40); +lean_ctor_set(x_43, 2, x_29); +lean_ctor_set(x_43, 3, x_41); +lean_ctor_set(x_43, 4, x_42); +lean_ctor_set(x_31, 2, x_43); if (lean_is_scalar(x_23)) { - x_43 = lean_alloc_ctor(1, 2, 0); + x_44 = lean_alloc_ctor(1, 2, 0); } else { - x_43 = x_23; - lean_ctor_set_tag(x_43, 1); + x_44 = x_23; + lean_ctor_set_tag(x_44, 1); } -lean_ctor_set(x_43, 0, x_33); -lean_ctor_set(x_43, 1, x_31); -return x_43; +lean_ctor_set(x_44, 0, x_33); +lean_ctor_set(x_44, 1, x_31); +return x_44; } } 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; -x_44 = lean_ctor_get(x_31, 0); -x_45 = lean_ctor_get(x_31, 1); -x_46 = lean_ctor_get(x_31, 3); -x_47 = lean_ctor_get(x_31, 4); -x_48 = lean_ctor_get(x_31, 5); +lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; +x_45 = lean_ctor_get(x_31, 0); +x_46 = lean_ctor_get(x_31, 1); +x_47 = lean_ctor_get(x_31, 3); +x_48 = lean_ctor_get(x_31, 4); +x_49 = lean_ctor_get(x_31, 5); +lean_inc(x_49); lean_inc(x_48); lean_inc(x_47); lean_inc(x_46); lean_inc(x_45); -lean_inc(x_44); lean_dec(x_31); -x_49 = lean_ctor_get(x_32, 0); -lean_inc(x_49); -x_50 = lean_ctor_get(x_32, 1); +x_50 = lean_ctor_get(x_32, 0); lean_inc(x_50); -x_51 = lean_ctor_get(x_32, 3); +x_51 = lean_ctor_get(x_32, 1); lean_inc(x_51); +x_52 = lean_ctor_get(x_32, 3); +lean_inc(x_52); +x_53 = lean_ctor_get(x_32, 4); +lean_inc(x_53); if (lean_is_exclusive(x_32)) { lean_ctor_release(x_32, 0); lean_ctor_release(x_32, 1); lean_ctor_release(x_32, 2); lean_ctor_release(x_32, 3); - x_52 = x_32; + lean_ctor_release(x_32, 4); + x_54 = x_32; } else { lean_dec_ref(x_32); - x_52 = lean_box(0); + x_54 = lean_box(0); } -if (lean_is_scalar(x_52)) { - x_53 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_54)) { + x_55 = lean_alloc_ctor(0, 5, 0); } else { - x_53 = x_52; + x_55 = x_54; } -lean_ctor_set(x_53, 0, x_49); -lean_ctor_set(x_53, 1, x_50); -lean_ctor_set(x_53, 2, x_29); -lean_ctor_set(x_53, 3, x_51); -x_54 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_54, 0, x_44); -lean_ctor_set(x_54, 1, x_45); -lean_ctor_set(x_54, 2, x_53); -lean_ctor_set(x_54, 3, x_46); -lean_ctor_set(x_54, 4, x_47); -lean_ctor_set(x_54, 5, x_48); +lean_ctor_set(x_55, 0, x_50); +lean_ctor_set(x_55, 1, x_51); +lean_ctor_set(x_55, 2, x_29); +lean_ctor_set(x_55, 3, x_52); +lean_ctor_set(x_55, 4, x_53); +x_56 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_56, 0, x_45); +lean_ctor_set(x_56, 1, x_46); +lean_ctor_set(x_56, 2, x_55); +lean_ctor_set(x_56, 3, x_47); +lean_ctor_set(x_56, 4, x_48); +lean_ctor_set(x_56, 5, x_49); if (lean_is_scalar(x_23)) { - x_55 = lean_alloc_ctor(1, 2, 0); + x_57 = lean_alloc_ctor(1, 2, 0); } else { - x_55 = x_23; - lean_ctor_set_tag(x_55, 1); + x_57 = x_23; + lean_ctor_set_tag(x_57, 1); } -lean_ctor_set(x_55, 0, x_33); -lean_ctor_set(x_55, 1, x_54); -return x_55; +lean_ctor_set(x_57, 0, x_33); +lean_ctor_set(x_57, 1, x_56); +return x_57; } } else { -lean_object* x_56; lean_object* x_57; uint8_t x_58; -x_56 = lean_ctor_get(x_31, 2); -lean_inc(x_56); -x_57 = lean_ctor_get(x_30, 0); -lean_inc(x_57); +lean_object* x_58; lean_object* x_59; uint8_t x_60; +x_58 = lean_ctor_get(x_31, 2); +lean_inc(x_58); +x_59 = lean_ctor_get(x_30, 0); +lean_inc(x_59); lean_dec(x_30); -x_58 = !lean_is_exclusive(x_31); -if (x_58 == 0) -{ -lean_object* x_59; uint8_t x_60; -x_59 = lean_ctor_get(x_31, 2); -lean_dec(x_59); -x_60 = !lean_is_exclusive(x_56); +x_60 = !lean_is_exclusive(x_31); if (x_60 == 0) { -lean_object* x_61; lean_object* x_62; -x_61 = lean_ctor_get(x_56, 2); +lean_object* x_61; uint8_t x_62; +x_61 = lean_ctor_get(x_31, 2); lean_dec(x_61); -lean_ctor_set(x_56, 2, x_29); +x_62 = !lean_is_exclusive(x_58); +if (x_62 == 0) +{ +lean_object* x_63; lean_object* x_64; +x_63 = lean_ctor_get(x_58, 2); +lean_dec(x_63); +lean_ctor_set(x_58, 2, x_29); if (lean_is_scalar(x_23)) { - x_62 = lean_alloc_ctor(0, 2, 0); + x_64 = lean_alloc_ctor(0, 2, 0); } else { - x_62 = x_23; + x_64 = x_23; } -lean_ctor_set(x_62, 0, x_57); -lean_ctor_set(x_62, 1, x_31); -return x_62; +lean_ctor_set(x_64, 0, x_59); +lean_ctor_set(x_64, 1, x_31); +return x_64; } else { -lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; -x_63 = lean_ctor_get(x_56, 0); -x_64 = lean_ctor_get(x_56, 1); -x_65 = lean_ctor_get(x_56, 3); +lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; +x_65 = lean_ctor_get(x_58, 0); +x_66 = lean_ctor_get(x_58, 1); +x_67 = lean_ctor_get(x_58, 3); +x_68 = lean_ctor_get(x_58, 4); +lean_inc(x_68); +lean_inc(x_67); +lean_inc(x_66); lean_inc(x_65); -lean_inc(x_64); -lean_inc(x_63); -lean_dec(x_56); -x_66 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_66, 0, x_63); -lean_ctor_set(x_66, 1, x_64); -lean_ctor_set(x_66, 2, x_29); -lean_ctor_set(x_66, 3, x_65); -lean_ctor_set(x_31, 2, x_66); +lean_dec(x_58); +x_69 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_69, 0, x_65); +lean_ctor_set(x_69, 1, x_66); +lean_ctor_set(x_69, 2, x_29); +lean_ctor_set(x_69, 3, x_67); +lean_ctor_set(x_69, 4, x_68); +lean_ctor_set(x_31, 2, x_69); if (lean_is_scalar(x_23)) { - x_67 = lean_alloc_ctor(0, 2, 0); + x_70 = lean_alloc_ctor(0, 2, 0); } else { - x_67 = x_23; + x_70 = x_23; } -lean_ctor_set(x_67, 0, x_57); -lean_ctor_set(x_67, 1, x_31); -return x_67; +lean_ctor_set(x_70, 0, x_59); +lean_ctor_set(x_70, 1, x_31); +return x_70; } } else { -lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; -x_68 = lean_ctor_get(x_31, 0); -x_69 = lean_ctor_get(x_31, 1); -x_70 = lean_ctor_get(x_31, 3); -x_71 = lean_ctor_get(x_31, 4); -x_72 = lean_ctor_get(x_31, 5); +lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; +x_71 = lean_ctor_get(x_31, 0); +x_72 = lean_ctor_get(x_31, 1); +x_73 = lean_ctor_get(x_31, 3); +x_74 = lean_ctor_get(x_31, 4); +x_75 = lean_ctor_get(x_31, 5); +lean_inc(x_75); +lean_inc(x_74); +lean_inc(x_73); lean_inc(x_72); lean_inc(x_71); -lean_inc(x_70); -lean_inc(x_69); -lean_inc(x_68); lean_dec(x_31); -x_73 = lean_ctor_get(x_56, 0); -lean_inc(x_73); -x_74 = lean_ctor_get(x_56, 1); -lean_inc(x_74); -x_75 = lean_ctor_get(x_56, 3); -lean_inc(x_75); -if (lean_is_exclusive(x_56)) { - lean_ctor_release(x_56, 0); - lean_ctor_release(x_56, 1); - lean_ctor_release(x_56, 2); - lean_ctor_release(x_56, 3); - x_76 = x_56; +x_76 = lean_ctor_get(x_58, 0); +lean_inc(x_76); +x_77 = lean_ctor_get(x_58, 1); +lean_inc(x_77); +x_78 = lean_ctor_get(x_58, 3); +lean_inc(x_78); +x_79 = lean_ctor_get(x_58, 4); +lean_inc(x_79); +if (lean_is_exclusive(x_58)) { + lean_ctor_release(x_58, 0); + lean_ctor_release(x_58, 1); + lean_ctor_release(x_58, 2); + lean_ctor_release(x_58, 3); + lean_ctor_release(x_58, 4); + x_80 = x_58; } else { - lean_dec_ref(x_56); - x_76 = lean_box(0); + lean_dec_ref(x_58); + x_80 = lean_box(0); } -if (lean_is_scalar(x_76)) { - x_77 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_80)) { + x_81 = lean_alloc_ctor(0, 5, 0); } else { - x_77 = x_76; + x_81 = x_80; } -lean_ctor_set(x_77, 0, x_73); -lean_ctor_set(x_77, 1, x_74); -lean_ctor_set(x_77, 2, x_29); -lean_ctor_set(x_77, 3, x_75); -x_78 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_78, 0, x_68); -lean_ctor_set(x_78, 1, x_69); -lean_ctor_set(x_78, 2, x_77); -lean_ctor_set(x_78, 3, x_70); -lean_ctor_set(x_78, 4, x_71); -lean_ctor_set(x_78, 5, x_72); +lean_ctor_set(x_81, 0, x_76); +lean_ctor_set(x_81, 1, x_77); +lean_ctor_set(x_81, 2, x_29); +lean_ctor_set(x_81, 3, x_78); +lean_ctor_set(x_81, 4, x_79); +x_82 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_82, 0, x_71); +lean_ctor_set(x_82, 1, x_72); +lean_ctor_set(x_82, 2, x_81); +lean_ctor_set(x_82, 3, x_73); +lean_ctor_set(x_82, 4, x_74); +lean_ctor_set(x_82, 5, x_75); if (lean_is_scalar(x_23)) { - x_79 = lean_alloc_ctor(0, 2, 0); + x_83 = lean_alloc_ctor(0, 2, 0); } else { - x_79 = x_23; + x_83 = x_23; } -lean_ctor_set(x_79, 0, x_57); -lean_ctor_set(x_79, 1, x_78); -return x_79; +lean_ctor_set(x_83, 0, x_59); +lean_ctor_set(x_83, 1, x_82); +return x_83; } } } } else { -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_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; -x_92 = lean_ctor_get(x_24, 0); -x_93 = lean_ctor_get(x_24, 1); -x_94 = lean_ctor_get(x_24, 2); -x_95 = lean_ctor_get(x_24, 3); -lean_inc(x_95); -lean_inc(x_94); -lean_inc(x_93); -lean_inc(x_92); -lean_dec(x_24); -x_129 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_130 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_130, 0, x_92); -lean_ctor_set(x_130, 1, x_93); -lean_ctor_set(x_130, 2, x_129); -lean_ctor_set(x_130, 3, x_95); -lean_ctor_set(x_22, 2, x_130); -lean_inc(x_17); -x_131 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_131, 0, x_25); -lean_ctor_set(x_131, 1, x_17); -x_132 = lean_array_push(x_13, x_131); -x_133 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_133, 0, x_11); -lean_ctor_set(x_133, 1, x_16); -lean_ctor_set(x_133, 2, x_132); -lean_ctor_set(x_133, 3, x_14); -lean_ctor_set(x_133, 4, x_15); -x_134 = lean_apply_3(x_4, x_17, x_133, x_22); -if (lean_obj_tag(x_134) == 0) -{ -lean_object* x_135; lean_object* x_136; lean_object* x_137; -x_135 = lean_ctor_get(x_134, 0); -lean_inc(x_135); -x_136 = lean_ctor_get(x_134, 1); -lean_inc(x_136); -lean_dec(x_134); -x_137 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_137, 0, x_135); -x_96 = x_137; -x_97 = x_136; -goto block_128; -} -else -{ -lean_object* x_138; lean_object* x_139; lean_object* x_140; -x_138 = lean_ctor_get(x_134, 0); -lean_inc(x_138); -x_139 = lean_ctor_get(x_134, 1); -lean_inc(x_139); -lean_dec(x_134); -x_140 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_140, 0, x_138); -x_96 = x_140; -x_97 = x_139; -goto block_128; -} -block_128: -{ -if (lean_obj_tag(x_96) == 0) -{ -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; -x_98 = lean_ctor_get(x_97, 2); -lean_inc(x_98); -x_99 = lean_ctor_get(x_96, 0); -lean_inc(x_99); -lean_dec(x_96); -x_100 = lean_ctor_get(x_97, 0); +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_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; +x_96 = lean_ctor_get(x_24, 0); +x_97 = lean_ctor_get(x_24, 1); +x_98 = lean_ctor_get(x_24, 2); +x_99 = lean_ctor_get(x_24, 3); +x_100 = lean_ctor_get(x_24, 4); lean_inc(x_100); -x_101 = lean_ctor_get(x_97, 1); -lean_inc(x_101); -x_102 = lean_ctor_get(x_97, 3); -lean_inc(x_102); -x_103 = lean_ctor_get(x_97, 4); -lean_inc(x_103); -x_104 = lean_ctor_get(x_97, 5); -lean_inc(x_104); -if (lean_is_exclusive(x_97)) { - lean_ctor_release(x_97, 0); - lean_ctor_release(x_97, 1); - lean_ctor_release(x_97, 2); - lean_ctor_release(x_97, 3); - lean_ctor_release(x_97, 4); - lean_ctor_release(x_97, 5); - x_105 = x_97; -} else { - lean_dec_ref(x_97); - x_105 = lean_box(0); -} -x_106 = lean_ctor_get(x_98, 0); -lean_inc(x_106); -x_107 = lean_ctor_get(x_98, 1); -lean_inc(x_107); -x_108 = lean_ctor_get(x_98, 3); -lean_inc(x_108); -if (lean_is_exclusive(x_98)) { - lean_ctor_release(x_98, 0); - lean_ctor_release(x_98, 1); - lean_ctor_release(x_98, 2); - lean_ctor_release(x_98, 3); - x_109 = x_98; -} else { - lean_dec_ref(x_98); - x_109 = lean_box(0); -} -if (lean_is_scalar(x_109)) { - x_110 = lean_alloc_ctor(0, 4, 0); -} else { - x_110 = x_109; -} -lean_ctor_set(x_110, 0, x_106); -lean_ctor_set(x_110, 1, x_107); -lean_ctor_set(x_110, 2, x_94); -lean_ctor_set(x_110, 3, x_108); -if (lean_is_scalar(x_105)) { - x_111 = lean_alloc_ctor(0, 6, 0); -} else { - x_111 = x_105; -} -lean_ctor_set(x_111, 0, x_100); -lean_ctor_set(x_111, 1, x_101); -lean_ctor_set(x_111, 2, x_110); -lean_ctor_set(x_111, 3, x_102); -lean_ctor_set(x_111, 4, x_103); -lean_ctor_set(x_111, 5, x_104); -if (lean_is_scalar(x_23)) { - x_112 = lean_alloc_ctor(1, 2, 0); -} else { - x_112 = x_23; - lean_ctor_set_tag(x_112, 1); -} -lean_ctor_set(x_112, 0, x_99); -lean_ctor_set(x_112, 1, x_111); -return x_112; -} -else +lean_inc(x_99); +lean_inc(x_98); +lean_inc(x_97); +lean_inc(x_96); +lean_dec(x_24); +x_136 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_137 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_137, 0, x_96); +lean_ctor_set(x_137, 1, x_97); +lean_ctor_set(x_137, 2, x_136); +lean_ctor_set(x_137, 3, x_99); +lean_ctor_set(x_137, 4, x_100); +lean_ctor_set(x_22, 2, x_137); +lean_inc(x_17); +x_138 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_138, 0, x_25); +lean_ctor_set(x_138, 1, x_17); +x_139 = lean_array_push(x_13, x_138); +x_140 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_140, 0, x_11); +lean_ctor_set(x_140, 1, x_16); +lean_ctor_set(x_140, 2, x_139); +lean_ctor_set(x_140, 3, x_14); +lean_ctor_set(x_140, 4, x_15); +x_141 = lean_apply_3(x_4, x_17, x_140, x_22); +if (lean_obj_tag(x_141) == 0) { -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; -x_113 = lean_ctor_get(x_97, 2); -lean_inc(x_113); -x_114 = lean_ctor_get(x_96, 0); -lean_inc(x_114); -lean_dec(x_96); -x_115 = lean_ctor_get(x_97, 0); -lean_inc(x_115); -x_116 = lean_ctor_get(x_97, 1); -lean_inc(x_116); -x_117 = lean_ctor_get(x_97, 3); -lean_inc(x_117); -x_118 = lean_ctor_get(x_97, 4); -lean_inc(x_118); -x_119 = lean_ctor_get(x_97, 5); -lean_inc(x_119); -if (lean_is_exclusive(x_97)) { - lean_ctor_release(x_97, 0); - lean_ctor_release(x_97, 1); - lean_ctor_release(x_97, 2); - lean_ctor_release(x_97, 3); - lean_ctor_release(x_97, 4); - lean_ctor_release(x_97, 5); - x_120 = x_97; -} else { - lean_dec_ref(x_97); - x_120 = lean_box(0); -} -x_121 = lean_ctor_get(x_113, 0); -lean_inc(x_121); -x_122 = lean_ctor_get(x_113, 1); -lean_inc(x_122); -x_123 = lean_ctor_get(x_113, 3); -lean_inc(x_123); -if (lean_is_exclusive(x_113)) { - lean_ctor_release(x_113, 0); - lean_ctor_release(x_113, 1); - lean_ctor_release(x_113, 2); - lean_ctor_release(x_113, 3); - x_124 = x_113; -} else { - lean_dec_ref(x_113); - x_124 = lean_box(0); -} -if (lean_is_scalar(x_124)) { - x_125 = lean_alloc_ctor(0, 4, 0); -} else { - x_125 = x_124; -} -lean_ctor_set(x_125, 0, x_121); -lean_ctor_set(x_125, 1, x_122); -lean_ctor_set(x_125, 2, x_94); -lean_ctor_set(x_125, 3, x_123); -if (lean_is_scalar(x_120)) { - x_126 = lean_alloc_ctor(0, 6, 0); -} else { - x_126 = x_120; -} -lean_ctor_set(x_126, 0, x_115); -lean_ctor_set(x_126, 1, x_116); -lean_ctor_set(x_126, 2, x_125); -lean_ctor_set(x_126, 3, x_117); -lean_ctor_set(x_126, 4, x_118); -lean_ctor_set(x_126, 5, x_119); -if (lean_is_scalar(x_23)) { - x_127 = lean_alloc_ctor(0, 2, 0); -} else { - x_127 = x_23; -} -lean_ctor_set(x_127, 0, x_114); -lean_ctor_set(x_127, 1, x_126); -return x_127; -} -} -} -} -else -{ -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_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; -x_141 = lean_ctor_get(x_22, 0); -x_142 = lean_ctor_get(x_22, 1); -x_143 = lean_ctor_get(x_22, 3); -x_144 = lean_ctor_get(x_22, 4); -x_145 = lean_ctor_get(x_22, 5); -lean_inc(x_145); -lean_inc(x_144); -lean_inc(x_143); +lean_object* x_142; lean_object* x_143; lean_object* x_144; +x_142 = lean_ctor_get(x_141, 0); lean_inc(x_142); -lean_inc(x_141); -lean_dec(x_22); -x_146 = lean_ctor_get(x_24, 0); +x_143 = lean_ctor_get(x_141, 1); +lean_inc(x_143); +lean_dec(x_141); +x_144 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_144, 0, x_142); +x_101 = x_144; +x_102 = x_143; +goto block_135; +} +else +{ +lean_object* x_145; lean_object* x_146; lean_object* x_147; +x_145 = lean_ctor_get(x_141, 0); +lean_inc(x_145); +x_146 = lean_ctor_get(x_141, 1); lean_inc(x_146); -x_147 = lean_ctor_get(x_24, 1); -lean_inc(x_147); -x_148 = lean_ctor_get(x_24, 2); -lean_inc(x_148); -x_149 = lean_ctor_get(x_24, 3); +lean_dec(x_141); +x_147 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_147, 0, x_145); +x_101 = x_147; +x_102 = x_146; +goto block_135; +} +block_135: +{ +if (lean_obj_tag(x_101) == 0) +{ +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; +x_103 = lean_ctor_get(x_102, 2); +lean_inc(x_103); +x_104 = lean_ctor_get(x_101, 0); +lean_inc(x_104); +lean_dec(x_101); +x_105 = lean_ctor_get(x_102, 0); +lean_inc(x_105); +x_106 = lean_ctor_get(x_102, 1); +lean_inc(x_106); +x_107 = lean_ctor_get(x_102, 3); +lean_inc(x_107); +x_108 = lean_ctor_get(x_102, 4); +lean_inc(x_108); +x_109 = lean_ctor_get(x_102, 5); +lean_inc(x_109); +if (lean_is_exclusive(x_102)) { + lean_ctor_release(x_102, 0); + lean_ctor_release(x_102, 1); + lean_ctor_release(x_102, 2); + lean_ctor_release(x_102, 3); + lean_ctor_release(x_102, 4); + lean_ctor_release(x_102, 5); + x_110 = x_102; +} else { + lean_dec_ref(x_102); + x_110 = lean_box(0); +} +x_111 = lean_ctor_get(x_103, 0); +lean_inc(x_111); +x_112 = lean_ctor_get(x_103, 1); +lean_inc(x_112); +x_113 = lean_ctor_get(x_103, 3); +lean_inc(x_113); +x_114 = lean_ctor_get(x_103, 4); +lean_inc(x_114); +if (lean_is_exclusive(x_103)) { + lean_ctor_release(x_103, 0); + lean_ctor_release(x_103, 1); + lean_ctor_release(x_103, 2); + lean_ctor_release(x_103, 3); + lean_ctor_release(x_103, 4); + x_115 = x_103; +} else { + lean_dec_ref(x_103); + x_115 = lean_box(0); +} +if (lean_is_scalar(x_115)) { + x_116 = lean_alloc_ctor(0, 5, 0); +} else { + x_116 = x_115; +} +lean_ctor_set(x_116, 0, x_111); +lean_ctor_set(x_116, 1, x_112); +lean_ctor_set(x_116, 2, x_98); +lean_ctor_set(x_116, 3, x_113); +lean_ctor_set(x_116, 4, x_114); +if (lean_is_scalar(x_110)) { + x_117 = lean_alloc_ctor(0, 6, 0); +} else { + x_117 = x_110; +} +lean_ctor_set(x_117, 0, x_105); +lean_ctor_set(x_117, 1, x_106); +lean_ctor_set(x_117, 2, x_116); +lean_ctor_set(x_117, 3, x_107); +lean_ctor_set(x_117, 4, x_108); +lean_ctor_set(x_117, 5, x_109); +if (lean_is_scalar(x_23)) { + x_118 = lean_alloc_ctor(1, 2, 0); +} else { + x_118 = x_23; + lean_ctor_set_tag(x_118, 1); +} +lean_ctor_set(x_118, 0, x_104); +lean_ctor_set(x_118, 1, x_117); +return x_118; +} +else +{ +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; +x_119 = lean_ctor_get(x_102, 2); +lean_inc(x_119); +x_120 = lean_ctor_get(x_101, 0); +lean_inc(x_120); +lean_dec(x_101); +x_121 = lean_ctor_get(x_102, 0); +lean_inc(x_121); +x_122 = lean_ctor_get(x_102, 1); +lean_inc(x_122); +x_123 = lean_ctor_get(x_102, 3); +lean_inc(x_123); +x_124 = lean_ctor_get(x_102, 4); +lean_inc(x_124); +x_125 = lean_ctor_get(x_102, 5); +lean_inc(x_125); +if (lean_is_exclusive(x_102)) { + lean_ctor_release(x_102, 0); + lean_ctor_release(x_102, 1); + lean_ctor_release(x_102, 2); + lean_ctor_release(x_102, 3); + lean_ctor_release(x_102, 4); + lean_ctor_release(x_102, 5); + x_126 = x_102; +} else { + lean_dec_ref(x_102); + x_126 = lean_box(0); +} +x_127 = lean_ctor_get(x_119, 0); +lean_inc(x_127); +x_128 = lean_ctor_get(x_119, 1); +lean_inc(x_128); +x_129 = lean_ctor_get(x_119, 3); +lean_inc(x_129); +x_130 = lean_ctor_get(x_119, 4); +lean_inc(x_130); +if (lean_is_exclusive(x_119)) { + lean_ctor_release(x_119, 0); + lean_ctor_release(x_119, 1); + lean_ctor_release(x_119, 2); + lean_ctor_release(x_119, 3); + lean_ctor_release(x_119, 4); + x_131 = x_119; +} else { + lean_dec_ref(x_119); + x_131 = lean_box(0); +} +if (lean_is_scalar(x_131)) { + x_132 = lean_alloc_ctor(0, 5, 0); +} else { + x_132 = x_131; +} +lean_ctor_set(x_132, 0, x_127); +lean_ctor_set(x_132, 1, x_128); +lean_ctor_set(x_132, 2, x_98); +lean_ctor_set(x_132, 3, x_129); +lean_ctor_set(x_132, 4, x_130); +if (lean_is_scalar(x_126)) { + x_133 = lean_alloc_ctor(0, 6, 0); +} else { + x_133 = x_126; +} +lean_ctor_set(x_133, 0, x_121); +lean_ctor_set(x_133, 1, x_122); +lean_ctor_set(x_133, 2, x_132); +lean_ctor_set(x_133, 3, x_123); +lean_ctor_set(x_133, 4, x_124); +lean_ctor_set(x_133, 5, x_125); +if (lean_is_scalar(x_23)) { + x_134 = lean_alloc_ctor(0, 2, 0); +} else { + x_134 = x_23; +} +lean_ctor_set(x_134, 0, x_120); +lean_ctor_set(x_134, 1, x_133); +return x_134; +} +} +} +} +else +{ +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_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; +x_148 = lean_ctor_get(x_22, 0); +x_149 = lean_ctor_get(x_22, 1); +x_150 = lean_ctor_get(x_22, 3); +x_151 = lean_ctor_get(x_22, 4); +x_152 = lean_ctor_get(x_22, 5); +lean_inc(x_152); +lean_inc(x_151); +lean_inc(x_150); lean_inc(x_149); +lean_inc(x_148); +lean_dec(x_22); +x_153 = lean_ctor_get(x_24, 0); +lean_inc(x_153); +x_154 = lean_ctor_get(x_24, 1); +lean_inc(x_154); +x_155 = lean_ctor_get(x_24, 2); +lean_inc(x_155); +x_156 = lean_ctor_get(x_24, 3); +lean_inc(x_156); +x_157 = lean_ctor_get(x_24, 4); +lean_inc(x_157); if (lean_is_exclusive(x_24)) { lean_ctor_release(x_24, 0); lean_ctor_release(x_24, 1); lean_ctor_release(x_24, 2); lean_ctor_release(x_24, 3); - x_150 = x_24; + lean_ctor_release(x_24, 4); + x_158 = x_24; } else { lean_dec_ref(x_24); - x_150 = lean_box(0); + x_158 = lean_box(0); } -x_184 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_150)) { - x_185 = lean_alloc_ctor(0, 4, 0); +x_194 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_158)) { + x_195 = lean_alloc_ctor(0, 5, 0); } else { - x_185 = x_150; + x_195 = x_158; } -lean_ctor_set(x_185, 0, x_146); -lean_ctor_set(x_185, 1, x_147); -lean_ctor_set(x_185, 2, x_184); -lean_ctor_set(x_185, 3, x_149); -x_186 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_186, 0, x_141); -lean_ctor_set(x_186, 1, x_142); -lean_ctor_set(x_186, 2, x_185); -lean_ctor_set(x_186, 3, x_143); -lean_ctor_set(x_186, 4, x_144); -lean_ctor_set(x_186, 5, x_145); +lean_ctor_set(x_195, 0, x_153); +lean_ctor_set(x_195, 1, x_154); +lean_ctor_set(x_195, 2, x_194); +lean_ctor_set(x_195, 3, x_156); +lean_ctor_set(x_195, 4, x_157); +x_196 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_196, 0, x_148); +lean_ctor_set(x_196, 1, x_149); +lean_ctor_set(x_196, 2, x_195); +lean_ctor_set(x_196, 3, x_150); +lean_ctor_set(x_196, 4, x_151); +lean_ctor_set(x_196, 5, x_152); lean_inc(x_17); -x_187 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_187, 0, x_25); -lean_ctor_set(x_187, 1, x_17); -x_188 = lean_array_push(x_13, x_187); -x_189 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_189, 0, x_11); -lean_ctor_set(x_189, 1, x_16); -lean_ctor_set(x_189, 2, x_188); -lean_ctor_set(x_189, 3, x_14); -lean_ctor_set(x_189, 4, x_15); -x_190 = lean_apply_3(x_4, x_17, x_189, x_186); -if (lean_obj_tag(x_190) == 0) +x_197 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_197, 0, x_25); +lean_ctor_set(x_197, 1, x_17); +x_198 = lean_array_push(x_13, x_197); +x_199 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_199, 0, x_11); +lean_ctor_set(x_199, 1, x_16); +lean_ctor_set(x_199, 2, x_198); +lean_ctor_set(x_199, 3, x_14); +lean_ctor_set(x_199, 4, x_15); +x_200 = lean_apply_3(x_4, x_17, x_199, x_196); +if (lean_obj_tag(x_200) == 0) { -lean_object* x_191; lean_object* x_192; lean_object* x_193; -x_191 = lean_ctor_get(x_190, 0); -lean_inc(x_191); -x_192 = lean_ctor_get(x_190, 1); -lean_inc(x_192); -lean_dec(x_190); -x_193 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_193, 0, x_191); -x_151 = x_193; -x_152 = x_192; -goto block_183; +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); +x_203 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_203, 0, x_201); +x_159 = x_203; +x_160 = x_202; +goto block_193; } else { -lean_object* x_194; lean_object* x_195; lean_object* x_196; -x_194 = lean_ctor_get(x_190, 0); -lean_inc(x_194); -x_195 = lean_ctor_get(x_190, 1); -lean_inc(x_195); -lean_dec(x_190); -x_196 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_196, 0, x_194); -x_151 = x_196; -x_152 = x_195; -goto block_183; +lean_object* x_204; lean_object* x_205; lean_object* x_206; +x_204 = lean_ctor_get(x_200, 0); +lean_inc(x_204); +x_205 = lean_ctor_get(x_200, 1); +lean_inc(x_205); +lean_dec(x_200); +x_206 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_206, 0, x_204); +x_159 = x_206; +x_160 = x_205; +goto block_193; } -block_183: +block_193: { -if (lean_obj_tag(x_151) == 0) +if (lean_obj_tag(x_159) == 0) { -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; -x_153 = lean_ctor_get(x_152, 2); -lean_inc(x_153); -x_154 = lean_ctor_get(x_151, 0); -lean_inc(x_154); -lean_dec(x_151); -x_155 = lean_ctor_get(x_152, 0); -lean_inc(x_155); -x_156 = lean_ctor_get(x_152, 1); -lean_inc(x_156); -x_157 = lean_ctor_get(x_152, 3); -lean_inc(x_157); -x_158 = lean_ctor_get(x_152, 4); -lean_inc(x_158); -x_159 = lean_ctor_get(x_152, 5); -lean_inc(x_159); -if (lean_is_exclusive(x_152)) { - lean_ctor_release(x_152, 0); - lean_ctor_release(x_152, 1); - lean_ctor_release(x_152, 2); - lean_ctor_release(x_152, 3); - lean_ctor_release(x_152, 4); - lean_ctor_release(x_152, 5); - x_160 = x_152; -} else { - lean_dec_ref(x_152); - x_160 = lean_box(0); -} -x_161 = lean_ctor_get(x_153, 0); +lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; lean_object* x_173; lean_object* x_174; lean_object* x_175; lean_object* x_176; +x_161 = lean_ctor_get(x_160, 2); lean_inc(x_161); -x_162 = lean_ctor_get(x_153, 1); +x_162 = lean_ctor_get(x_159, 0); lean_inc(x_162); -x_163 = lean_ctor_get(x_153, 3); +lean_dec(x_159); +x_163 = lean_ctor_get(x_160, 0); lean_inc(x_163); -if (lean_is_exclusive(x_153)) { - lean_ctor_release(x_153, 0); - lean_ctor_release(x_153, 1); - lean_ctor_release(x_153, 2); - lean_ctor_release(x_153, 3); - x_164 = x_153; +x_164 = lean_ctor_get(x_160, 1); +lean_inc(x_164); +x_165 = lean_ctor_get(x_160, 3); +lean_inc(x_165); +x_166 = lean_ctor_get(x_160, 4); +lean_inc(x_166); +x_167 = lean_ctor_get(x_160, 5); +lean_inc(x_167); +if (lean_is_exclusive(x_160)) { + lean_ctor_release(x_160, 0); + lean_ctor_release(x_160, 1); + lean_ctor_release(x_160, 2); + lean_ctor_release(x_160, 3); + lean_ctor_release(x_160, 4); + lean_ctor_release(x_160, 5); + x_168 = x_160; } else { - lean_dec_ref(x_153); - x_164 = lean_box(0); + lean_dec_ref(x_160); + x_168 = lean_box(0); } -if (lean_is_scalar(x_164)) { - x_165 = lean_alloc_ctor(0, 4, 0); -} else { - x_165 = x_164; -} -lean_ctor_set(x_165, 0, x_161); -lean_ctor_set(x_165, 1, x_162); -lean_ctor_set(x_165, 2, x_148); -lean_ctor_set(x_165, 3, x_163); -if (lean_is_scalar(x_160)) { - x_166 = lean_alloc_ctor(0, 6, 0); -} else { - x_166 = x_160; -} -lean_ctor_set(x_166, 0, x_155); -lean_ctor_set(x_166, 1, x_156); -lean_ctor_set(x_166, 2, x_165); -lean_ctor_set(x_166, 3, x_157); -lean_ctor_set(x_166, 4, x_158); -lean_ctor_set(x_166, 5, x_159); -if (lean_is_scalar(x_23)) { - x_167 = lean_alloc_ctor(1, 2, 0); -} else { - x_167 = x_23; - lean_ctor_set_tag(x_167, 1); -} -lean_ctor_set(x_167, 0, x_154); -lean_ctor_set(x_167, 1, x_166); -return x_167; -} -else -{ -lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; lean_object* x_173; lean_object* x_174; lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; -x_168 = lean_ctor_get(x_152, 2); -lean_inc(x_168); -x_169 = lean_ctor_get(x_151, 0); +x_169 = lean_ctor_get(x_161, 0); lean_inc(x_169); -lean_dec(x_151); -x_170 = lean_ctor_get(x_152, 0); +x_170 = lean_ctor_get(x_161, 1); lean_inc(x_170); -x_171 = lean_ctor_get(x_152, 1); +x_171 = lean_ctor_get(x_161, 3); lean_inc(x_171); -x_172 = lean_ctor_get(x_152, 3); +x_172 = lean_ctor_get(x_161, 4); lean_inc(x_172); -x_173 = lean_ctor_get(x_152, 4); -lean_inc(x_173); -x_174 = lean_ctor_get(x_152, 5); -lean_inc(x_174); -if (lean_is_exclusive(x_152)) { - lean_ctor_release(x_152, 0); - lean_ctor_release(x_152, 1); - lean_ctor_release(x_152, 2); - lean_ctor_release(x_152, 3); - lean_ctor_release(x_152, 4); - lean_ctor_release(x_152, 5); - x_175 = x_152; +if (lean_is_exclusive(x_161)) { + lean_ctor_release(x_161, 0); + lean_ctor_release(x_161, 1); + lean_ctor_release(x_161, 2); + lean_ctor_release(x_161, 3); + lean_ctor_release(x_161, 4); + x_173 = x_161; } else { - lean_dec_ref(x_152); - x_175 = lean_box(0); + lean_dec_ref(x_161); + x_173 = lean_box(0); } -x_176 = lean_ctor_get(x_168, 0); -lean_inc(x_176); -x_177 = lean_ctor_get(x_168, 1); -lean_inc(x_177); -x_178 = lean_ctor_get(x_168, 3); -lean_inc(x_178); -if (lean_is_exclusive(x_168)) { - lean_ctor_release(x_168, 0); - lean_ctor_release(x_168, 1); - lean_ctor_release(x_168, 2); - lean_ctor_release(x_168, 3); - x_179 = x_168; +if (lean_is_scalar(x_173)) { + x_174 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_168); - x_179 = lean_box(0); + x_174 = x_173; } -if (lean_is_scalar(x_179)) { - x_180 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_174, 0, x_169); +lean_ctor_set(x_174, 1, x_170); +lean_ctor_set(x_174, 2, x_155); +lean_ctor_set(x_174, 3, x_171); +lean_ctor_set(x_174, 4, x_172); +if (lean_is_scalar(x_168)) { + x_175 = lean_alloc_ctor(0, 6, 0); } else { - x_180 = x_179; + x_175 = x_168; } -lean_ctor_set(x_180, 0, x_176); -lean_ctor_set(x_180, 1, x_177); -lean_ctor_set(x_180, 2, x_148); -lean_ctor_set(x_180, 3, x_178); -if (lean_is_scalar(x_175)) { - x_181 = lean_alloc_ctor(0, 6, 0); -} else { - x_181 = x_175; -} -lean_ctor_set(x_181, 0, x_170); -lean_ctor_set(x_181, 1, x_171); -lean_ctor_set(x_181, 2, x_180); -lean_ctor_set(x_181, 3, x_172); -lean_ctor_set(x_181, 4, x_173); -lean_ctor_set(x_181, 5, x_174); +lean_ctor_set(x_175, 0, x_163); +lean_ctor_set(x_175, 1, x_164); +lean_ctor_set(x_175, 2, x_174); +lean_ctor_set(x_175, 3, x_165); +lean_ctor_set(x_175, 4, x_166); +lean_ctor_set(x_175, 5, x_167); if (lean_is_scalar(x_23)) { - x_182 = lean_alloc_ctor(0, 2, 0); + x_176 = lean_alloc_ctor(1, 2, 0); } else { - x_182 = x_23; + x_176 = x_23; + lean_ctor_set_tag(x_176, 1); } -lean_ctor_set(x_182, 0, x_169); -lean_ctor_set(x_182, 1, x_181); -return x_182; +lean_ctor_set(x_176, 0, x_162); +lean_ctor_set(x_176, 1, x_175); +return x_176; +} +else +{ +lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; 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; +x_177 = lean_ctor_get(x_160, 2); +lean_inc(x_177); +x_178 = lean_ctor_get(x_159, 0); +lean_inc(x_178); +lean_dec(x_159); +x_179 = lean_ctor_get(x_160, 0); +lean_inc(x_179); +x_180 = lean_ctor_get(x_160, 1); +lean_inc(x_180); +x_181 = lean_ctor_get(x_160, 3); +lean_inc(x_181); +x_182 = lean_ctor_get(x_160, 4); +lean_inc(x_182); +x_183 = lean_ctor_get(x_160, 5); +lean_inc(x_183); +if (lean_is_exclusive(x_160)) { + lean_ctor_release(x_160, 0); + lean_ctor_release(x_160, 1); + lean_ctor_release(x_160, 2); + lean_ctor_release(x_160, 3); + lean_ctor_release(x_160, 4); + lean_ctor_release(x_160, 5); + x_184 = x_160; +} else { + lean_dec_ref(x_160); + x_184 = lean_box(0); +} +x_185 = lean_ctor_get(x_177, 0); +lean_inc(x_185); +x_186 = lean_ctor_get(x_177, 1); +lean_inc(x_186); +x_187 = lean_ctor_get(x_177, 3); +lean_inc(x_187); +x_188 = lean_ctor_get(x_177, 4); +lean_inc(x_188); +if (lean_is_exclusive(x_177)) { + lean_ctor_release(x_177, 0); + lean_ctor_release(x_177, 1); + lean_ctor_release(x_177, 2); + lean_ctor_release(x_177, 3); + lean_ctor_release(x_177, 4); + x_189 = x_177; +} else { + lean_dec_ref(x_177); + x_189 = lean_box(0); +} +if (lean_is_scalar(x_189)) { + x_190 = lean_alloc_ctor(0, 5, 0); +} else { + x_190 = x_189; +} +lean_ctor_set(x_190, 0, x_185); +lean_ctor_set(x_190, 1, x_186); +lean_ctor_set(x_190, 2, x_155); +lean_ctor_set(x_190, 3, x_187); +lean_ctor_set(x_190, 4, x_188); +if (lean_is_scalar(x_184)) { + x_191 = lean_alloc_ctor(0, 6, 0); +} else { + x_191 = x_184; +} +lean_ctor_set(x_191, 0, x_179); +lean_ctor_set(x_191, 1, x_180); +lean_ctor_set(x_191, 2, x_190); +lean_ctor_set(x_191, 3, x_181); +lean_ctor_set(x_191, 4, x_182); +lean_ctor_set(x_191, 5, x_183); +if (lean_is_scalar(x_23)) { + x_192 = lean_alloc_ctor(0, 2, 0); +} else { + x_192 = x_23; +} +lean_ctor_set(x_192, 0, x_178); +lean_ctor_set(x_192, 1, x_191); +return x_192; } } } @@ -41052,7 +42342,7 @@ return x_182; } else { -uint8_t x_197; +uint8_t x_207; lean_dec(x_5); lean_dec(x_17); lean_dec(x_16); @@ -41061,383 +42351,395 @@ lean_dec(x_14); lean_dec(x_13); lean_dec(x_11); lean_dec(x_4); -x_197 = !lean_is_exclusive(x_18); -if (x_197 == 0) +x_207 = !lean_is_exclusive(x_18); +if (x_207 == 0) { return x_18; } else { -lean_object* x_198; lean_object* x_199; lean_object* x_200; -x_198 = lean_ctor_get(x_18, 0); -x_199 = lean_ctor_get(x_18, 1); -lean_inc(x_199); -lean_inc(x_198); +lean_object* x_208; lean_object* x_209; lean_object* x_210; +x_208 = lean_ctor_get(x_18, 0); +x_209 = lean_ctor_get(x_18, 1); +lean_inc(x_209); +lean_inc(x_208); lean_dec(x_18); -x_200 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_200, 0, x_198); -lean_ctor_set(x_200, 1, x_199); -return x_200; +x_210 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_210, 0, x_208); +lean_ctor_set(x_210, 1, x_209); +return x_210; } } } else { -lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; -x_201 = lean_ctor_get(x_5, 0); -x_202 = lean_ctor_get(x_5, 1); -x_203 = lean_ctor_get(x_5, 2); -x_204 = lean_ctor_get(x_5, 3); -x_205 = lean_ctor_get(x_5, 4); -lean_inc(x_205); -lean_inc(x_204); -lean_inc(x_203); -lean_inc(x_202); -lean_inc(x_201); +lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; +x_211 = lean_ctor_get(x_5, 0); +x_212 = lean_ctor_get(x_5, 1); +x_213 = lean_ctor_get(x_5, 2); +x_214 = lean_ctor_get(x_5, 3); +x_215 = lean_ctor_get(x_5, 4); +lean_inc(x_215); +lean_inc(x_214); +lean_inc(x_213); +lean_inc(x_212); +lean_inc(x_211); lean_dec(x_5); lean_inc(x_2); lean_inc(x_8); -x_206 = lean_local_ctx_mk_local_decl(x_202, x_8, x_1, x_2, x_3); -x_207 = l_Lean_mkFVar(x_8); -lean_inc(x_205); -lean_inc(x_204); -lean_inc(x_203); -lean_inc(x_206); -lean_inc(x_201); -x_208 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_208, 0, x_201); -lean_ctor_set(x_208, 1, x_206); -lean_ctor_set(x_208, 2, x_203); -lean_ctor_set(x_208, 3, x_204); -lean_ctor_set(x_208, 4, x_205); -lean_inc(x_208); -x_209 = l_Lean_Meta_isClass(x_2, x_208, x_9); -if (lean_obj_tag(x_209) == 0) -{ -lean_object* x_210; -x_210 = lean_ctor_get(x_209, 0); -lean_inc(x_210); -if (lean_obj_tag(x_210) == 0) -{ -lean_object* x_211; lean_object* x_212; -lean_dec(x_206); -lean_dec(x_205); -lean_dec(x_204); -lean_dec(x_203); -lean_dec(x_201); -x_211 = lean_ctor_get(x_209, 1); -lean_inc(x_211); -lean_dec(x_209); -x_212 = lean_apply_3(x_4, x_207, x_208, x_211); -return x_212; -} -else -{ -lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; lean_object* x_224; lean_object* x_225; lean_object* x_226; lean_object* x_227; lean_object* x_228; lean_object* x_229; 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_dec(x_208); -x_213 = lean_ctor_get(x_209, 1); -lean_inc(x_213); -if (lean_is_exclusive(x_209)) { - lean_ctor_release(x_209, 0); - lean_ctor_release(x_209, 1); - x_214 = x_209; -} else { - lean_dec_ref(x_209); - x_214 = lean_box(0); -} -x_215 = lean_ctor_get(x_213, 2); +x_216 = lean_local_ctx_mk_local_decl(x_212, x_8, x_1, x_2, x_3); +x_217 = l_Lean_mkFVar(x_8); lean_inc(x_215); -x_216 = lean_ctor_get(x_210, 0); +lean_inc(x_214); +lean_inc(x_213); lean_inc(x_216); -lean_dec(x_210); -x_217 = lean_ctor_get(x_213, 0); -lean_inc(x_217); -x_218 = lean_ctor_get(x_213, 1); +lean_inc(x_211); +x_218 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_218, 0, x_211); +lean_ctor_set(x_218, 1, x_216); +lean_ctor_set(x_218, 2, x_213); +lean_ctor_set(x_218, 3, x_214); +lean_ctor_set(x_218, 4, x_215); lean_inc(x_218); -x_219 = lean_ctor_get(x_213, 3); -lean_inc(x_219); -x_220 = lean_ctor_get(x_213, 4); +x_219 = l_Lean_Meta_isClass(x_2, x_218, x_9); +if (lean_obj_tag(x_219) == 0) +{ +lean_object* x_220; +x_220 = lean_ctor_get(x_219, 0); lean_inc(x_220); -x_221 = lean_ctor_get(x_213, 5); +if (lean_obj_tag(x_220) == 0) +{ +lean_object* x_221; lean_object* x_222; +lean_dec(x_216); +lean_dec(x_215); +lean_dec(x_214); +lean_dec(x_213); +lean_dec(x_211); +x_221 = lean_ctor_get(x_219, 1); lean_inc(x_221); -if (lean_is_exclusive(x_213)) { - lean_ctor_release(x_213, 0); - lean_ctor_release(x_213, 1); - lean_ctor_release(x_213, 2); - lean_ctor_release(x_213, 3); - lean_ctor_release(x_213, 4); - lean_ctor_release(x_213, 5); - x_222 = x_213; -} else { - lean_dec_ref(x_213); - x_222 = lean_box(0); +lean_dec(x_219); +x_222 = lean_apply_3(x_4, x_217, x_218, x_221); +return x_222; } -x_223 = lean_ctor_get(x_215, 0); +else +{ +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; lean_object* x_231; lean_object* x_232; lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_object* x_236; lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_274; lean_object* x_275; lean_object* x_276; lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; +lean_dec(x_218); +x_223 = lean_ctor_get(x_219, 1); lean_inc(x_223); -x_224 = lean_ctor_get(x_215, 1); -lean_inc(x_224); -x_225 = lean_ctor_get(x_215, 2); +if (lean_is_exclusive(x_219)) { + lean_ctor_release(x_219, 0); + lean_ctor_release(x_219, 1); + x_224 = x_219; +} else { + lean_dec_ref(x_219); + x_224 = lean_box(0); +} +x_225 = lean_ctor_get(x_223, 2); lean_inc(x_225); -x_226 = lean_ctor_get(x_215, 3); +x_226 = lean_ctor_get(x_220, 0); lean_inc(x_226); -if (lean_is_exclusive(x_215)) { - lean_ctor_release(x_215, 0); - lean_ctor_release(x_215, 1); - lean_ctor_release(x_215, 2); - lean_ctor_release(x_215, 3); - x_227 = x_215; -} else { - lean_dec_ref(x_215); - x_227 = lean_box(0); -} -x_261 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_227)) { - x_262 = lean_alloc_ctor(0, 4, 0); -} else { - x_262 = x_227; -} -lean_ctor_set(x_262, 0, x_223); -lean_ctor_set(x_262, 1, x_224); -lean_ctor_set(x_262, 2, x_261); -lean_ctor_set(x_262, 3, x_226); -if (lean_is_scalar(x_222)) { - x_263 = lean_alloc_ctor(0, 6, 0); -} else { - x_263 = x_222; -} -lean_ctor_set(x_263, 0, x_217); -lean_ctor_set(x_263, 1, x_218); -lean_ctor_set(x_263, 2, x_262); -lean_ctor_set(x_263, 3, x_219); -lean_ctor_set(x_263, 4, x_220); -lean_ctor_set(x_263, 5, x_221); -lean_inc(x_207); -x_264 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_264, 0, x_216); -lean_ctor_set(x_264, 1, x_207); -x_265 = lean_array_push(x_203, x_264); -x_266 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_266, 0, x_201); -lean_ctor_set(x_266, 1, x_206); -lean_ctor_set(x_266, 2, x_265); -lean_ctor_set(x_266, 3, x_204); -lean_ctor_set(x_266, 4, x_205); -x_267 = lean_apply_3(x_4, x_207, x_266, x_263); -if (lean_obj_tag(x_267) == 0) -{ -lean_object* x_268; lean_object* x_269; lean_object* x_270; -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_270 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_270, 0, x_268); -x_228 = x_270; -x_229 = x_269; -goto block_260; -} -else -{ -lean_object* x_271; lean_object* x_272; lean_object* x_273; -x_271 = lean_ctor_get(x_267, 0); -lean_inc(x_271); -x_272 = lean_ctor_get(x_267, 1); -lean_inc(x_272); -lean_dec(x_267); -x_273 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_273, 0, x_271); -x_228 = x_273; -x_229 = x_272; -goto block_260; -} -block_260: -{ -if (lean_obj_tag(x_228) == 0) -{ -lean_object* x_230; lean_object* x_231; lean_object* x_232; lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_object* x_236; lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; lean_object* x_242; lean_object* x_243; lean_object* x_244; -x_230 = lean_ctor_get(x_229, 2); +lean_dec(x_220); +x_227 = lean_ctor_get(x_223, 0); +lean_inc(x_227); +x_228 = lean_ctor_get(x_223, 1); +lean_inc(x_228); +x_229 = lean_ctor_get(x_223, 3); +lean_inc(x_229); +x_230 = lean_ctor_get(x_223, 4); lean_inc(x_230); -x_231 = lean_ctor_get(x_228, 0); +x_231 = lean_ctor_get(x_223, 5); lean_inc(x_231); -lean_dec(x_228); -x_232 = lean_ctor_get(x_229, 0); -lean_inc(x_232); -x_233 = lean_ctor_get(x_229, 1); +if (lean_is_exclusive(x_223)) { + lean_ctor_release(x_223, 0); + lean_ctor_release(x_223, 1); + lean_ctor_release(x_223, 2); + lean_ctor_release(x_223, 3); + lean_ctor_release(x_223, 4); + lean_ctor_release(x_223, 5); + x_232 = x_223; +} else { + lean_dec_ref(x_223); + x_232 = lean_box(0); +} +x_233 = lean_ctor_get(x_225, 0); lean_inc(x_233); -x_234 = lean_ctor_get(x_229, 3); +x_234 = lean_ctor_get(x_225, 1); lean_inc(x_234); -x_235 = lean_ctor_get(x_229, 4); +x_235 = lean_ctor_get(x_225, 2); lean_inc(x_235); -x_236 = lean_ctor_get(x_229, 5); +x_236 = lean_ctor_get(x_225, 3); lean_inc(x_236); -if (lean_is_exclusive(x_229)) { - lean_ctor_release(x_229, 0); - lean_ctor_release(x_229, 1); - lean_ctor_release(x_229, 2); - lean_ctor_release(x_229, 3); - lean_ctor_release(x_229, 4); - lean_ctor_release(x_229, 5); - x_237 = x_229; +x_237 = lean_ctor_get(x_225, 4); +lean_inc(x_237); +if (lean_is_exclusive(x_225)) { + lean_ctor_release(x_225, 0); + lean_ctor_release(x_225, 1); + lean_ctor_release(x_225, 2); + lean_ctor_release(x_225, 3); + lean_ctor_release(x_225, 4); + x_238 = x_225; } else { - lean_dec_ref(x_229); - x_237 = lean_box(0); + lean_dec_ref(x_225); + x_238 = lean_box(0); } -x_238 = lean_ctor_get(x_230, 0); -lean_inc(x_238); -x_239 = lean_ctor_get(x_230, 1); -lean_inc(x_239); -x_240 = lean_ctor_get(x_230, 3); -lean_inc(x_240); -if (lean_is_exclusive(x_230)) { - lean_ctor_release(x_230, 0); - lean_ctor_release(x_230, 1); - lean_ctor_release(x_230, 2); - lean_ctor_release(x_230, 3); - x_241 = x_230; +x_274 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_238)) { + x_275 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_230); - x_241 = lean_box(0); + x_275 = x_238; } -if (lean_is_scalar(x_241)) { - x_242 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_275, 0, x_233); +lean_ctor_set(x_275, 1, x_234); +lean_ctor_set(x_275, 2, x_274); +lean_ctor_set(x_275, 3, x_236); +lean_ctor_set(x_275, 4, x_237); +if (lean_is_scalar(x_232)) { + x_276 = lean_alloc_ctor(0, 6, 0); } else { - x_242 = x_241; + x_276 = x_232; } -lean_ctor_set(x_242, 0, x_238); -lean_ctor_set(x_242, 1, x_239); -lean_ctor_set(x_242, 2, x_225); -lean_ctor_set(x_242, 3, x_240); -if (lean_is_scalar(x_237)) { - x_243 = lean_alloc_ctor(0, 6, 0); -} else { - x_243 = x_237; -} -lean_ctor_set(x_243, 0, x_232); -lean_ctor_set(x_243, 1, x_233); -lean_ctor_set(x_243, 2, x_242); -lean_ctor_set(x_243, 3, x_234); -lean_ctor_set(x_243, 4, x_235); -lean_ctor_set(x_243, 5, x_236); -if (lean_is_scalar(x_214)) { - x_244 = lean_alloc_ctor(1, 2, 0); -} else { - x_244 = x_214; - lean_ctor_set_tag(x_244, 1); -} -lean_ctor_set(x_244, 0, x_231); -lean_ctor_set(x_244, 1, x_243); -return x_244; +lean_ctor_set(x_276, 0, x_227); +lean_ctor_set(x_276, 1, x_228); +lean_ctor_set(x_276, 2, x_275); +lean_ctor_set(x_276, 3, x_229); +lean_ctor_set(x_276, 4, x_230); +lean_ctor_set(x_276, 5, x_231); +lean_inc(x_217); +x_277 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_277, 0, x_226); +lean_ctor_set(x_277, 1, x_217); +x_278 = lean_array_push(x_213, x_277); +x_279 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_279, 0, x_211); +lean_ctor_set(x_279, 1, x_216); +lean_ctor_set(x_279, 2, x_278); +lean_ctor_set(x_279, 3, x_214); +lean_ctor_set(x_279, 4, x_215); +x_280 = lean_apply_3(x_4, x_217, x_279, x_276); +if (lean_obj_tag(x_280) == 0) +{ +lean_object* x_281; lean_object* x_282; lean_object* x_283; +x_281 = lean_ctor_get(x_280, 0); +lean_inc(x_281); +x_282 = lean_ctor_get(x_280, 1); +lean_inc(x_282); +lean_dec(x_280); +x_283 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_283, 0, x_281); +x_239 = x_283; +x_240 = x_282; +goto block_273; } else { -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; lean_object* x_252; lean_object* x_253; lean_object* x_254; lean_object* x_255; lean_object* x_256; lean_object* x_257; lean_object* x_258; lean_object* x_259; -x_245 = lean_ctor_get(x_229, 2); +lean_object* x_284; lean_object* x_285; lean_object* x_286; +x_284 = lean_ctor_get(x_280, 0); +lean_inc(x_284); +x_285 = lean_ctor_get(x_280, 1); +lean_inc(x_285); +lean_dec(x_280); +x_286 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_286, 0, x_284); +x_239 = x_286; +x_240 = x_285; +goto block_273; +} +block_273: +{ +if (lean_obj_tag(x_239) == 0) +{ +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; lean_object* x_252; lean_object* x_253; lean_object* x_254; lean_object* x_255; lean_object* x_256; +x_241 = lean_ctor_get(x_240, 2); +lean_inc(x_241); +x_242 = lean_ctor_get(x_239, 0); +lean_inc(x_242); +lean_dec(x_239); +x_243 = lean_ctor_get(x_240, 0); +lean_inc(x_243); +x_244 = lean_ctor_get(x_240, 1); +lean_inc(x_244); +x_245 = lean_ctor_get(x_240, 3); lean_inc(x_245); -x_246 = lean_ctor_get(x_228, 0); +x_246 = lean_ctor_get(x_240, 4); lean_inc(x_246); -lean_dec(x_228); -x_247 = lean_ctor_get(x_229, 0); +x_247 = lean_ctor_get(x_240, 5); lean_inc(x_247); -x_248 = lean_ctor_get(x_229, 1); -lean_inc(x_248); -x_249 = lean_ctor_get(x_229, 3); +if (lean_is_exclusive(x_240)) { + lean_ctor_release(x_240, 0); + lean_ctor_release(x_240, 1); + lean_ctor_release(x_240, 2); + lean_ctor_release(x_240, 3); + lean_ctor_release(x_240, 4); + lean_ctor_release(x_240, 5); + x_248 = x_240; +} else { + lean_dec_ref(x_240); + x_248 = lean_box(0); +} +x_249 = lean_ctor_get(x_241, 0); lean_inc(x_249); -x_250 = lean_ctor_get(x_229, 4); +x_250 = lean_ctor_get(x_241, 1); lean_inc(x_250); -x_251 = lean_ctor_get(x_229, 5); +x_251 = lean_ctor_get(x_241, 3); lean_inc(x_251); -if (lean_is_exclusive(x_229)) { - lean_ctor_release(x_229, 0); - lean_ctor_release(x_229, 1); - lean_ctor_release(x_229, 2); - lean_ctor_release(x_229, 3); - lean_ctor_release(x_229, 4); - lean_ctor_release(x_229, 5); - x_252 = x_229; +x_252 = lean_ctor_get(x_241, 4); +lean_inc(x_252); +if (lean_is_exclusive(x_241)) { + lean_ctor_release(x_241, 0); + lean_ctor_release(x_241, 1); + lean_ctor_release(x_241, 2); + lean_ctor_release(x_241, 3); + lean_ctor_release(x_241, 4); + x_253 = x_241; } else { - lean_dec_ref(x_229); - x_252 = lean_box(0); + lean_dec_ref(x_241); + x_253 = lean_box(0); } -x_253 = lean_ctor_get(x_245, 0); -lean_inc(x_253); -x_254 = lean_ctor_get(x_245, 1); -lean_inc(x_254); -x_255 = lean_ctor_get(x_245, 3); -lean_inc(x_255); -if (lean_is_exclusive(x_245)) { - lean_ctor_release(x_245, 0); - lean_ctor_release(x_245, 1); - lean_ctor_release(x_245, 2); - lean_ctor_release(x_245, 3); - x_256 = x_245; +if (lean_is_scalar(x_253)) { + x_254 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_245); - x_256 = lean_box(0); + x_254 = x_253; } -if (lean_is_scalar(x_256)) { - x_257 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_254, 0, x_249); +lean_ctor_set(x_254, 1, x_250); +lean_ctor_set(x_254, 2, x_235); +lean_ctor_set(x_254, 3, x_251); +lean_ctor_set(x_254, 4, x_252); +if (lean_is_scalar(x_248)) { + x_255 = lean_alloc_ctor(0, 6, 0); } else { - x_257 = x_256; + x_255 = x_248; } -lean_ctor_set(x_257, 0, x_253); -lean_ctor_set(x_257, 1, x_254); -lean_ctor_set(x_257, 2, x_225); -lean_ctor_set(x_257, 3, x_255); -if (lean_is_scalar(x_252)) { - x_258 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_255, 0, x_243); +lean_ctor_set(x_255, 1, x_244); +lean_ctor_set(x_255, 2, x_254); +lean_ctor_set(x_255, 3, x_245); +lean_ctor_set(x_255, 4, x_246); +lean_ctor_set(x_255, 5, x_247); +if (lean_is_scalar(x_224)) { + x_256 = lean_alloc_ctor(1, 2, 0); } else { - x_258 = x_252; + x_256 = x_224; + lean_ctor_set_tag(x_256, 1); } -lean_ctor_set(x_258, 0, x_247); -lean_ctor_set(x_258, 1, x_248); -lean_ctor_set(x_258, 2, x_257); -lean_ctor_set(x_258, 3, x_249); -lean_ctor_set(x_258, 4, x_250); -lean_ctor_set(x_258, 5, x_251); -if (lean_is_scalar(x_214)) { - x_259 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_256, 0, x_242); +lean_ctor_set(x_256, 1, x_255); +return x_256; +} +else +{ +lean_object* x_257; lean_object* x_258; lean_object* x_259; lean_object* x_260; lean_object* x_261; lean_object* x_262; lean_object* x_263; lean_object* x_264; lean_object* x_265; lean_object* x_266; lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_object* x_270; lean_object* x_271; lean_object* x_272; +x_257 = lean_ctor_get(x_240, 2); +lean_inc(x_257); +x_258 = lean_ctor_get(x_239, 0); +lean_inc(x_258); +lean_dec(x_239); +x_259 = lean_ctor_get(x_240, 0); +lean_inc(x_259); +x_260 = lean_ctor_get(x_240, 1); +lean_inc(x_260); +x_261 = lean_ctor_get(x_240, 3); +lean_inc(x_261); +x_262 = lean_ctor_get(x_240, 4); +lean_inc(x_262); +x_263 = lean_ctor_get(x_240, 5); +lean_inc(x_263); +if (lean_is_exclusive(x_240)) { + lean_ctor_release(x_240, 0); + lean_ctor_release(x_240, 1); + lean_ctor_release(x_240, 2); + lean_ctor_release(x_240, 3); + lean_ctor_release(x_240, 4); + lean_ctor_release(x_240, 5); + x_264 = x_240; } else { - x_259 = x_214; + lean_dec_ref(x_240); + x_264 = lean_box(0); } -lean_ctor_set(x_259, 0, x_246); -lean_ctor_set(x_259, 1, x_258); -return x_259; +x_265 = lean_ctor_get(x_257, 0); +lean_inc(x_265); +x_266 = lean_ctor_get(x_257, 1); +lean_inc(x_266); +x_267 = lean_ctor_get(x_257, 3); +lean_inc(x_267); +x_268 = lean_ctor_get(x_257, 4); +lean_inc(x_268); +if (lean_is_exclusive(x_257)) { + lean_ctor_release(x_257, 0); + lean_ctor_release(x_257, 1); + lean_ctor_release(x_257, 2); + lean_ctor_release(x_257, 3); + lean_ctor_release(x_257, 4); + x_269 = x_257; +} else { + lean_dec_ref(x_257); + x_269 = lean_box(0); +} +if (lean_is_scalar(x_269)) { + x_270 = lean_alloc_ctor(0, 5, 0); +} else { + x_270 = x_269; +} +lean_ctor_set(x_270, 0, x_265); +lean_ctor_set(x_270, 1, x_266); +lean_ctor_set(x_270, 2, x_235); +lean_ctor_set(x_270, 3, x_267); +lean_ctor_set(x_270, 4, x_268); +if (lean_is_scalar(x_264)) { + x_271 = lean_alloc_ctor(0, 6, 0); +} else { + x_271 = x_264; +} +lean_ctor_set(x_271, 0, x_259); +lean_ctor_set(x_271, 1, x_260); +lean_ctor_set(x_271, 2, x_270); +lean_ctor_set(x_271, 3, x_261); +lean_ctor_set(x_271, 4, x_262); +lean_ctor_set(x_271, 5, x_263); +if (lean_is_scalar(x_224)) { + x_272 = lean_alloc_ctor(0, 2, 0); +} else { + x_272 = x_224; +} +lean_ctor_set(x_272, 0, x_258); +lean_ctor_set(x_272, 1, x_271); +return x_272; } } } } else { -lean_object* x_274; lean_object* x_275; lean_object* x_276; lean_object* x_277; -lean_dec(x_208); -lean_dec(x_207); -lean_dec(x_206); -lean_dec(x_205); -lean_dec(x_204); -lean_dec(x_203); -lean_dec(x_201); +lean_object* x_287; lean_object* x_288; lean_object* x_289; lean_object* x_290; +lean_dec(x_218); +lean_dec(x_217); +lean_dec(x_216); +lean_dec(x_215); +lean_dec(x_214); +lean_dec(x_213); +lean_dec(x_211); lean_dec(x_4); -x_274 = lean_ctor_get(x_209, 0); -lean_inc(x_274); -x_275 = lean_ctor_get(x_209, 1); -lean_inc(x_275); -if (lean_is_exclusive(x_209)) { - lean_ctor_release(x_209, 0); - lean_ctor_release(x_209, 1); - x_276 = x_209; +x_287 = lean_ctor_get(x_219, 0); +lean_inc(x_287); +x_288 = lean_ctor_get(x_219, 1); +lean_inc(x_288); +if (lean_is_exclusive(x_219)) { + lean_ctor_release(x_219, 0); + lean_ctor_release(x_219, 1); + x_289 = x_219; } else { - lean_dec_ref(x_209); - x_276 = lean_box(0); + lean_dec_ref(x_219); + x_289 = lean_box(0); } -if (lean_is_scalar(x_276)) { - x_277 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_289)) { + x_290 = lean_alloc_ctor(1, 2, 0); } else { - x_277 = x_276; + x_290 = x_289; } -lean_ctor_set(x_277, 0, x_274); -lean_ctor_set(x_277, 1, x_275); -return x_277; +lean_ctor_set(x_290, 0, x_287); +lean_ctor_set(x_290, 1, x_288); +return x_290; } } } @@ -41555,51 +42857,51 @@ lean_dec(x_27); x_28 = !lean_is_exclusive(x_24); if (x_28 == 0) { -lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; +lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; x_29 = lean_ctor_get(x_24, 2); -x_81 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_24, 2, x_81); +x_85 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_24, 2, x_85); lean_inc(x_17); -x_82 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_82, 0, x_25); -lean_ctor_set(x_82, 1, x_17); -x_83 = lean_array_push(x_13, x_82); -x_84 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_84, 0, x_11); -lean_ctor_set(x_84, 1, x_16); -lean_ctor_set(x_84, 2, x_83); -lean_ctor_set(x_84, 3, x_14); -lean_ctor_set(x_84, 4, x_15); -x_85 = lean_apply_3(x_4, x_17, x_84, x_22); -if (lean_obj_tag(x_85) == 0) +x_86 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_86, 0, x_25); +lean_ctor_set(x_86, 1, x_17); +x_87 = lean_array_push(x_13, x_86); +x_88 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_88, 0, x_11); +lean_ctor_set(x_88, 1, x_16); +lean_ctor_set(x_88, 2, x_87); +lean_ctor_set(x_88, 3, x_14); +lean_ctor_set(x_88, 4, x_15); +x_89 = lean_apply_3(x_4, x_17, x_88, x_22); +if (lean_obj_tag(x_89) == 0) { -lean_object* x_86; lean_object* x_87; lean_object* x_88; -x_86 = lean_ctor_get(x_85, 0); -lean_inc(x_86); -x_87 = lean_ctor_get(x_85, 1); -lean_inc(x_87); -lean_dec(x_85); -x_88 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_88, 0, x_86); -x_30 = x_88; -x_31 = x_87; -goto block_80; +lean_object* x_90; lean_object* x_91; lean_object* x_92; +x_90 = lean_ctor_get(x_89, 0); +lean_inc(x_90); +x_91 = lean_ctor_get(x_89, 1); +lean_inc(x_91); +lean_dec(x_89); +x_92 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_92, 0, x_90); +x_30 = x_92; +x_31 = x_91; +goto block_84; } else { -lean_object* x_89; lean_object* x_90; lean_object* x_91; -x_89 = lean_ctor_get(x_85, 0); -lean_inc(x_89); -x_90 = lean_ctor_get(x_85, 1); -lean_inc(x_90); -lean_dec(x_85); -x_91 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_91, 0, x_89); -x_30 = x_91; -x_31 = x_90; -goto block_80; +lean_object* x_93; lean_object* x_94; lean_object* x_95; +x_93 = lean_ctor_get(x_89, 0); +lean_inc(x_93); +x_94 = lean_ctor_get(x_89, 1); +lean_inc(x_94); +lean_dec(x_89); +x_95 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_95, 0, x_93); +x_30 = x_95; +x_31 = x_94; +goto block_84; } -block_80: +block_84: { if (lean_obj_tag(x_30) == 0) { @@ -41634,658 +42936,695 @@ return x_38; } else { -lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; +lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; x_39 = lean_ctor_get(x_32, 0); x_40 = lean_ctor_get(x_32, 1); x_41 = lean_ctor_get(x_32, 3); +x_42 = lean_ctor_get(x_32, 4); +lean_inc(x_42); lean_inc(x_41); lean_inc(x_40); lean_inc(x_39); lean_dec(x_32); -x_42 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_42, 0, x_39); -lean_ctor_set(x_42, 1, x_40); -lean_ctor_set(x_42, 2, x_29); -lean_ctor_set(x_42, 3, x_41); -lean_ctor_set(x_31, 2, x_42); +x_43 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_43, 0, x_39); +lean_ctor_set(x_43, 1, x_40); +lean_ctor_set(x_43, 2, x_29); +lean_ctor_set(x_43, 3, x_41); +lean_ctor_set(x_43, 4, x_42); +lean_ctor_set(x_31, 2, x_43); if (lean_is_scalar(x_23)) { - x_43 = lean_alloc_ctor(1, 2, 0); + x_44 = lean_alloc_ctor(1, 2, 0); } else { - x_43 = x_23; - lean_ctor_set_tag(x_43, 1); + x_44 = x_23; + lean_ctor_set_tag(x_44, 1); } -lean_ctor_set(x_43, 0, x_33); -lean_ctor_set(x_43, 1, x_31); -return x_43; +lean_ctor_set(x_44, 0, x_33); +lean_ctor_set(x_44, 1, x_31); +return x_44; } } 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; -x_44 = lean_ctor_get(x_31, 0); -x_45 = lean_ctor_get(x_31, 1); -x_46 = lean_ctor_get(x_31, 3); -x_47 = lean_ctor_get(x_31, 4); -x_48 = lean_ctor_get(x_31, 5); +lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; +x_45 = lean_ctor_get(x_31, 0); +x_46 = lean_ctor_get(x_31, 1); +x_47 = lean_ctor_get(x_31, 3); +x_48 = lean_ctor_get(x_31, 4); +x_49 = lean_ctor_get(x_31, 5); +lean_inc(x_49); lean_inc(x_48); lean_inc(x_47); lean_inc(x_46); lean_inc(x_45); -lean_inc(x_44); lean_dec(x_31); -x_49 = lean_ctor_get(x_32, 0); -lean_inc(x_49); -x_50 = lean_ctor_get(x_32, 1); +x_50 = lean_ctor_get(x_32, 0); lean_inc(x_50); -x_51 = lean_ctor_get(x_32, 3); +x_51 = lean_ctor_get(x_32, 1); lean_inc(x_51); +x_52 = lean_ctor_get(x_32, 3); +lean_inc(x_52); +x_53 = lean_ctor_get(x_32, 4); +lean_inc(x_53); if (lean_is_exclusive(x_32)) { lean_ctor_release(x_32, 0); lean_ctor_release(x_32, 1); lean_ctor_release(x_32, 2); lean_ctor_release(x_32, 3); - x_52 = x_32; + lean_ctor_release(x_32, 4); + x_54 = x_32; } else { lean_dec_ref(x_32); - x_52 = lean_box(0); + x_54 = lean_box(0); } -if (lean_is_scalar(x_52)) { - x_53 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_54)) { + x_55 = lean_alloc_ctor(0, 5, 0); } else { - x_53 = x_52; + x_55 = x_54; } -lean_ctor_set(x_53, 0, x_49); -lean_ctor_set(x_53, 1, x_50); -lean_ctor_set(x_53, 2, x_29); -lean_ctor_set(x_53, 3, x_51); -x_54 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_54, 0, x_44); -lean_ctor_set(x_54, 1, x_45); -lean_ctor_set(x_54, 2, x_53); -lean_ctor_set(x_54, 3, x_46); -lean_ctor_set(x_54, 4, x_47); -lean_ctor_set(x_54, 5, x_48); +lean_ctor_set(x_55, 0, x_50); +lean_ctor_set(x_55, 1, x_51); +lean_ctor_set(x_55, 2, x_29); +lean_ctor_set(x_55, 3, x_52); +lean_ctor_set(x_55, 4, x_53); +x_56 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_56, 0, x_45); +lean_ctor_set(x_56, 1, x_46); +lean_ctor_set(x_56, 2, x_55); +lean_ctor_set(x_56, 3, x_47); +lean_ctor_set(x_56, 4, x_48); +lean_ctor_set(x_56, 5, x_49); if (lean_is_scalar(x_23)) { - x_55 = lean_alloc_ctor(1, 2, 0); + x_57 = lean_alloc_ctor(1, 2, 0); } else { - x_55 = x_23; - lean_ctor_set_tag(x_55, 1); + x_57 = x_23; + lean_ctor_set_tag(x_57, 1); } -lean_ctor_set(x_55, 0, x_33); -lean_ctor_set(x_55, 1, x_54); -return x_55; +lean_ctor_set(x_57, 0, x_33); +lean_ctor_set(x_57, 1, x_56); +return x_57; } } else { -lean_object* x_56; lean_object* x_57; uint8_t x_58; -x_56 = lean_ctor_get(x_31, 2); -lean_inc(x_56); -x_57 = lean_ctor_get(x_30, 0); -lean_inc(x_57); +lean_object* x_58; lean_object* x_59; uint8_t x_60; +x_58 = lean_ctor_get(x_31, 2); +lean_inc(x_58); +x_59 = lean_ctor_get(x_30, 0); +lean_inc(x_59); lean_dec(x_30); -x_58 = !lean_is_exclusive(x_31); -if (x_58 == 0) -{ -lean_object* x_59; uint8_t x_60; -x_59 = lean_ctor_get(x_31, 2); -lean_dec(x_59); -x_60 = !lean_is_exclusive(x_56); +x_60 = !lean_is_exclusive(x_31); if (x_60 == 0) { -lean_object* x_61; lean_object* x_62; -x_61 = lean_ctor_get(x_56, 2); +lean_object* x_61; uint8_t x_62; +x_61 = lean_ctor_get(x_31, 2); lean_dec(x_61); -lean_ctor_set(x_56, 2, x_29); +x_62 = !lean_is_exclusive(x_58); +if (x_62 == 0) +{ +lean_object* x_63; lean_object* x_64; +x_63 = lean_ctor_get(x_58, 2); +lean_dec(x_63); +lean_ctor_set(x_58, 2, x_29); if (lean_is_scalar(x_23)) { - x_62 = lean_alloc_ctor(0, 2, 0); + x_64 = lean_alloc_ctor(0, 2, 0); } else { - x_62 = x_23; + x_64 = x_23; } -lean_ctor_set(x_62, 0, x_57); -lean_ctor_set(x_62, 1, x_31); -return x_62; +lean_ctor_set(x_64, 0, x_59); +lean_ctor_set(x_64, 1, x_31); +return x_64; } else { -lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; -x_63 = lean_ctor_get(x_56, 0); -x_64 = lean_ctor_get(x_56, 1); -x_65 = lean_ctor_get(x_56, 3); +lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; +x_65 = lean_ctor_get(x_58, 0); +x_66 = lean_ctor_get(x_58, 1); +x_67 = lean_ctor_get(x_58, 3); +x_68 = lean_ctor_get(x_58, 4); +lean_inc(x_68); +lean_inc(x_67); +lean_inc(x_66); lean_inc(x_65); -lean_inc(x_64); -lean_inc(x_63); -lean_dec(x_56); -x_66 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_66, 0, x_63); -lean_ctor_set(x_66, 1, x_64); -lean_ctor_set(x_66, 2, x_29); -lean_ctor_set(x_66, 3, x_65); -lean_ctor_set(x_31, 2, x_66); +lean_dec(x_58); +x_69 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_69, 0, x_65); +lean_ctor_set(x_69, 1, x_66); +lean_ctor_set(x_69, 2, x_29); +lean_ctor_set(x_69, 3, x_67); +lean_ctor_set(x_69, 4, x_68); +lean_ctor_set(x_31, 2, x_69); if (lean_is_scalar(x_23)) { - x_67 = lean_alloc_ctor(0, 2, 0); + x_70 = lean_alloc_ctor(0, 2, 0); } else { - x_67 = x_23; + x_70 = x_23; } -lean_ctor_set(x_67, 0, x_57); -lean_ctor_set(x_67, 1, x_31); -return x_67; +lean_ctor_set(x_70, 0, x_59); +lean_ctor_set(x_70, 1, x_31); +return x_70; } } else { -lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; -x_68 = lean_ctor_get(x_31, 0); -x_69 = lean_ctor_get(x_31, 1); -x_70 = lean_ctor_get(x_31, 3); -x_71 = lean_ctor_get(x_31, 4); -x_72 = lean_ctor_get(x_31, 5); +lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; +x_71 = lean_ctor_get(x_31, 0); +x_72 = lean_ctor_get(x_31, 1); +x_73 = lean_ctor_get(x_31, 3); +x_74 = lean_ctor_get(x_31, 4); +x_75 = lean_ctor_get(x_31, 5); +lean_inc(x_75); +lean_inc(x_74); +lean_inc(x_73); lean_inc(x_72); lean_inc(x_71); -lean_inc(x_70); -lean_inc(x_69); -lean_inc(x_68); lean_dec(x_31); -x_73 = lean_ctor_get(x_56, 0); -lean_inc(x_73); -x_74 = lean_ctor_get(x_56, 1); -lean_inc(x_74); -x_75 = lean_ctor_get(x_56, 3); -lean_inc(x_75); -if (lean_is_exclusive(x_56)) { - lean_ctor_release(x_56, 0); - lean_ctor_release(x_56, 1); - lean_ctor_release(x_56, 2); - lean_ctor_release(x_56, 3); - x_76 = x_56; +x_76 = lean_ctor_get(x_58, 0); +lean_inc(x_76); +x_77 = lean_ctor_get(x_58, 1); +lean_inc(x_77); +x_78 = lean_ctor_get(x_58, 3); +lean_inc(x_78); +x_79 = lean_ctor_get(x_58, 4); +lean_inc(x_79); +if (lean_is_exclusive(x_58)) { + lean_ctor_release(x_58, 0); + lean_ctor_release(x_58, 1); + lean_ctor_release(x_58, 2); + lean_ctor_release(x_58, 3); + lean_ctor_release(x_58, 4); + x_80 = x_58; } else { - lean_dec_ref(x_56); - x_76 = lean_box(0); + lean_dec_ref(x_58); + x_80 = lean_box(0); } -if (lean_is_scalar(x_76)) { - x_77 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_80)) { + x_81 = lean_alloc_ctor(0, 5, 0); } else { - x_77 = x_76; + x_81 = x_80; } -lean_ctor_set(x_77, 0, x_73); -lean_ctor_set(x_77, 1, x_74); -lean_ctor_set(x_77, 2, x_29); -lean_ctor_set(x_77, 3, x_75); -x_78 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_78, 0, x_68); -lean_ctor_set(x_78, 1, x_69); -lean_ctor_set(x_78, 2, x_77); -lean_ctor_set(x_78, 3, x_70); -lean_ctor_set(x_78, 4, x_71); -lean_ctor_set(x_78, 5, x_72); +lean_ctor_set(x_81, 0, x_76); +lean_ctor_set(x_81, 1, x_77); +lean_ctor_set(x_81, 2, x_29); +lean_ctor_set(x_81, 3, x_78); +lean_ctor_set(x_81, 4, x_79); +x_82 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_82, 0, x_71); +lean_ctor_set(x_82, 1, x_72); +lean_ctor_set(x_82, 2, x_81); +lean_ctor_set(x_82, 3, x_73); +lean_ctor_set(x_82, 4, x_74); +lean_ctor_set(x_82, 5, x_75); if (lean_is_scalar(x_23)) { - x_79 = lean_alloc_ctor(0, 2, 0); + x_83 = lean_alloc_ctor(0, 2, 0); } else { - x_79 = x_23; + x_83 = x_23; } -lean_ctor_set(x_79, 0, x_57); -lean_ctor_set(x_79, 1, x_78); -return x_79; +lean_ctor_set(x_83, 0, x_59); +lean_ctor_set(x_83, 1, x_82); +return x_83; } } } } else { -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_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; -x_92 = lean_ctor_get(x_24, 0); -x_93 = lean_ctor_get(x_24, 1); -x_94 = lean_ctor_get(x_24, 2); -x_95 = lean_ctor_get(x_24, 3); -lean_inc(x_95); -lean_inc(x_94); -lean_inc(x_93); -lean_inc(x_92); -lean_dec(x_24); -x_129 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_130 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_130, 0, x_92); -lean_ctor_set(x_130, 1, x_93); -lean_ctor_set(x_130, 2, x_129); -lean_ctor_set(x_130, 3, x_95); -lean_ctor_set(x_22, 2, x_130); -lean_inc(x_17); -x_131 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_131, 0, x_25); -lean_ctor_set(x_131, 1, x_17); -x_132 = lean_array_push(x_13, x_131); -x_133 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_133, 0, x_11); -lean_ctor_set(x_133, 1, x_16); -lean_ctor_set(x_133, 2, x_132); -lean_ctor_set(x_133, 3, x_14); -lean_ctor_set(x_133, 4, x_15); -x_134 = lean_apply_3(x_4, x_17, x_133, x_22); -if (lean_obj_tag(x_134) == 0) -{ -lean_object* x_135; lean_object* x_136; lean_object* x_137; -x_135 = lean_ctor_get(x_134, 0); -lean_inc(x_135); -x_136 = lean_ctor_get(x_134, 1); -lean_inc(x_136); -lean_dec(x_134); -x_137 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_137, 0, x_135); -x_96 = x_137; -x_97 = x_136; -goto block_128; -} -else -{ -lean_object* x_138; lean_object* x_139; lean_object* x_140; -x_138 = lean_ctor_get(x_134, 0); -lean_inc(x_138); -x_139 = lean_ctor_get(x_134, 1); -lean_inc(x_139); -lean_dec(x_134); -x_140 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_140, 0, x_138); -x_96 = x_140; -x_97 = x_139; -goto block_128; -} -block_128: -{ -if (lean_obj_tag(x_96) == 0) -{ -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; -x_98 = lean_ctor_get(x_97, 2); -lean_inc(x_98); -x_99 = lean_ctor_get(x_96, 0); -lean_inc(x_99); -lean_dec(x_96); -x_100 = lean_ctor_get(x_97, 0); +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_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; +x_96 = lean_ctor_get(x_24, 0); +x_97 = lean_ctor_get(x_24, 1); +x_98 = lean_ctor_get(x_24, 2); +x_99 = lean_ctor_get(x_24, 3); +x_100 = lean_ctor_get(x_24, 4); lean_inc(x_100); -x_101 = lean_ctor_get(x_97, 1); -lean_inc(x_101); -x_102 = lean_ctor_get(x_97, 3); -lean_inc(x_102); -x_103 = lean_ctor_get(x_97, 4); -lean_inc(x_103); -x_104 = lean_ctor_get(x_97, 5); -lean_inc(x_104); -if (lean_is_exclusive(x_97)) { - lean_ctor_release(x_97, 0); - lean_ctor_release(x_97, 1); - lean_ctor_release(x_97, 2); - lean_ctor_release(x_97, 3); - lean_ctor_release(x_97, 4); - lean_ctor_release(x_97, 5); - x_105 = x_97; -} else { - lean_dec_ref(x_97); - x_105 = lean_box(0); -} -x_106 = lean_ctor_get(x_98, 0); -lean_inc(x_106); -x_107 = lean_ctor_get(x_98, 1); -lean_inc(x_107); -x_108 = lean_ctor_get(x_98, 3); -lean_inc(x_108); -if (lean_is_exclusive(x_98)) { - lean_ctor_release(x_98, 0); - lean_ctor_release(x_98, 1); - lean_ctor_release(x_98, 2); - lean_ctor_release(x_98, 3); - x_109 = x_98; -} else { - lean_dec_ref(x_98); - x_109 = lean_box(0); -} -if (lean_is_scalar(x_109)) { - x_110 = lean_alloc_ctor(0, 4, 0); -} else { - x_110 = x_109; -} -lean_ctor_set(x_110, 0, x_106); -lean_ctor_set(x_110, 1, x_107); -lean_ctor_set(x_110, 2, x_94); -lean_ctor_set(x_110, 3, x_108); -if (lean_is_scalar(x_105)) { - x_111 = lean_alloc_ctor(0, 6, 0); -} else { - x_111 = x_105; -} -lean_ctor_set(x_111, 0, x_100); -lean_ctor_set(x_111, 1, x_101); -lean_ctor_set(x_111, 2, x_110); -lean_ctor_set(x_111, 3, x_102); -lean_ctor_set(x_111, 4, x_103); -lean_ctor_set(x_111, 5, x_104); -if (lean_is_scalar(x_23)) { - x_112 = lean_alloc_ctor(1, 2, 0); -} else { - x_112 = x_23; - lean_ctor_set_tag(x_112, 1); -} -lean_ctor_set(x_112, 0, x_99); -lean_ctor_set(x_112, 1, x_111); -return x_112; -} -else +lean_inc(x_99); +lean_inc(x_98); +lean_inc(x_97); +lean_inc(x_96); +lean_dec(x_24); +x_136 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_137 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_137, 0, x_96); +lean_ctor_set(x_137, 1, x_97); +lean_ctor_set(x_137, 2, x_136); +lean_ctor_set(x_137, 3, x_99); +lean_ctor_set(x_137, 4, x_100); +lean_ctor_set(x_22, 2, x_137); +lean_inc(x_17); +x_138 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_138, 0, x_25); +lean_ctor_set(x_138, 1, x_17); +x_139 = lean_array_push(x_13, x_138); +x_140 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_140, 0, x_11); +lean_ctor_set(x_140, 1, x_16); +lean_ctor_set(x_140, 2, x_139); +lean_ctor_set(x_140, 3, x_14); +lean_ctor_set(x_140, 4, x_15); +x_141 = lean_apply_3(x_4, x_17, x_140, x_22); +if (lean_obj_tag(x_141) == 0) { -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; -x_113 = lean_ctor_get(x_97, 2); -lean_inc(x_113); -x_114 = lean_ctor_get(x_96, 0); -lean_inc(x_114); -lean_dec(x_96); -x_115 = lean_ctor_get(x_97, 0); -lean_inc(x_115); -x_116 = lean_ctor_get(x_97, 1); -lean_inc(x_116); -x_117 = lean_ctor_get(x_97, 3); -lean_inc(x_117); -x_118 = lean_ctor_get(x_97, 4); -lean_inc(x_118); -x_119 = lean_ctor_get(x_97, 5); -lean_inc(x_119); -if (lean_is_exclusive(x_97)) { - lean_ctor_release(x_97, 0); - lean_ctor_release(x_97, 1); - lean_ctor_release(x_97, 2); - lean_ctor_release(x_97, 3); - lean_ctor_release(x_97, 4); - lean_ctor_release(x_97, 5); - x_120 = x_97; -} else { - lean_dec_ref(x_97); - x_120 = lean_box(0); -} -x_121 = lean_ctor_get(x_113, 0); -lean_inc(x_121); -x_122 = lean_ctor_get(x_113, 1); -lean_inc(x_122); -x_123 = lean_ctor_get(x_113, 3); -lean_inc(x_123); -if (lean_is_exclusive(x_113)) { - lean_ctor_release(x_113, 0); - lean_ctor_release(x_113, 1); - lean_ctor_release(x_113, 2); - lean_ctor_release(x_113, 3); - x_124 = x_113; -} else { - lean_dec_ref(x_113); - x_124 = lean_box(0); -} -if (lean_is_scalar(x_124)) { - x_125 = lean_alloc_ctor(0, 4, 0); -} else { - x_125 = x_124; -} -lean_ctor_set(x_125, 0, x_121); -lean_ctor_set(x_125, 1, x_122); -lean_ctor_set(x_125, 2, x_94); -lean_ctor_set(x_125, 3, x_123); -if (lean_is_scalar(x_120)) { - x_126 = lean_alloc_ctor(0, 6, 0); -} else { - x_126 = x_120; -} -lean_ctor_set(x_126, 0, x_115); -lean_ctor_set(x_126, 1, x_116); -lean_ctor_set(x_126, 2, x_125); -lean_ctor_set(x_126, 3, x_117); -lean_ctor_set(x_126, 4, x_118); -lean_ctor_set(x_126, 5, x_119); -if (lean_is_scalar(x_23)) { - x_127 = lean_alloc_ctor(0, 2, 0); -} else { - x_127 = x_23; -} -lean_ctor_set(x_127, 0, x_114); -lean_ctor_set(x_127, 1, x_126); -return x_127; -} -} -} -} -else -{ -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_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; -x_141 = lean_ctor_get(x_22, 0); -x_142 = lean_ctor_get(x_22, 1); -x_143 = lean_ctor_get(x_22, 3); -x_144 = lean_ctor_get(x_22, 4); -x_145 = lean_ctor_get(x_22, 5); -lean_inc(x_145); -lean_inc(x_144); -lean_inc(x_143); +lean_object* x_142; lean_object* x_143; lean_object* x_144; +x_142 = lean_ctor_get(x_141, 0); lean_inc(x_142); -lean_inc(x_141); -lean_dec(x_22); -x_146 = lean_ctor_get(x_24, 0); +x_143 = lean_ctor_get(x_141, 1); +lean_inc(x_143); +lean_dec(x_141); +x_144 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_144, 0, x_142); +x_101 = x_144; +x_102 = x_143; +goto block_135; +} +else +{ +lean_object* x_145; lean_object* x_146; lean_object* x_147; +x_145 = lean_ctor_get(x_141, 0); +lean_inc(x_145); +x_146 = lean_ctor_get(x_141, 1); lean_inc(x_146); -x_147 = lean_ctor_get(x_24, 1); -lean_inc(x_147); -x_148 = lean_ctor_get(x_24, 2); -lean_inc(x_148); -x_149 = lean_ctor_get(x_24, 3); +lean_dec(x_141); +x_147 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_147, 0, x_145); +x_101 = x_147; +x_102 = x_146; +goto block_135; +} +block_135: +{ +if (lean_obj_tag(x_101) == 0) +{ +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; +x_103 = lean_ctor_get(x_102, 2); +lean_inc(x_103); +x_104 = lean_ctor_get(x_101, 0); +lean_inc(x_104); +lean_dec(x_101); +x_105 = lean_ctor_get(x_102, 0); +lean_inc(x_105); +x_106 = lean_ctor_get(x_102, 1); +lean_inc(x_106); +x_107 = lean_ctor_get(x_102, 3); +lean_inc(x_107); +x_108 = lean_ctor_get(x_102, 4); +lean_inc(x_108); +x_109 = lean_ctor_get(x_102, 5); +lean_inc(x_109); +if (lean_is_exclusive(x_102)) { + lean_ctor_release(x_102, 0); + lean_ctor_release(x_102, 1); + lean_ctor_release(x_102, 2); + lean_ctor_release(x_102, 3); + lean_ctor_release(x_102, 4); + lean_ctor_release(x_102, 5); + x_110 = x_102; +} else { + lean_dec_ref(x_102); + x_110 = lean_box(0); +} +x_111 = lean_ctor_get(x_103, 0); +lean_inc(x_111); +x_112 = lean_ctor_get(x_103, 1); +lean_inc(x_112); +x_113 = lean_ctor_get(x_103, 3); +lean_inc(x_113); +x_114 = lean_ctor_get(x_103, 4); +lean_inc(x_114); +if (lean_is_exclusive(x_103)) { + lean_ctor_release(x_103, 0); + lean_ctor_release(x_103, 1); + lean_ctor_release(x_103, 2); + lean_ctor_release(x_103, 3); + lean_ctor_release(x_103, 4); + x_115 = x_103; +} else { + lean_dec_ref(x_103); + x_115 = lean_box(0); +} +if (lean_is_scalar(x_115)) { + x_116 = lean_alloc_ctor(0, 5, 0); +} else { + x_116 = x_115; +} +lean_ctor_set(x_116, 0, x_111); +lean_ctor_set(x_116, 1, x_112); +lean_ctor_set(x_116, 2, x_98); +lean_ctor_set(x_116, 3, x_113); +lean_ctor_set(x_116, 4, x_114); +if (lean_is_scalar(x_110)) { + x_117 = lean_alloc_ctor(0, 6, 0); +} else { + x_117 = x_110; +} +lean_ctor_set(x_117, 0, x_105); +lean_ctor_set(x_117, 1, x_106); +lean_ctor_set(x_117, 2, x_116); +lean_ctor_set(x_117, 3, x_107); +lean_ctor_set(x_117, 4, x_108); +lean_ctor_set(x_117, 5, x_109); +if (lean_is_scalar(x_23)) { + x_118 = lean_alloc_ctor(1, 2, 0); +} else { + x_118 = x_23; + lean_ctor_set_tag(x_118, 1); +} +lean_ctor_set(x_118, 0, x_104); +lean_ctor_set(x_118, 1, x_117); +return x_118; +} +else +{ +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; +x_119 = lean_ctor_get(x_102, 2); +lean_inc(x_119); +x_120 = lean_ctor_get(x_101, 0); +lean_inc(x_120); +lean_dec(x_101); +x_121 = lean_ctor_get(x_102, 0); +lean_inc(x_121); +x_122 = lean_ctor_get(x_102, 1); +lean_inc(x_122); +x_123 = lean_ctor_get(x_102, 3); +lean_inc(x_123); +x_124 = lean_ctor_get(x_102, 4); +lean_inc(x_124); +x_125 = lean_ctor_get(x_102, 5); +lean_inc(x_125); +if (lean_is_exclusive(x_102)) { + lean_ctor_release(x_102, 0); + lean_ctor_release(x_102, 1); + lean_ctor_release(x_102, 2); + lean_ctor_release(x_102, 3); + lean_ctor_release(x_102, 4); + lean_ctor_release(x_102, 5); + x_126 = x_102; +} else { + lean_dec_ref(x_102); + x_126 = lean_box(0); +} +x_127 = lean_ctor_get(x_119, 0); +lean_inc(x_127); +x_128 = lean_ctor_get(x_119, 1); +lean_inc(x_128); +x_129 = lean_ctor_get(x_119, 3); +lean_inc(x_129); +x_130 = lean_ctor_get(x_119, 4); +lean_inc(x_130); +if (lean_is_exclusive(x_119)) { + lean_ctor_release(x_119, 0); + lean_ctor_release(x_119, 1); + lean_ctor_release(x_119, 2); + lean_ctor_release(x_119, 3); + lean_ctor_release(x_119, 4); + x_131 = x_119; +} else { + lean_dec_ref(x_119); + x_131 = lean_box(0); +} +if (lean_is_scalar(x_131)) { + x_132 = lean_alloc_ctor(0, 5, 0); +} else { + x_132 = x_131; +} +lean_ctor_set(x_132, 0, x_127); +lean_ctor_set(x_132, 1, x_128); +lean_ctor_set(x_132, 2, x_98); +lean_ctor_set(x_132, 3, x_129); +lean_ctor_set(x_132, 4, x_130); +if (lean_is_scalar(x_126)) { + x_133 = lean_alloc_ctor(0, 6, 0); +} else { + x_133 = x_126; +} +lean_ctor_set(x_133, 0, x_121); +lean_ctor_set(x_133, 1, x_122); +lean_ctor_set(x_133, 2, x_132); +lean_ctor_set(x_133, 3, x_123); +lean_ctor_set(x_133, 4, x_124); +lean_ctor_set(x_133, 5, x_125); +if (lean_is_scalar(x_23)) { + x_134 = lean_alloc_ctor(0, 2, 0); +} else { + x_134 = x_23; +} +lean_ctor_set(x_134, 0, x_120); +lean_ctor_set(x_134, 1, x_133); +return x_134; +} +} +} +} +else +{ +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_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; +x_148 = lean_ctor_get(x_22, 0); +x_149 = lean_ctor_get(x_22, 1); +x_150 = lean_ctor_get(x_22, 3); +x_151 = lean_ctor_get(x_22, 4); +x_152 = lean_ctor_get(x_22, 5); +lean_inc(x_152); +lean_inc(x_151); +lean_inc(x_150); lean_inc(x_149); +lean_inc(x_148); +lean_dec(x_22); +x_153 = lean_ctor_get(x_24, 0); +lean_inc(x_153); +x_154 = lean_ctor_get(x_24, 1); +lean_inc(x_154); +x_155 = lean_ctor_get(x_24, 2); +lean_inc(x_155); +x_156 = lean_ctor_get(x_24, 3); +lean_inc(x_156); +x_157 = lean_ctor_get(x_24, 4); +lean_inc(x_157); if (lean_is_exclusive(x_24)) { lean_ctor_release(x_24, 0); lean_ctor_release(x_24, 1); lean_ctor_release(x_24, 2); lean_ctor_release(x_24, 3); - x_150 = x_24; + lean_ctor_release(x_24, 4); + x_158 = x_24; } else { lean_dec_ref(x_24); - x_150 = lean_box(0); + x_158 = lean_box(0); } -x_184 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_150)) { - x_185 = lean_alloc_ctor(0, 4, 0); +x_194 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_158)) { + x_195 = lean_alloc_ctor(0, 5, 0); } else { - x_185 = x_150; + x_195 = x_158; } -lean_ctor_set(x_185, 0, x_146); -lean_ctor_set(x_185, 1, x_147); -lean_ctor_set(x_185, 2, x_184); -lean_ctor_set(x_185, 3, x_149); -x_186 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_186, 0, x_141); -lean_ctor_set(x_186, 1, x_142); -lean_ctor_set(x_186, 2, x_185); -lean_ctor_set(x_186, 3, x_143); -lean_ctor_set(x_186, 4, x_144); -lean_ctor_set(x_186, 5, x_145); +lean_ctor_set(x_195, 0, x_153); +lean_ctor_set(x_195, 1, x_154); +lean_ctor_set(x_195, 2, x_194); +lean_ctor_set(x_195, 3, x_156); +lean_ctor_set(x_195, 4, x_157); +x_196 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_196, 0, x_148); +lean_ctor_set(x_196, 1, x_149); +lean_ctor_set(x_196, 2, x_195); +lean_ctor_set(x_196, 3, x_150); +lean_ctor_set(x_196, 4, x_151); +lean_ctor_set(x_196, 5, x_152); lean_inc(x_17); -x_187 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_187, 0, x_25); -lean_ctor_set(x_187, 1, x_17); -x_188 = lean_array_push(x_13, x_187); -x_189 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_189, 0, x_11); -lean_ctor_set(x_189, 1, x_16); -lean_ctor_set(x_189, 2, x_188); -lean_ctor_set(x_189, 3, x_14); -lean_ctor_set(x_189, 4, x_15); -x_190 = lean_apply_3(x_4, x_17, x_189, x_186); -if (lean_obj_tag(x_190) == 0) +x_197 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_197, 0, x_25); +lean_ctor_set(x_197, 1, x_17); +x_198 = lean_array_push(x_13, x_197); +x_199 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_199, 0, x_11); +lean_ctor_set(x_199, 1, x_16); +lean_ctor_set(x_199, 2, x_198); +lean_ctor_set(x_199, 3, x_14); +lean_ctor_set(x_199, 4, x_15); +x_200 = lean_apply_3(x_4, x_17, x_199, x_196); +if (lean_obj_tag(x_200) == 0) { -lean_object* x_191; lean_object* x_192; lean_object* x_193; -x_191 = lean_ctor_get(x_190, 0); -lean_inc(x_191); -x_192 = lean_ctor_get(x_190, 1); -lean_inc(x_192); -lean_dec(x_190); -x_193 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_193, 0, x_191); -x_151 = x_193; -x_152 = x_192; -goto block_183; +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); +x_203 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_203, 0, x_201); +x_159 = x_203; +x_160 = x_202; +goto block_193; } else { -lean_object* x_194; lean_object* x_195; lean_object* x_196; -x_194 = lean_ctor_get(x_190, 0); -lean_inc(x_194); -x_195 = lean_ctor_get(x_190, 1); -lean_inc(x_195); -lean_dec(x_190); -x_196 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_196, 0, x_194); -x_151 = x_196; -x_152 = x_195; -goto block_183; +lean_object* x_204; lean_object* x_205; lean_object* x_206; +x_204 = lean_ctor_get(x_200, 0); +lean_inc(x_204); +x_205 = lean_ctor_get(x_200, 1); +lean_inc(x_205); +lean_dec(x_200); +x_206 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_206, 0, x_204); +x_159 = x_206; +x_160 = x_205; +goto block_193; } -block_183: +block_193: { -if (lean_obj_tag(x_151) == 0) +if (lean_obj_tag(x_159) == 0) { -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; -x_153 = lean_ctor_get(x_152, 2); -lean_inc(x_153); -x_154 = lean_ctor_get(x_151, 0); -lean_inc(x_154); -lean_dec(x_151); -x_155 = lean_ctor_get(x_152, 0); -lean_inc(x_155); -x_156 = lean_ctor_get(x_152, 1); -lean_inc(x_156); -x_157 = lean_ctor_get(x_152, 3); -lean_inc(x_157); -x_158 = lean_ctor_get(x_152, 4); -lean_inc(x_158); -x_159 = lean_ctor_get(x_152, 5); -lean_inc(x_159); -if (lean_is_exclusive(x_152)) { - lean_ctor_release(x_152, 0); - lean_ctor_release(x_152, 1); - lean_ctor_release(x_152, 2); - lean_ctor_release(x_152, 3); - lean_ctor_release(x_152, 4); - lean_ctor_release(x_152, 5); - x_160 = x_152; -} else { - lean_dec_ref(x_152); - x_160 = lean_box(0); -} -x_161 = lean_ctor_get(x_153, 0); +lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; lean_object* x_173; lean_object* x_174; lean_object* x_175; lean_object* x_176; +x_161 = lean_ctor_get(x_160, 2); lean_inc(x_161); -x_162 = lean_ctor_get(x_153, 1); +x_162 = lean_ctor_get(x_159, 0); lean_inc(x_162); -x_163 = lean_ctor_get(x_153, 3); +lean_dec(x_159); +x_163 = lean_ctor_get(x_160, 0); lean_inc(x_163); -if (lean_is_exclusive(x_153)) { - lean_ctor_release(x_153, 0); - lean_ctor_release(x_153, 1); - lean_ctor_release(x_153, 2); - lean_ctor_release(x_153, 3); - x_164 = x_153; +x_164 = lean_ctor_get(x_160, 1); +lean_inc(x_164); +x_165 = lean_ctor_get(x_160, 3); +lean_inc(x_165); +x_166 = lean_ctor_get(x_160, 4); +lean_inc(x_166); +x_167 = lean_ctor_get(x_160, 5); +lean_inc(x_167); +if (lean_is_exclusive(x_160)) { + lean_ctor_release(x_160, 0); + lean_ctor_release(x_160, 1); + lean_ctor_release(x_160, 2); + lean_ctor_release(x_160, 3); + lean_ctor_release(x_160, 4); + lean_ctor_release(x_160, 5); + x_168 = x_160; } else { - lean_dec_ref(x_153); - x_164 = lean_box(0); + lean_dec_ref(x_160); + x_168 = lean_box(0); } -if (lean_is_scalar(x_164)) { - x_165 = lean_alloc_ctor(0, 4, 0); -} else { - x_165 = x_164; -} -lean_ctor_set(x_165, 0, x_161); -lean_ctor_set(x_165, 1, x_162); -lean_ctor_set(x_165, 2, x_148); -lean_ctor_set(x_165, 3, x_163); -if (lean_is_scalar(x_160)) { - x_166 = lean_alloc_ctor(0, 6, 0); -} else { - x_166 = x_160; -} -lean_ctor_set(x_166, 0, x_155); -lean_ctor_set(x_166, 1, x_156); -lean_ctor_set(x_166, 2, x_165); -lean_ctor_set(x_166, 3, x_157); -lean_ctor_set(x_166, 4, x_158); -lean_ctor_set(x_166, 5, x_159); -if (lean_is_scalar(x_23)) { - x_167 = lean_alloc_ctor(1, 2, 0); -} else { - x_167 = x_23; - lean_ctor_set_tag(x_167, 1); -} -lean_ctor_set(x_167, 0, x_154); -lean_ctor_set(x_167, 1, x_166); -return x_167; -} -else -{ -lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; lean_object* x_173; lean_object* x_174; lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; -x_168 = lean_ctor_get(x_152, 2); -lean_inc(x_168); -x_169 = lean_ctor_get(x_151, 0); +x_169 = lean_ctor_get(x_161, 0); lean_inc(x_169); -lean_dec(x_151); -x_170 = lean_ctor_get(x_152, 0); +x_170 = lean_ctor_get(x_161, 1); lean_inc(x_170); -x_171 = lean_ctor_get(x_152, 1); +x_171 = lean_ctor_get(x_161, 3); lean_inc(x_171); -x_172 = lean_ctor_get(x_152, 3); +x_172 = lean_ctor_get(x_161, 4); lean_inc(x_172); -x_173 = lean_ctor_get(x_152, 4); -lean_inc(x_173); -x_174 = lean_ctor_get(x_152, 5); -lean_inc(x_174); -if (lean_is_exclusive(x_152)) { - lean_ctor_release(x_152, 0); - lean_ctor_release(x_152, 1); - lean_ctor_release(x_152, 2); - lean_ctor_release(x_152, 3); - lean_ctor_release(x_152, 4); - lean_ctor_release(x_152, 5); - x_175 = x_152; +if (lean_is_exclusive(x_161)) { + lean_ctor_release(x_161, 0); + lean_ctor_release(x_161, 1); + lean_ctor_release(x_161, 2); + lean_ctor_release(x_161, 3); + lean_ctor_release(x_161, 4); + x_173 = x_161; } else { - lean_dec_ref(x_152); - x_175 = lean_box(0); + lean_dec_ref(x_161); + x_173 = lean_box(0); } -x_176 = lean_ctor_get(x_168, 0); -lean_inc(x_176); -x_177 = lean_ctor_get(x_168, 1); -lean_inc(x_177); -x_178 = lean_ctor_get(x_168, 3); -lean_inc(x_178); -if (lean_is_exclusive(x_168)) { - lean_ctor_release(x_168, 0); - lean_ctor_release(x_168, 1); - lean_ctor_release(x_168, 2); - lean_ctor_release(x_168, 3); - x_179 = x_168; +if (lean_is_scalar(x_173)) { + x_174 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_168); - x_179 = lean_box(0); + x_174 = x_173; } -if (lean_is_scalar(x_179)) { - x_180 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_174, 0, x_169); +lean_ctor_set(x_174, 1, x_170); +lean_ctor_set(x_174, 2, x_155); +lean_ctor_set(x_174, 3, x_171); +lean_ctor_set(x_174, 4, x_172); +if (lean_is_scalar(x_168)) { + x_175 = lean_alloc_ctor(0, 6, 0); } else { - x_180 = x_179; + x_175 = x_168; } -lean_ctor_set(x_180, 0, x_176); -lean_ctor_set(x_180, 1, x_177); -lean_ctor_set(x_180, 2, x_148); -lean_ctor_set(x_180, 3, x_178); -if (lean_is_scalar(x_175)) { - x_181 = lean_alloc_ctor(0, 6, 0); -} else { - x_181 = x_175; -} -lean_ctor_set(x_181, 0, x_170); -lean_ctor_set(x_181, 1, x_171); -lean_ctor_set(x_181, 2, x_180); -lean_ctor_set(x_181, 3, x_172); -lean_ctor_set(x_181, 4, x_173); -lean_ctor_set(x_181, 5, x_174); +lean_ctor_set(x_175, 0, x_163); +lean_ctor_set(x_175, 1, x_164); +lean_ctor_set(x_175, 2, x_174); +lean_ctor_set(x_175, 3, x_165); +lean_ctor_set(x_175, 4, x_166); +lean_ctor_set(x_175, 5, x_167); if (lean_is_scalar(x_23)) { - x_182 = lean_alloc_ctor(0, 2, 0); + x_176 = lean_alloc_ctor(1, 2, 0); } else { - x_182 = x_23; + x_176 = x_23; + lean_ctor_set_tag(x_176, 1); } -lean_ctor_set(x_182, 0, x_169); -lean_ctor_set(x_182, 1, x_181); -return x_182; +lean_ctor_set(x_176, 0, x_162); +lean_ctor_set(x_176, 1, x_175); +return x_176; +} +else +{ +lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; 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; +x_177 = lean_ctor_get(x_160, 2); +lean_inc(x_177); +x_178 = lean_ctor_get(x_159, 0); +lean_inc(x_178); +lean_dec(x_159); +x_179 = lean_ctor_get(x_160, 0); +lean_inc(x_179); +x_180 = lean_ctor_get(x_160, 1); +lean_inc(x_180); +x_181 = lean_ctor_get(x_160, 3); +lean_inc(x_181); +x_182 = lean_ctor_get(x_160, 4); +lean_inc(x_182); +x_183 = lean_ctor_get(x_160, 5); +lean_inc(x_183); +if (lean_is_exclusive(x_160)) { + lean_ctor_release(x_160, 0); + lean_ctor_release(x_160, 1); + lean_ctor_release(x_160, 2); + lean_ctor_release(x_160, 3); + lean_ctor_release(x_160, 4); + lean_ctor_release(x_160, 5); + x_184 = x_160; +} else { + lean_dec_ref(x_160); + x_184 = lean_box(0); +} +x_185 = lean_ctor_get(x_177, 0); +lean_inc(x_185); +x_186 = lean_ctor_get(x_177, 1); +lean_inc(x_186); +x_187 = lean_ctor_get(x_177, 3); +lean_inc(x_187); +x_188 = lean_ctor_get(x_177, 4); +lean_inc(x_188); +if (lean_is_exclusive(x_177)) { + lean_ctor_release(x_177, 0); + lean_ctor_release(x_177, 1); + lean_ctor_release(x_177, 2); + lean_ctor_release(x_177, 3); + lean_ctor_release(x_177, 4); + x_189 = x_177; +} else { + lean_dec_ref(x_177); + x_189 = lean_box(0); +} +if (lean_is_scalar(x_189)) { + x_190 = lean_alloc_ctor(0, 5, 0); +} else { + x_190 = x_189; +} +lean_ctor_set(x_190, 0, x_185); +lean_ctor_set(x_190, 1, x_186); +lean_ctor_set(x_190, 2, x_155); +lean_ctor_set(x_190, 3, x_187); +lean_ctor_set(x_190, 4, x_188); +if (lean_is_scalar(x_184)) { + x_191 = lean_alloc_ctor(0, 6, 0); +} else { + x_191 = x_184; +} +lean_ctor_set(x_191, 0, x_179); +lean_ctor_set(x_191, 1, x_180); +lean_ctor_set(x_191, 2, x_190); +lean_ctor_set(x_191, 3, x_181); +lean_ctor_set(x_191, 4, x_182); +lean_ctor_set(x_191, 5, x_183); +if (lean_is_scalar(x_23)) { + x_192 = lean_alloc_ctor(0, 2, 0); +} else { + x_192 = x_23; +} +lean_ctor_set(x_192, 0, x_178); +lean_ctor_set(x_192, 1, x_191); +return x_192; } } } @@ -42293,7 +43632,7 @@ return x_182; } else { -uint8_t x_197; +uint8_t x_207; lean_dec(x_5); lean_dec(x_17); lean_dec(x_16); @@ -42302,383 +43641,395 @@ lean_dec(x_14); lean_dec(x_13); lean_dec(x_11); lean_dec(x_4); -x_197 = !lean_is_exclusive(x_18); -if (x_197 == 0) +x_207 = !lean_is_exclusive(x_18); +if (x_207 == 0) { return x_18; } else { -lean_object* x_198; lean_object* x_199; lean_object* x_200; -x_198 = lean_ctor_get(x_18, 0); -x_199 = lean_ctor_get(x_18, 1); -lean_inc(x_199); -lean_inc(x_198); +lean_object* x_208; lean_object* x_209; lean_object* x_210; +x_208 = lean_ctor_get(x_18, 0); +x_209 = lean_ctor_get(x_18, 1); +lean_inc(x_209); +lean_inc(x_208); lean_dec(x_18); -x_200 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_200, 0, x_198); -lean_ctor_set(x_200, 1, x_199); -return x_200; +x_210 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_210, 0, x_208); +lean_ctor_set(x_210, 1, x_209); +return x_210; } } } else { -lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; -x_201 = lean_ctor_get(x_5, 0); -x_202 = lean_ctor_get(x_5, 1); -x_203 = lean_ctor_get(x_5, 2); -x_204 = lean_ctor_get(x_5, 3); -x_205 = lean_ctor_get(x_5, 4); -lean_inc(x_205); -lean_inc(x_204); -lean_inc(x_203); -lean_inc(x_202); -lean_inc(x_201); +lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; +x_211 = lean_ctor_get(x_5, 0); +x_212 = lean_ctor_get(x_5, 1); +x_213 = lean_ctor_get(x_5, 2); +x_214 = lean_ctor_get(x_5, 3); +x_215 = lean_ctor_get(x_5, 4); +lean_inc(x_215); +lean_inc(x_214); +lean_inc(x_213); +lean_inc(x_212); +lean_inc(x_211); lean_dec(x_5); lean_inc(x_2); lean_inc(x_8); -x_206 = lean_local_ctx_mk_let_decl(x_202, x_8, x_1, x_2, x_3); -x_207 = l_Lean_mkFVar(x_8); -lean_inc(x_205); -lean_inc(x_204); -lean_inc(x_203); -lean_inc(x_206); -lean_inc(x_201); -x_208 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_208, 0, x_201); -lean_ctor_set(x_208, 1, x_206); -lean_ctor_set(x_208, 2, x_203); -lean_ctor_set(x_208, 3, x_204); -lean_ctor_set(x_208, 4, x_205); -lean_inc(x_208); -x_209 = l_Lean_Meta_isClass(x_2, x_208, x_9); -if (lean_obj_tag(x_209) == 0) -{ -lean_object* x_210; -x_210 = lean_ctor_get(x_209, 0); -lean_inc(x_210); -if (lean_obj_tag(x_210) == 0) -{ -lean_object* x_211; lean_object* x_212; -lean_dec(x_206); -lean_dec(x_205); -lean_dec(x_204); -lean_dec(x_203); -lean_dec(x_201); -x_211 = lean_ctor_get(x_209, 1); -lean_inc(x_211); -lean_dec(x_209); -x_212 = lean_apply_3(x_4, x_207, x_208, x_211); -return x_212; -} -else -{ -lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; lean_object* x_224; lean_object* x_225; lean_object* x_226; lean_object* x_227; lean_object* x_228; lean_object* x_229; 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_dec(x_208); -x_213 = lean_ctor_get(x_209, 1); -lean_inc(x_213); -if (lean_is_exclusive(x_209)) { - lean_ctor_release(x_209, 0); - lean_ctor_release(x_209, 1); - x_214 = x_209; -} else { - lean_dec_ref(x_209); - x_214 = lean_box(0); -} -x_215 = lean_ctor_get(x_213, 2); +x_216 = lean_local_ctx_mk_let_decl(x_212, x_8, x_1, x_2, x_3); +x_217 = l_Lean_mkFVar(x_8); lean_inc(x_215); -x_216 = lean_ctor_get(x_210, 0); +lean_inc(x_214); +lean_inc(x_213); lean_inc(x_216); -lean_dec(x_210); -x_217 = lean_ctor_get(x_213, 0); -lean_inc(x_217); -x_218 = lean_ctor_get(x_213, 1); +lean_inc(x_211); +x_218 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_218, 0, x_211); +lean_ctor_set(x_218, 1, x_216); +lean_ctor_set(x_218, 2, x_213); +lean_ctor_set(x_218, 3, x_214); +lean_ctor_set(x_218, 4, x_215); lean_inc(x_218); -x_219 = lean_ctor_get(x_213, 3); -lean_inc(x_219); -x_220 = lean_ctor_get(x_213, 4); +x_219 = l_Lean_Meta_isClass(x_2, x_218, x_9); +if (lean_obj_tag(x_219) == 0) +{ +lean_object* x_220; +x_220 = lean_ctor_get(x_219, 0); lean_inc(x_220); -x_221 = lean_ctor_get(x_213, 5); +if (lean_obj_tag(x_220) == 0) +{ +lean_object* x_221; lean_object* x_222; +lean_dec(x_216); +lean_dec(x_215); +lean_dec(x_214); +lean_dec(x_213); +lean_dec(x_211); +x_221 = lean_ctor_get(x_219, 1); lean_inc(x_221); -if (lean_is_exclusive(x_213)) { - lean_ctor_release(x_213, 0); - lean_ctor_release(x_213, 1); - lean_ctor_release(x_213, 2); - lean_ctor_release(x_213, 3); - lean_ctor_release(x_213, 4); - lean_ctor_release(x_213, 5); - x_222 = x_213; -} else { - lean_dec_ref(x_213); - x_222 = lean_box(0); +lean_dec(x_219); +x_222 = lean_apply_3(x_4, x_217, x_218, x_221); +return x_222; } -x_223 = lean_ctor_get(x_215, 0); +else +{ +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; lean_object* x_231; lean_object* x_232; lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_object* x_236; lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_274; lean_object* x_275; lean_object* x_276; lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; +lean_dec(x_218); +x_223 = lean_ctor_get(x_219, 1); lean_inc(x_223); -x_224 = lean_ctor_get(x_215, 1); -lean_inc(x_224); -x_225 = lean_ctor_get(x_215, 2); +if (lean_is_exclusive(x_219)) { + lean_ctor_release(x_219, 0); + lean_ctor_release(x_219, 1); + x_224 = x_219; +} else { + lean_dec_ref(x_219); + x_224 = lean_box(0); +} +x_225 = lean_ctor_get(x_223, 2); lean_inc(x_225); -x_226 = lean_ctor_get(x_215, 3); +x_226 = lean_ctor_get(x_220, 0); lean_inc(x_226); -if (lean_is_exclusive(x_215)) { - lean_ctor_release(x_215, 0); - lean_ctor_release(x_215, 1); - lean_ctor_release(x_215, 2); - lean_ctor_release(x_215, 3); - x_227 = x_215; -} else { - lean_dec_ref(x_215); - x_227 = lean_box(0); -} -x_261 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_227)) { - x_262 = lean_alloc_ctor(0, 4, 0); -} else { - x_262 = x_227; -} -lean_ctor_set(x_262, 0, x_223); -lean_ctor_set(x_262, 1, x_224); -lean_ctor_set(x_262, 2, x_261); -lean_ctor_set(x_262, 3, x_226); -if (lean_is_scalar(x_222)) { - x_263 = lean_alloc_ctor(0, 6, 0); -} else { - x_263 = x_222; -} -lean_ctor_set(x_263, 0, x_217); -lean_ctor_set(x_263, 1, x_218); -lean_ctor_set(x_263, 2, x_262); -lean_ctor_set(x_263, 3, x_219); -lean_ctor_set(x_263, 4, x_220); -lean_ctor_set(x_263, 5, x_221); -lean_inc(x_207); -x_264 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_264, 0, x_216); -lean_ctor_set(x_264, 1, x_207); -x_265 = lean_array_push(x_203, x_264); -x_266 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_266, 0, x_201); -lean_ctor_set(x_266, 1, x_206); -lean_ctor_set(x_266, 2, x_265); -lean_ctor_set(x_266, 3, x_204); -lean_ctor_set(x_266, 4, x_205); -x_267 = lean_apply_3(x_4, x_207, x_266, x_263); -if (lean_obj_tag(x_267) == 0) -{ -lean_object* x_268; lean_object* x_269; lean_object* x_270; -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_270 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_270, 0, x_268); -x_228 = x_270; -x_229 = x_269; -goto block_260; -} -else -{ -lean_object* x_271; lean_object* x_272; lean_object* x_273; -x_271 = lean_ctor_get(x_267, 0); -lean_inc(x_271); -x_272 = lean_ctor_get(x_267, 1); -lean_inc(x_272); -lean_dec(x_267); -x_273 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_273, 0, x_271); -x_228 = x_273; -x_229 = x_272; -goto block_260; -} -block_260: -{ -if (lean_obj_tag(x_228) == 0) -{ -lean_object* x_230; lean_object* x_231; lean_object* x_232; lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_object* x_236; lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; lean_object* x_242; lean_object* x_243; lean_object* x_244; -x_230 = lean_ctor_get(x_229, 2); +lean_dec(x_220); +x_227 = lean_ctor_get(x_223, 0); +lean_inc(x_227); +x_228 = lean_ctor_get(x_223, 1); +lean_inc(x_228); +x_229 = lean_ctor_get(x_223, 3); +lean_inc(x_229); +x_230 = lean_ctor_get(x_223, 4); lean_inc(x_230); -x_231 = lean_ctor_get(x_228, 0); +x_231 = lean_ctor_get(x_223, 5); lean_inc(x_231); -lean_dec(x_228); -x_232 = lean_ctor_get(x_229, 0); -lean_inc(x_232); -x_233 = lean_ctor_get(x_229, 1); +if (lean_is_exclusive(x_223)) { + lean_ctor_release(x_223, 0); + lean_ctor_release(x_223, 1); + lean_ctor_release(x_223, 2); + lean_ctor_release(x_223, 3); + lean_ctor_release(x_223, 4); + lean_ctor_release(x_223, 5); + x_232 = x_223; +} else { + lean_dec_ref(x_223); + x_232 = lean_box(0); +} +x_233 = lean_ctor_get(x_225, 0); lean_inc(x_233); -x_234 = lean_ctor_get(x_229, 3); +x_234 = lean_ctor_get(x_225, 1); lean_inc(x_234); -x_235 = lean_ctor_get(x_229, 4); +x_235 = lean_ctor_get(x_225, 2); lean_inc(x_235); -x_236 = lean_ctor_get(x_229, 5); +x_236 = lean_ctor_get(x_225, 3); lean_inc(x_236); -if (lean_is_exclusive(x_229)) { - lean_ctor_release(x_229, 0); - lean_ctor_release(x_229, 1); - lean_ctor_release(x_229, 2); - lean_ctor_release(x_229, 3); - lean_ctor_release(x_229, 4); - lean_ctor_release(x_229, 5); - x_237 = x_229; +x_237 = lean_ctor_get(x_225, 4); +lean_inc(x_237); +if (lean_is_exclusive(x_225)) { + lean_ctor_release(x_225, 0); + lean_ctor_release(x_225, 1); + lean_ctor_release(x_225, 2); + lean_ctor_release(x_225, 3); + lean_ctor_release(x_225, 4); + x_238 = x_225; } else { - lean_dec_ref(x_229); - x_237 = lean_box(0); + lean_dec_ref(x_225); + x_238 = lean_box(0); } -x_238 = lean_ctor_get(x_230, 0); -lean_inc(x_238); -x_239 = lean_ctor_get(x_230, 1); -lean_inc(x_239); -x_240 = lean_ctor_get(x_230, 3); -lean_inc(x_240); -if (lean_is_exclusive(x_230)) { - lean_ctor_release(x_230, 0); - lean_ctor_release(x_230, 1); - lean_ctor_release(x_230, 2); - lean_ctor_release(x_230, 3); - x_241 = x_230; +x_274 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_238)) { + x_275 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_230); - x_241 = lean_box(0); + x_275 = x_238; } -if (lean_is_scalar(x_241)) { - x_242 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_275, 0, x_233); +lean_ctor_set(x_275, 1, x_234); +lean_ctor_set(x_275, 2, x_274); +lean_ctor_set(x_275, 3, x_236); +lean_ctor_set(x_275, 4, x_237); +if (lean_is_scalar(x_232)) { + x_276 = lean_alloc_ctor(0, 6, 0); } else { - x_242 = x_241; + x_276 = x_232; } -lean_ctor_set(x_242, 0, x_238); -lean_ctor_set(x_242, 1, x_239); -lean_ctor_set(x_242, 2, x_225); -lean_ctor_set(x_242, 3, x_240); -if (lean_is_scalar(x_237)) { - x_243 = lean_alloc_ctor(0, 6, 0); -} else { - x_243 = x_237; -} -lean_ctor_set(x_243, 0, x_232); -lean_ctor_set(x_243, 1, x_233); -lean_ctor_set(x_243, 2, x_242); -lean_ctor_set(x_243, 3, x_234); -lean_ctor_set(x_243, 4, x_235); -lean_ctor_set(x_243, 5, x_236); -if (lean_is_scalar(x_214)) { - x_244 = lean_alloc_ctor(1, 2, 0); -} else { - x_244 = x_214; - lean_ctor_set_tag(x_244, 1); -} -lean_ctor_set(x_244, 0, x_231); -lean_ctor_set(x_244, 1, x_243); -return x_244; +lean_ctor_set(x_276, 0, x_227); +lean_ctor_set(x_276, 1, x_228); +lean_ctor_set(x_276, 2, x_275); +lean_ctor_set(x_276, 3, x_229); +lean_ctor_set(x_276, 4, x_230); +lean_ctor_set(x_276, 5, x_231); +lean_inc(x_217); +x_277 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_277, 0, x_226); +lean_ctor_set(x_277, 1, x_217); +x_278 = lean_array_push(x_213, x_277); +x_279 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_279, 0, x_211); +lean_ctor_set(x_279, 1, x_216); +lean_ctor_set(x_279, 2, x_278); +lean_ctor_set(x_279, 3, x_214); +lean_ctor_set(x_279, 4, x_215); +x_280 = lean_apply_3(x_4, x_217, x_279, x_276); +if (lean_obj_tag(x_280) == 0) +{ +lean_object* x_281; lean_object* x_282; lean_object* x_283; +x_281 = lean_ctor_get(x_280, 0); +lean_inc(x_281); +x_282 = lean_ctor_get(x_280, 1); +lean_inc(x_282); +lean_dec(x_280); +x_283 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_283, 0, x_281); +x_239 = x_283; +x_240 = x_282; +goto block_273; } else { -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; lean_object* x_252; lean_object* x_253; lean_object* x_254; lean_object* x_255; lean_object* x_256; lean_object* x_257; lean_object* x_258; lean_object* x_259; -x_245 = lean_ctor_get(x_229, 2); +lean_object* x_284; lean_object* x_285; lean_object* x_286; +x_284 = lean_ctor_get(x_280, 0); +lean_inc(x_284); +x_285 = lean_ctor_get(x_280, 1); +lean_inc(x_285); +lean_dec(x_280); +x_286 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_286, 0, x_284); +x_239 = x_286; +x_240 = x_285; +goto block_273; +} +block_273: +{ +if (lean_obj_tag(x_239) == 0) +{ +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; lean_object* x_252; lean_object* x_253; lean_object* x_254; lean_object* x_255; lean_object* x_256; +x_241 = lean_ctor_get(x_240, 2); +lean_inc(x_241); +x_242 = lean_ctor_get(x_239, 0); +lean_inc(x_242); +lean_dec(x_239); +x_243 = lean_ctor_get(x_240, 0); +lean_inc(x_243); +x_244 = lean_ctor_get(x_240, 1); +lean_inc(x_244); +x_245 = lean_ctor_get(x_240, 3); lean_inc(x_245); -x_246 = lean_ctor_get(x_228, 0); +x_246 = lean_ctor_get(x_240, 4); lean_inc(x_246); -lean_dec(x_228); -x_247 = lean_ctor_get(x_229, 0); +x_247 = lean_ctor_get(x_240, 5); lean_inc(x_247); -x_248 = lean_ctor_get(x_229, 1); -lean_inc(x_248); -x_249 = lean_ctor_get(x_229, 3); +if (lean_is_exclusive(x_240)) { + lean_ctor_release(x_240, 0); + lean_ctor_release(x_240, 1); + lean_ctor_release(x_240, 2); + lean_ctor_release(x_240, 3); + lean_ctor_release(x_240, 4); + lean_ctor_release(x_240, 5); + x_248 = x_240; +} else { + lean_dec_ref(x_240); + x_248 = lean_box(0); +} +x_249 = lean_ctor_get(x_241, 0); lean_inc(x_249); -x_250 = lean_ctor_get(x_229, 4); +x_250 = lean_ctor_get(x_241, 1); lean_inc(x_250); -x_251 = lean_ctor_get(x_229, 5); +x_251 = lean_ctor_get(x_241, 3); lean_inc(x_251); -if (lean_is_exclusive(x_229)) { - lean_ctor_release(x_229, 0); - lean_ctor_release(x_229, 1); - lean_ctor_release(x_229, 2); - lean_ctor_release(x_229, 3); - lean_ctor_release(x_229, 4); - lean_ctor_release(x_229, 5); - x_252 = x_229; +x_252 = lean_ctor_get(x_241, 4); +lean_inc(x_252); +if (lean_is_exclusive(x_241)) { + lean_ctor_release(x_241, 0); + lean_ctor_release(x_241, 1); + lean_ctor_release(x_241, 2); + lean_ctor_release(x_241, 3); + lean_ctor_release(x_241, 4); + x_253 = x_241; } else { - lean_dec_ref(x_229); - x_252 = lean_box(0); + lean_dec_ref(x_241); + x_253 = lean_box(0); } -x_253 = lean_ctor_get(x_245, 0); -lean_inc(x_253); -x_254 = lean_ctor_get(x_245, 1); -lean_inc(x_254); -x_255 = lean_ctor_get(x_245, 3); -lean_inc(x_255); -if (lean_is_exclusive(x_245)) { - lean_ctor_release(x_245, 0); - lean_ctor_release(x_245, 1); - lean_ctor_release(x_245, 2); - lean_ctor_release(x_245, 3); - x_256 = x_245; +if (lean_is_scalar(x_253)) { + x_254 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_245); - x_256 = lean_box(0); + x_254 = x_253; } -if (lean_is_scalar(x_256)) { - x_257 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_254, 0, x_249); +lean_ctor_set(x_254, 1, x_250); +lean_ctor_set(x_254, 2, x_235); +lean_ctor_set(x_254, 3, x_251); +lean_ctor_set(x_254, 4, x_252); +if (lean_is_scalar(x_248)) { + x_255 = lean_alloc_ctor(0, 6, 0); } else { - x_257 = x_256; + x_255 = x_248; } -lean_ctor_set(x_257, 0, x_253); -lean_ctor_set(x_257, 1, x_254); -lean_ctor_set(x_257, 2, x_225); -lean_ctor_set(x_257, 3, x_255); -if (lean_is_scalar(x_252)) { - x_258 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_255, 0, x_243); +lean_ctor_set(x_255, 1, x_244); +lean_ctor_set(x_255, 2, x_254); +lean_ctor_set(x_255, 3, x_245); +lean_ctor_set(x_255, 4, x_246); +lean_ctor_set(x_255, 5, x_247); +if (lean_is_scalar(x_224)) { + x_256 = lean_alloc_ctor(1, 2, 0); } else { - x_258 = x_252; + x_256 = x_224; + lean_ctor_set_tag(x_256, 1); } -lean_ctor_set(x_258, 0, x_247); -lean_ctor_set(x_258, 1, x_248); -lean_ctor_set(x_258, 2, x_257); -lean_ctor_set(x_258, 3, x_249); -lean_ctor_set(x_258, 4, x_250); -lean_ctor_set(x_258, 5, x_251); -if (lean_is_scalar(x_214)) { - x_259 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_256, 0, x_242); +lean_ctor_set(x_256, 1, x_255); +return x_256; +} +else +{ +lean_object* x_257; lean_object* x_258; lean_object* x_259; lean_object* x_260; lean_object* x_261; lean_object* x_262; lean_object* x_263; lean_object* x_264; lean_object* x_265; lean_object* x_266; lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_object* x_270; lean_object* x_271; lean_object* x_272; +x_257 = lean_ctor_get(x_240, 2); +lean_inc(x_257); +x_258 = lean_ctor_get(x_239, 0); +lean_inc(x_258); +lean_dec(x_239); +x_259 = lean_ctor_get(x_240, 0); +lean_inc(x_259); +x_260 = lean_ctor_get(x_240, 1); +lean_inc(x_260); +x_261 = lean_ctor_get(x_240, 3); +lean_inc(x_261); +x_262 = lean_ctor_get(x_240, 4); +lean_inc(x_262); +x_263 = lean_ctor_get(x_240, 5); +lean_inc(x_263); +if (lean_is_exclusive(x_240)) { + lean_ctor_release(x_240, 0); + lean_ctor_release(x_240, 1); + lean_ctor_release(x_240, 2); + lean_ctor_release(x_240, 3); + lean_ctor_release(x_240, 4); + lean_ctor_release(x_240, 5); + x_264 = x_240; } else { - x_259 = x_214; + lean_dec_ref(x_240); + x_264 = lean_box(0); } -lean_ctor_set(x_259, 0, x_246); -lean_ctor_set(x_259, 1, x_258); -return x_259; +x_265 = lean_ctor_get(x_257, 0); +lean_inc(x_265); +x_266 = lean_ctor_get(x_257, 1); +lean_inc(x_266); +x_267 = lean_ctor_get(x_257, 3); +lean_inc(x_267); +x_268 = lean_ctor_get(x_257, 4); +lean_inc(x_268); +if (lean_is_exclusive(x_257)) { + lean_ctor_release(x_257, 0); + lean_ctor_release(x_257, 1); + lean_ctor_release(x_257, 2); + lean_ctor_release(x_257, 3); + lean_ctor_release(x_257, 4); + x_269 = x_257; +} else { + lean_dec_ref(x_257); + x_269 = lean_box(0); +} +if (lean_is_scalar(x_269)) { + x_270 = lean_alloc_ctor(0, 5, 0); +} else { + x_270 = x_269; +} +lean_ctor_set(x_270, 0, x_265); +lean_ctor_set(x_270, 1, x_266); +lean_ctor_set(x_270, 2, x_235); +lean_ctor_set(x_270, 3, x_267); +lean_ctor_set(x_270, 4, x_268); +if (lean_is_scalar(x_264)) { + x_271 = lean_alloc_ctor(0, 6, 0); +} else { + x_271 = x_264; +} +lean_ctor_set(x_271, 0, x_259); +lean_ctor_set(x_271, 1, x_260); +lean_ctor_set(x_271, 2, x_270); +lean_ctor_set(x_271, 3, x_261); +lean_ctor_set(x_271, 4, x_262); +lean_ctor_set(x_271, 5, x_263); +if (lean_is_scalar(x_224)) { + x_272 = lean_alloc_ctor(0, 2, 0); +} else { + x_272 = x_224; +} +lean_ctor_set(x_272, 0, x_258); +lean_ctor_set(x_272, 1, x_271); +return x_272; } } } } else { -lean_object* x_274; lean_object* x_275; lean_object* x_276; lean_object* x_277; -lean_dec(x_208); -lean_dec(x_207); -lean_dec(x_206); -lean_dec(x_205); -lean_dec(x_204); -lean_dec(x_203); -lean_dec(x_201); +lean_object* x_287; lean_object* x_288; lean_object* x_289; lean_object* x_290; +lean_dec(x_218); +lean_dec(x_217); +lean_dec(x_216); +lean_dec(x_215); +lean_dec(x_214); +lean_dec(x_213); +lean_dec(x_211); lean_dec(x_4); -x_274 = lean_ctor_get(x_209, 0); -lean_inc(x_274); -x_275 = lean_ctor_get(x_209, 1); -lean_inc(x_275); -if (lean_is_exclusive(x_209)) { - lean_ctor_release(x_209, 0); - lean_ctor_release(x_209, 1); - x_276 = x_209; +x_287 = lean_ctor_get(x_219, 0); +lean_inc(x_287); +x_288 = lean_ctor_get(x_219, 1); +lean_inc(x_288); +if (lean_is_exclusive(x_219)) { + lean_ctor_release(x_219, 0); + lean_ctor_release(x_219, 1); + x_289 = x_219; } else { - lean_dec_ref(x_209); - x_276 = lean_box(0); + lean_dec_ref(x_219); + x_289 = lean_box(0); } -if (lean_is_scalar(x_276)) { - x_277 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_289)) { + x_290 = lean_alloc_ctor(1, 2, 0); } else { - x_277 = x_276; + x_290 = x_289; } -lean_ctor_set(x_277, 0, x_274); -lean_ctor_set(x_277, 1, x_275); -return x_277; +lean_ctor_set(x_290, 0, x_287); +lean_ctor_set(x_290, 1, x_288); +return x_290; } } } @@ -42851,46 +44202,46 @@ x_20 = lean_ctor_get(x_15, 2); 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_74; lean_object* x_75; lean_object* x_76; +lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_78; lean_object* x_79; lean_object* x_80; x_22 = lean_ctor_get(x_20, 2); -x_74 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_20, 2, x_74); -x_75 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_75, 0, x_6); -lean_ctor_set(x_75, 1, x_12); -lean_ctor_set(x_75, 2, x_14); -lean_ctor_set(x_75, 3, x_9); -lean_ctor_set(x_75, 4, x_10); -x_76 = lean_apply_2(x_2, x_75, x_15); -if (lean_obj_tag(x_76) == 0) +x_78 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_20, 2, x_78); +x_79 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_79, 0, x_6); +lean_ctor_set(x_79, 1, x_12); +lean_ctor_set(x_79, 2, x_14); +lean_ctor_set(x_79, 3, x_9); +lean_ctor_set(x_79, 4, x_10); +x_80 = lean_apply_2(x_2, x_79, x_15); +if (lean_obj_tag(x_80) == 0) { -lean_object* x_77; lean_object* x_78; lean_object* x_79; -x_77 = lean_ctor_get(x_76, 0); -lean_inc(x_77); -x_78 = lean_ctor_get(x_76, 1); -lean_inc(x_78); -lean_dec(x_76); -x_79 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_79, 0, x_77); -x_23 = x_79; -x_24 = x_78; -goto block_73; +lean_object* x_81; lean_object* x_82; lean_object* x_83; +x_81 = lean_ctor_get(x_80, 0); +lean_inc(x_81); +x_82 = lean_ctor_get(x_80, 1); +lean_inc(x_82); +lean_dec(x_80); +x_83 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_83, 0, x_81); +x_23 = x_83; +x_24 = x_82; +goto block_77; } else { -lean_object* x_80; lean_object* x_81; lean_object* x_82; -x_80 = lean_ctor_get(x_76, 0); -lean_inc(x_80); -x_81 = lean_ctor_get(x_76, 1); -lean_inc(x_81); -lean_dec(x_76); -x_82 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_82, 0, x_80); -x_23 = x_82; -x_24 = x_81; -goto block_73; +lean_object* x_84; lean_object* x_85; lean_object* x_86; +x_84 = lean_ctor_get(x_80, 0); +lean_inc(x_84); +x_85 = lean_ctor_get(x_80, 1); +lean_inc(x_85); +lean_dec(x_80); +x_86 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_86, 0, x_84); +x_23 = x_86; +x_24 = x_85; +goto block_77; } -block_73: +block_77: { if (lean_obj_tag(x_23) == 0) { @@ -42925,670 +44276,707 @@ return x_31; } else { -lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; +lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; x_32 = lean_ctor_get(x_25, 0); x_33 = lean_ctor_get(x_25, 1); x_34 = lean_ctor_get(x_25, 3); +x_35 = lean_ctor_get(x_25, 4); +lean_inc(x_35); lean_inc(x_34); lean_inc(x_33); lean_inc(x_32); lean_dec(x_25); -x_35 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_35, 0, x_32); -lean_ctor_set(x_35, 1, x_33); -lean_ctor_set(x_35, 2, x_22); -lean_ctor_set(x_35, 3, x_34); -lean_ctor_set(x_24, 2, x_35); +x_36 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_36, 0, x_32); +lean_ctor_set(x_36, 1, x_33); +lean_ctor_set(x_36, 2, x_22); +lean_ctor_set(x_36, 3, x_34); +lean_ctor_set(x_36, 4, x_35); +lean_ctor_set(x_24, 2, x_36); if (lean_is_scalar(x_16)) { - x_36 = lean_alloc_ctor(1, 2, 0); + x_37 = lean_alloc_ctor(1, 2, 0); } else { - x_36 = x_16; - lean_ctor_set_tag(x_36, 1); + x_37 = x_16; + lean_ctor_set_tag(x_37, 1); } -lean_ctor_set(x_36, 0, x_26); -lean_ctor_set(x_36, 1, x_24); -return x_36; +lean_ctor_set(x_37, 0, x_26); +lean_ctor_set(x_37, 1, x_24); +return x_37; } } else { -lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; -x_37 = lean_ctor_get(x_24, 0); -x_38 = lean_ctor_get(x_24, 1); -x_39 = lean_ctor_get(x_24, 3); -x_40 = lean_ctor_get(x_24, 4); -x_41 = lean_ctor_get(x_24, 5); +lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; +x_38 = lean_ctor_get(x_24, 0); +x_39 = lean_ctor_get(x_24, 1); +x_40 = lean_ctor_get(x_24, 3); +x_41 = lean_ctor_get(x_24, 4); +x_42 = lean_ctor_get(x_24, 5); +lean_inc(x_42); lean_inc(x_41); lean_inc(x_40); lean_inc(x_39); lean_inc(x_38); -lean_inc(x_37); lean_dec(x_24); -x_42 = lean_ctor_get(x_25, 0); -lean_inc(x_42); -x_43 = lean_ctor_get(x_25, 1); +x_43 = lean_ctor_get(x_25, 0); lean_inc(x_43); -x_44 = lean_ctor_get(x_25, 3); +x_44 = lean_ctor_get(x_25, 1); lean_inc(x_44); +x_45 = lean_ctor_get(x_25, 3); +lean_inc(x_45); +x_46 = lean_ctor_get(x_25, 4); +lean_inc(x_46); if (lean_is_exclusive(x_25)) { lean_ctor_release(x_25, 0); lean_ctor_release(x_25, 1); lean_ctor_release(x_25, 2); lean_ctor_release(x_25, 3); - x_45 = x_25; + lean_ctor_release(x_25, 4); + x_47 = x_25; } else { lean_dec_ref(x_25); - x_45 = lean_box(0); + x_47 = lean_box(0); } -if (lean_is_scalar(x_45)) { - x_46 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_47)) { + x_48 = lean_alloc_ctor(0, 5, 0); } else { - x_46 = x_45; + x_48 = x_47; } -lean_ctor_set(x_46, 0, x_42); -lean_ctor_set(x_46, 1, x_43); -lean_ctor_set(x_46, 2, x_22); -lean_ctor_set(x_46, 3, x_44); -x_47 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_47, 0, x_37); -lean_ctor_set(x_47, 1, x_38); -lean_ctor_set(x_47, 2, x_46); -lean_ctor_set(x_47, 3, x_39); -lean_ctor_set(x_47, 4, x_40); -lean_ctor_set(x_47, 5, x_41); +lean_ctor_set(x_48, 0, x_43); +lean_ctor_set(x_48, 1, x_44); +lean_ctor_set(x_48, 2, x_22); +lean_ctor_set(x_48, 3, x_45); +lean_ctor_set(x_48, 4, x_46); +x_49 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_49, 0, x_38); +lean_ctor_set(x_49, 1, x_39); +lean_ctor_set(x_49, 2, x_48); +lean_ctor_set(x_49, 3, x_40); +lean_ctor_set(x_49, 4, x_41); +lean_ctor_set(x_49, 5, x_42); if (lean_is_scalar(x_16)) { - x_48 = lean_alloc_ctor(1, 2, 0); + x_50 = lean_alloc_ctor(1, 2, 0); } else { - x_48 = x_16; - lean_ctor_set_tag(x_48, 1); + x_50 = x_16; + lean_ctor_set_tag(x_50, 1); } -lean_ctor_set(x_48, 0, x_26); -lean_ctor_set(x_48, 1, x_47); -return x_48; +lean_ctor_set(x_50, 0, x_26); +lean_ctor_set(x_50, 1, x_49); +return x_50; } } else { -lean_object* x_49; lean_object* x_50; uint8_t x_51; -x_49 = lean_ctor_get(x_24, 2); -lean_inc(x_49); -x_50 = lean_ctor_get(x_23, 0); -lean_inc(x_50); +lean_object* x_51; lean_object* x_52; uint8_t x_53; +x_51 = lean_ctor_get(x_24, 2); +lean_inc(x_51); +x_52 = lean_ctor_get(x_23, 0); +lean_inc(x_52); lean_dec(x_23); -x_51 = !lean_is_exclusive(x_24); -if (x_51 == 0) -{ -lean_object* x_52; uint8_t x_53; -x_52 = lean_ctor_get(x_24, 2); -lean_dec(x_52); -x_53 = !lean_is_exclusive(x_49); +x_53 = !lean_is_exclusive(x_24); if (x_53 == 0) { -lean_object* x_54; lean_object* x_55; -x_54 = lean_ctor_get(x_49, 2); +lean_object* x_54; uint8_t x_55; +x_54 = lean_ctor_get(x_24, 2); lean_dec(x_54); -lean_ctor_set(x_49, 2, x_22); +x_55 = !lean_is_exclusive(x_51); +if (x_55 == 0) +{ +lean_object* x_56; lean_object* x_57; +x_56 = lean_ctor_get(x_51, 2); +lean_dec(x_56); +lean_ctor_set(x_51, 2, x_22); if (lean_is_scalar(x_16)) { - x_55 = lean_alloc_ctor(0, 2, 0); + x_57 = lean_alloc_ctor(0, 2, 0); } else { - x_55 = x_16; + x_57 = x_16; } -lean_ctor_set(x_55, 0, x_50); -lean_ctor_set(x_55, 1, x_24); -return x_55; +lean_ctor_set(x_57, 0, x_52); +lean_ctor_set(x_57, 1, x_24); +return x_57; } else { -lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; -x_56 = lean_ctor_get(x_49, 0); -x_57 = lean_ctor_get(x_49, 1); -x_58 = lean_ctor_get(x_49, 3); +lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; +x_58 = lean_ctor_get(x_51, 0); +x_59 = lean_ctor_get(x_51, 1); +x_60 = lean_ctor_get(x_51, 3); +x_61 = lean_ctor_get(x_51, 4); +lean_inc(x_61); +lean_inc(x_60); +lean_inc(x_59); lean_inc(x_58); -lean_inc(x_57); -lean_inc(x_56); -lean_dec(x_49); -x_59 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_59, 0, x_56); -lean_ctor_set(x_59, 1, x_57); -lean_ctor_set(x_59, 2, x_22); -lean_ctor_set(x_59, 3, x_58); -lean_ctor_set(x_24, 2, x_59); +lean_dec(x_51); +x_62 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_62, 0, x_58); +lean_ctor_set(x_62, 1, x_59); +lean_ctor_set(x_62, 2, x_22); +lean_ctor_set(x_62, 3, x_60); +lean_ctor_set(x_62, 4, x_61); +lean_ctor_set(x_24, 2, x_62); if (lean_is_scalar(x_16)) { - x_60 = lean_alloc_ctor(0, 2, 0); + x_63 = lean_alloc_ctor(0, 2, 0); } else { - x_60 = x_16; + x_63 = x_16; } -lean_ctor_set(x_60, 0, x_50); -lean_ctor_set(x_60, 1, x_24); -return x_60; +lean_ctor_set(x_63, 0, x_52); +lean_ctor_set(x_63, 1, x_24); +return x_63; } } else { -lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; -x_61 = lean_ctor_get(x_24, 0); -x_62 = lean_ctor_get(x_24, 1); -x_63 = lean_ctor_get(x_24, 3); -x_64 = lean_ctor_get(x_24, 4); -x_65 = lean_ctor_get(x_24, 5); +lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; +x_64 = lean_ctor_get(x_24, 0); +x_65 = lean_ctor_get(x_24, 1); +x_66 = lean_ctor_get(x_24, 3); +x_67 = lean_ctor_get(x_24, 4); +x_68 = lean_ctor_get(x_24, 5); +lean_inc(x_68); +lean_inc(x_67); +lean_inc(x_66); lean_inc(x_65); lean_inc(x_64); -lean_inc(x_63); -lean_inc(x_62); -lean_inc(x_61); lean_dec(x_24); -x_66 = lean_ctor_get(x_49, 0); -lean_inc(x_66); -x_67 = lean_ctor_get(x_49, 1); -lean_inc(x_67); -x_68 = lean_ctor_get(x_49, 3); -lean_inc(x_68); -if (lean_is_exclusive(x_49)) { - lean_ctor_release(x_49, 0); - lean_ctor_release(x_49, 1); - lean_ctor_release(x_49, 2); - lean_ctor_release(x_49, 3); - x_69 = x_49; +x_69 = lean_ctor_get(x_51, 0); +lean_inc(x_69); +x_70 = lean_ctor_get(x_51, 1); +lean_inc(x_70); +x_71 = lean_ctor_get(x_51, 3); +lean_inc(x_71); +x_72 = lean_ctor_get(x_51, 4); +lean_inc(x_72); +if (lean_is_exclusive(x_51)) { + lean_ctor_release(x_51, 0); + lean_ctor_release(x_51, 1); + lean_ctor_release(x_51, 2); + lean_ctor_release(x_51, 3); + lean_ctor_release(x_51, 4); + x_73 = x_51; } else { - lean_dec_ref(x_49); - x_69 = lean_box(0); + lean_dec_ref(x_51); + x_73 = lean_box(0); } -if (lean_is_scalar(x_69)) { - x_70 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_73)) { + x_74 = lean_alloc_ctor(0, 5, 0); } else { - x_70 = x_69; + x_74 = x_73; } -lean_ctor_set(x_70, 0, x_66); -lean_ctor_set(x_70, 1, x_67); -lean_ctor_set(x_70, 2, x_22); -lean_ctor_set(x_70, 3, x_68); -x_71 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_71, 0, x_61); -lean_ctor_set(x_71, 1, x_62); -lean_ctor_set(x_71, 2, x_70); -lean_ctor_set(x_71, 3, x_63); -lean_ctor_set(x_71, 4, x_64); -lean_ctor_set(x_71, 5, x_65); +lean_ctor_set(x_74, 0, x_69); +lean_ctor_set(x_74, 1, x_70); +lean_ctor_set(x_74, 2, x_22); +lean_ctor_set(x_74, 3, x_71); +lean_ctor_set(x_74, 4, x_72); +x_75 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_75, 0, x_64); +lean_ctor_set(x_75, 1, x_65); +lean_ctor_set(x_75, 2, x_74); +lean_ctor_set(x_75, 3, x_66); +lean_ctor_set(x_75, 4, x_67); +lean_ctor_set(x_75, 5, x_68); if (lean_is_scalar(x_16)) { - x_72 = lean_alloc_ctor(0, 2, 0); + x_76 = lean_alloc_ctor(0, 2, 0); } else { - x_72 = x_16; + x_76 = x_16; } -lean_ctor_set(x_72, 0, x_50); -lean_ctor_set(x_72, 1, x_71); -return x_72; +lean_ctor_set(x_76, 0, x_52); +lean_ctor_set(x_76, 1, x_75); +return x_76; } } } } else { -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_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; -x_83 = lean_ctor_get(x_20, 0); -x_84 = lean_ctor_get(x_20, 1); -x_85 = lean_ctor_get(x_20, 2); -x_86 = lean_ctor_get(x_20, 3); -lean_inc(x_86); -lean_inc(x_85); -lean_inc(x_84); -lean_inc(x_83); -lean_dec(x_20); -x_120 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_121 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_121, 0, x_83); -lean_ctor_set(x_121, 1, x_84); -lean_ctor_set(x_121, 2, x_120); -lean_ctor_set(x_121, 3, x_86); -lean_ctor_set(x_15, 2, x_121); -x_122 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_122, 0, x_6); -lean_ctor_set(x_122, 1, x_12); -lean_ctor_set(x_122, 2, x_14); -lean_ctor_set(x_122, 3, x_9); -lean_ctor_set(x_122, 4, x_10); -x_123 = lean_apply_2(x_2, x_122, x_15); -if (lean_obj_tag(x_123) == 0) -{ -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); -x_126 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_126, 0, x_124); -x_87 = x_126; -x_88 = x_125; -goto block_119; -} -else -{ -lean_object* x_127; lean_object* x_128; lean_object* x_129; -x_127 = lean_ctor_get(x_123, 0); -lean_inc(x_127); -x_128 = lean_ctor_get(x_123, 1); -lean_inc(x_128); -lean_dec(x_123); -x_129 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_129, 0, x_127); -x_87 = x_129; -x_88 = x_128; -goto block_119; -} -block_119: -{ -if (lean_obj_tag(x_87) == 0) -{ -lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; -x_89 = lean_ctor_get(x_88, 2); -lean_inc(x_89); -x_90 = lean_ctor_get(x_87, 0); -lean_inc(x_90); -lean_dec(x_87); -x_91 = lean_ctor_get(x_88, 0); +lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; +x_87 = lean_ctor_get(x_20, 0); +x_88 = lean_ctor_get(x_20, 1); +x_89 = lean_ctor_get(x_20, 2); +x_90 = lean_ctor_get(x_20, 3); +x_91 = lean_ctor_get(x_20, 4); lean_inc(x_91); -x_92 = lean_ctor_get(x_88, 1); -lean_inc(x_92); -x_93 = lean_ctor_get(x_88, 3); -lean_inc(x_93); -x_94 = lean_ctor_get(x_88, 4); -lean_inc(x_94); -x_95 = lean_ctor_get(x_88, 5); -lean_inc(x_95); -if (lean_is_exclusive(x_88)) { - lean_ctor_release(x_88, 0); - lean_ctor_release(x_88, 1); - lean_ctor_release(x_88, 2); - lean_ctor_release(x_88, 3); - lean_ctor_release(x_88, 4); - lean_ctor_release(x_88, 5); - x_96 = x_88; -} else { - lean_dec_ref(x_88); - x_96 = lean_box(0); -} -x_97 = lean_ctor_get(x_89, 0); -lean_inc(x_97); -x_98 = lean_ctor_get(x_89, 1); -lean_inc(x_98); -x_99 = lean_ctor_get(x_89, 3); -lean_inc(x_99); -if (lean_is_exclusive(x_89)) { - lean_ctor_release(x_89, 0); - lean_ctor_release(x_89, 1); - lean_ctor_release(x_89, 2); - lean_ctor_release(x_89, 3); - x_100 = x_89; -} else { - lean_dec_ref(x_89); - x_100 = lean_box(0); -} -if (lean_is_scalar(x_100)) { - x_101 = lean_alloc_ctor(0, 4, 0); -} else { - x_101 = x_100; -} -lean_ctor_set(x_101, 0, x_97); -lean_ctor_set(x_101, 1, x_98); -lean_ctor_set(x_101, 2, x_85); -lean_ctor_set(x_101, 3, x_99); -if (lean_is_scalar(x_96)) { - x_102 = lean_alloc_ctor(0, 6, 0); -} else { - x_102 = x_96; -} -lean_ctor_set(x_102, 0, x_91); -lean_ctor_set(x_102, 1, x_92); -lean_ctor_set(x_102, 2, x_101); -lean_ctor_set(x_102, 3, x_93); -lean_ctor_set(x_102, 4, x_94); -lean_ctor_set(x_102, 5, x_95); -if (lean_is_scalar(x_16)) { - x_103 = lean_alloc_ctor(1, 2, 0); -} else { - x_103 = x_16; - lean_ctor_set_tag(x_103, 1); -} -lean_ctor_set(x_103, 0, x_90); -lean_ctor_set(x_103, 1, x_102); -return x_103; -} -else +lean_inc(x_90); +lean_inc(x_89); +lean_inc(x_88); +lean_inc(x_87); +lean_dec(x_20); +x_127 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_128 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_128, 0, x_87); +lean_ctor_set(x_128, 1, x_88); +lean_ctor_set(x_128, 2, x_127); +lean_ctor_set(x_128, 3, x_90); +lean_ctor_set(x_128, 4, x_91); +lean_ctor_set(x_15, 2, x_128); +x_129 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_129, 0, x_6); +lean_ctor_set(x_129, 1, x_12); +lean_ctor_set(x_129, 2, x_14); +lean_ctor_set(x_129, 3, x_9); +lean_ctor_set(x_129, 4, x_10); +x_130 = lean_apply_2(x_2, x_129, x_15); +if (lean_obj_tag(x_130) == 0) { -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; -x_104 = lean_ctor_get(x_88, 2); -lean_inc(x_104); -x_105 = lean_ctor_get(x_87, 0); -lean_inc(x_105); -lean_dec(x_87); -x_106 = lean_ctor_get(x_88, 0); -lean_inc(x_106); -x_107 = lean_ctor_get(x_88, 1); -lean_inc(x_107); -x_108 = lean_ctor_get(x_88, 3); -lean_inc(x_108); -x_109 = lean_ctor_get(x_88, 4); -lean_inc(x_109); -x_110 = lean_ctor_get(x_88, 5); -lean_inc(x_110); -if (lean_is_exclusive(x_88)) { - lean_ctor_release(x_88, 0); - lean_ctor_release(x_88, 1); - lean_ctor_release(x_88, 2); - lean_ctor_release(x_88, 3); - lean_ctor_release(x_88, 4); - lean_ctor_release(x_88, 5); - x_111 = x_88; -} else { - lean_dec_ref(x_88); - x_111 = lean_box(0); -} -x_112 = lean_ctor_get(x_104, 0); -lean_inc(x_112); -x_113 = lean_ctor_get(x_104, 1); -lean_inc(x_113); -x_114 = lean_ctor_get(x_104, 3); -lean_inc(x_114); -if (lean_is_exclusive(x_104)) { - lean_ctor_release(x_104, 0); - lean_ctor_release(x_104, 1); - lean_ctor_release(x_104, 2); - lean_ctor_release(x_104, 3); - x_115 = x_104; -} else { - lean_dec_ref(x_104); - x_115 = lean_box(0); -} -if (lean_is_scalar(x_115)) { - x_116 = lean_alloc_ctor(0, 4, 0); -} else { - x_116 = x_115; -} -lean_ctor_set(x_116, 0, x_112); -lean_ctor_set(x_116, 1, x_113); -lean_ctor_set(x_116, 2, x_85); -lean_ctor_set(x_116, 3, x_114); -if (lean_is_scalar(x_111)) { - x_117 = lean_alloc_ctor(0, 6, 0); -} else { - x_117 = x_111; -} -lean_ctor_set(x_117, 0, x_106); -lean_ctor_set(x_117, 1, x_107); -lean_ctor_set(x_117, 2, x_116); -lean_ctor_set(x_117, 3, x_108); -lean_ctor_set(x_117, 4, x_109); -lean_ctor_set(x_117, 5, x_110); -if (lean_is_scalar(x_16)) { - x_118 = lean_alloc_ctor(0, 2, 0); -} else { - x_118 = x_16; -} -lean_ctor_set(x_118, 0, x_105); -lean_ctor_set(x_118, 1, x_117); -return x_118; -} -} -} -} -else -{ -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_174; lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; -x_130 = lean_ctor_get(x_15, 2); -x_131 = lean_ctor_get(x_15, 0); -x_132 = lean_ctor_get(x_15, 1); -x_133 = lean_ctor_get(x_15, 3); -x_134 = lean_ctor_get(x_15, 4); -x_135 = lean_ctor_get(x_15, 5); -lean_inc(x_135); -lean_inc(x_134); -lean_inc(x_133); -lean_inc(x_130); -lean_inc(x_132); +lean_object* x_131; lean_object* x_132; lean_object* x_133; +x_131 = lean_ctor_get(x_130, 0); lean_inc(x_131); -lean_dec(x_15); -x_136 = lean_ctor_get(x_130, 0); -lean_inc(x_136); -x_137 = lean_ctor_get(x_130, 1); +x_132 = lean_ctor_get(x_130, 1); +lean_inc(x_132); +lean_dec(x_130); +x_133 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_133, 0, x_131); +x_92 = x_133; +x_93 = x_132; +goto block_126; +} +else +{ +lean_object* x_134; lean_object* x_135; lean_object* x_136; +x_134 = lean_ctor_get(x_130, 0); +lean_inc(x_134); +x_135 = lean_ctor_get(x_130, 1); +lean_inc(x_135); +lean_dec(x_130); +x_136 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_136, 0, x_134); +x_92 = x_136; +x_93 = x_135; +goto block_126; +} +block_126: +{ +if (lean_obj_tag(x_92) == 0) +{ +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; +x_94 = lean_ctor_get(x_93, 2); +lean_inc(x_94); +x_95 = lean_ctor_get(x_92, 0); +lean_inc(x_95); +lean_dec(x_92); +x_96 = lean_ctor_get(x_93, 0); +lean_inc(x_96); +x_97 = lean_ctor_get(x_93, 1); +lean_inc(x_97); +x_98 = lean_ctor_get(x_93, 3); +lean_inc(x_98); +x_99 = lean_ctor_get(x_93, 4); +lean_inc(x_99); +x_100 = lean_ctor_get(x_93, 5); +lean_inc(x_100); +if (lean_is_exclusive(x_93)) { + lean_ctor_release(x_93, 0); + lean_ctor_release(x_93, 1); + lean_ctor_release(x_93, 2); + lean_ctor_release(x_93, 3); + lean_ctor_release(x_93, 4); + lean_ctor_release(x_93, 5); + x_101 = x_93; +} else { + lean_dec_ref(x_93); + x_101 = lean_box(0); +} +x_102 = lean_ctor_get(x_94, 0); +lean_inc(x_102); +x_103 = lean_ctor_get(x_94, 1); +lean_inc(x_103); +x_104 = lean_ctor_get(x_94, 3); +lean_inc(x_104); +x_105 = lean_ctor_get(x_94, 4); +lean_inc(x_105); +if (lean_is_exclusive(x_94)) { + lean_ctor_release(x_94, 0); + lean_ctor_release(x_94, 1); + lean_ctor_release(x_94, 2); + lean_ctor_release(x_94, 3); + lean_ctor_release(x_94, 4); + x_106 = x_94; +} else { + lean_dec_ref(x_94); + x_106 = lean_box(0); +} +if (lean_is_scalar(x_106)) { + x_107 = lean_alloc_ctor(0, 5, 0); +} else { + x_107 = x_106; +} +lean_ctor_set(x_107, 0, x_102); +lean_ctor_set(x_107, 1, x_103); +lean_ctor_set(x_107, 2, x_89); +lean_ctor_set(x_107, 3, x_104); +lean_ctor_set(x_107, 4, x_105); +if (lean_is_scalar(x_101)) { + x_108 = lean_alloc_ctor(0, 6, 0); +} else { + x_108 = x_101; +} +lean_ctor_set(x_108, 0, x_96); +lean_ctor_set(x_108, 1, x_97); +lean_ctor_set(x_108, 2, x_107); +lean_ctor_set(x_108, 3, x_98); +lean_ctor_set(x_108, 4, x_99); +lean_ctor_set(x_108, 5, x_100); +if (lean_is_scalar(x_16)) { + x_109 = lean_alloc_ctor(1, 2, 0); +} else { + x_109 = x_16; + lean_ctor_set_tag(x_109, 1); +} +lean_ctor_set(x_109, 0, x_95); +lean_ctor_set(x_109, 1, x_108); +return x_109; +} +else +{ +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; +x_110 = lean_ctor_get(x_93, 2); +lean_inc(x_110); +x_111 = lean_ctor_get(x_92, 0); +lean_inc(x_111); +lean_dec(x_92); +x_112 = lean_ctor_get(x_93, 0); +lean_inc(x_112); +x_113 = lean_ctor_get(x_93, 1); +lean_inc(x_113); +x_114 = lean_ctor_get(x_93, 3); +lean_inc(x_114); +x_115 = lean_ctor_get(x_93, 4); +lean_inc(x_115); +x_116 = lean_ctor_get(x_93, 5); +lean_inc(x_116); +if (lean_is_exclusive(x_93)) { + lean_ctor_release(x_93, 0); + lean_ctor_release(x_93, 1); + lean_ctor_release(x_93, 2); + lean_ctor_release(x_93, 3); + lean_ctor_release(x_93, 4); + lean_ctor_release(x_93, 5); + x_117 = x_93; +} else { + lean_dec_ref(x_93); + x_117 = lean_box(0); +} +x_118 = lean_ctor_get(x_110, 0); +lean_inc(x_118); +x_119 = lean_ctor_get(x_110, 1); +lean_inc(x_119); +x_120 = lean_ctor_get(x_110, 3); +lean_inc(x_120); +x_121 = lean_ctor_get(x_110, 4); +lean_inc(x_121); +if (lean_is_exclusive(x_110)) { + lean_ctor_release(x_110, 0); + lean_ctor_release(x_110, 1); + lean_ctor_release(x_110, 2); + lean_ctor_release(x_110, 3); + lean_ctor_release(x_110, 4); + x_122 = x_110; +} else { + lean_dec_ref(x_110); + x_122 = lean_box(0); +} +if (lean_is_scalar(x_122)) { + x_123 = lean_alloc_ctor(0, 5, 0); +} else { + x_123 = x_122; +} +lean_ctor_set(x_123, 0, x_118); +lean_ctor_set(x_123, 1, x_119); +lean_ctor_set(x_123, 2, x_89); +lean_ctor_set(x_123, 3, x_120); +lean_ctor_set(x_123, 4, x_121); +if (lean_is_scalar(x_117)) { + x_124 = lean_alloc_ctor(0, 6, 0); +} else { + x_124 = x_117; +} +lean_ctor_set(x_124, 0, x_112); +lean_ctor_set(x_124, 1, x_113); +lean_ctor_set(x_124, 2, x_123); +lean_ctor_set(x_124, 3, x_114); +lean_ctor_set(x_124, 4, x_115); +lean_ctor_set(x_124, 5, x_116); +if (lean_is_scalar(x_16)) { + x_125 = lean_alloc_ctor(0, 2, 0); +} else { + x_125 = x_16; +} +lean_ctor_set(x_125, 0, x_111); +lean_ctor_set(x_125, 1, x_124); +return x_125; +} +} +} +} +else +{ +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_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; +x_137 = lean_ctor_get(x_15, 2); +x_138 = lean_ctor_get(x_15, 0); +x_139 = lean_ctor_get(x_15, 1); +x_140 = lean_ctor_get(x_15, 3); +x_141 = lean_ctor_get(x_15, 4); +x_142 = lean_ctor_get(x_15, 5); +lean_inc(x_142); +lean_inc(x_141); +lean_inc(x_140); lean_inc(x_137); -x_138 = lean_ctor_get(x_130, 2); -lean_inc(x_138); -x_139 = lean_ctor_get(x_130, 3); lean_inc(x_139); -if (lean_is_exclusive(x_130)) { - lean_ctor_release(x_130, 0); - lean_ctor_release(x_130, 1); - lean_ctor_release(x_130, 2); - lean_ctor_release(x_130, 3); - x_140 = x_130; -} else { - lean_dec_ref(x_130); - x_140 = lean_box(0); -} -x_174 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_140)) { - x_175 = lean_alloc_ctor(0, 4, 0); -} else { - x_175 = x_140; -} -lean_ctor_set(x_175, 0, x_136); -lean_ctor_set(x_175, 1, x_137); -lean_ctor_set(x_175, 2, x_174); -lean_ctor_set(x_175, 3, x_139); -x_176 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_176, 0, x_131); -lean_ctor_set(x_176, 1, x_132); -lean_ctor_set(x_176, 2, x_175); -lean_ctor_set(x_176, 3, x_133); -lean_ctor_set(x_176, 4, x_134); -lean_ctor_set(x_176, 5, x_135); -x_177 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_177, 0, x_6); -lean_ctor_set(x_177, 1, x_12); -lean_ctor_set(x_177, 2, x_14); -lean_ctor_set(x_177, 3, x_9); -lean_ctor_set(x_177, 4, x_10); -x_178 = lean_apply_2(x_2, x_177, x_176); -if (lean_obj_tag(x_178) == 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); -x_181 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_181, 0, x_179); -x_141 = x_181; -x_142 = x_180; -goto block_173; -} -else -{ -lean_object* x_182; lean_object* x_183; lean_object* x_184; -x_182 = lean_ctor_get(x_178, 0); -lean_inc(x_182); -x_183 = lean_ctor_get(x_178, 1); -lean_inc(x_183); -lean_dec(x_178); -x_184 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_184, 0, x_182); -x_141 = x_184; -x_142 = x_183; -goto block_173; -} -block_173: -{ -if (lean_obj_tag(x_141) == 0) -{ -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; -x_143 = lean_ctor_get(x_142, 2); +lean_inc(x_138); +lean_dec(x_15); +x_143 = lean_ctor_get(x_137, 0); lean_inc(x_143); -x_144 = lean_ctor_get(x_141, 0); +x_144 = lean_ctor_get(x_137, 1); lean_inc(x_144); -lean_dec(x_141); -x_145 = lean_ctor_get(x_142, 0); +x_145 = lean_ctor_get(x_137, 2); lean_inc(x_145); -x_146 = lean_ctor_get(x_142, 1); +x_146 = lean_ctor_get(x_137, 3); lean_inc(x_146); -x_147 = lean_ctor_get(x_142, 3); +x_147 = lean_ctor_get(x_137, 4); lean_inc(x_147); -x_148 = lean_ctor_get(x_142, 4); -lean_inc(x_148); -x_149 = lean_ctor_get(x_142, 5); -lean_inc(x_149); -if (lean_is_exclusive(x_142)) { - lean_ctor_release(x_142, 0); - lean_ctor_release(x_142, 1); - lean_ctor_release(x_142, 2); - lean_ctor_release(x_142, 3); - lean_ctor_release(x_142, 4); - lean_ctor_release(x_142, 5); - x_150 = x_142; +if (lean_is_exclusive(x_137)) { + lean_ctor_release(x_137, 0); + lean_ctor_release(x_137, 1); + lean_ctor_release(x_137, 2); + lean_ctor_release(x_137, 3); + lean_ctor_release(x_137, 4); + x_148 = x_137; } else { - lean_dec_ref(x_142); - x_150 = lean_box(0); + lean_dec_ref(x_137); + x_148 = lean_box(0); } -x_151 = lean_ctor_get(x_143, 0); +x_184 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_148)) { + x_185 = lean_alloc_ctor(0, 5, 0); +} else { + x_185 = x_148; +} +lean_ctor_set(x_185, 0, x_143); +lean_ctor_set(x_185, 1, x_144); +lean_ctor_set(x_185, 2, x_184); +lean_ctor_set(x_185, 3, x_146); +lean_ctor_set(x_185, 4, x_147); +x_186 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_186, 0, x_138); +lean_ctor_set(x_186, 1, x_139); +lean_ctor_set(x_186, 2, x_185); +lean_ctor_set(x_186, 3, x_140); +lean_ctor_set(x_186, 4, x_141); +lean_ctor_set(x_186, 5, x_142); +x_187 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_187, 0, x_6); +lean_ctor_set(x_187, 1, x_12); +lean_ctor_set(x_187, 2, x_14); +lean_ctor_set(x_187, 3, x_9); +lean_ctor_set(x_187, 4, x_10); +x_188 = lean_apply_2(x_2, x_187, x_186); +if (lean_obj_tag(x_188) == 0) +{ +lean_object* x_189; lean_object* x_190; lean_object* x_191; +x_189 = lean_ctor_get(x_188, 0); +lean_inc(x_189); +x_190 = lean_ctor_get(x_188, 1); +lean_inc(x_190); +lean_dec(x_188); +x_191 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_191, 0, x_189); +x_149 = x_191; +x_150 = x_190; +goto block_183; +} +else +{ +lean_object* x_192; lean_object* x_193; lean_object* x_194; +x_192 = lean_ctor_get(x_188, 0); +lean_inc(x_192); +x_193 = lean_ctor_get(x_188, 1); +lean_inc(x_193); +lean_dec(x_188); +x_194 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_194, 0, x_192); +x_149 = x_194; +x_150 = x_193; +goto block_183; +} +block_183: +{ +if (lean_obj_tag(x_149) == 0) +{ +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; +x_151 = lean_ctor_get(x_150, 2); lean_inc(x_151); -x_152 = lean_ctor_get(x_143, 1); +x_152 = lean_ctor_get(x_149, 0); lean_inc(x_152); -x_153 = lean_ctor_get(x_143, 3); +lean_dec(x_149); +x_153 = lean_ctor_get(x_150, 0); lean_inc(x_153); -if (lean_is_exclusive(x_143)) { - lean_ctor_release(x_143, 0); - lean_ctor_release(x_143, 1); - lean_ctor_release(x_143, 2); - lean_ctor_release(x_143, 3); - x_154 = x_143; +x_154 = lean_ctor_get(x_150, 1); +lean_inc(x_154); +x_155 = lean_ctor_get(x_150, 3); +lean_inc(x_155); +x_156 = lean_ctor_get(x_150, 4); +lean_inc(x_156); +x_157 = lean_ctor_get(x_150, 5); +lean_inc(x_157); +if (lean_is_exclusive(x_150)) { + lean_ctor_release(x_150, 0); + lean_ctor_release(x_150, 1); + lean_ctor_release(x_150, 2); + lean_ctor_release(x_150, 3); + lean_ctor_release(x_150, 4); + lean_ctor_release(x_150, 5); + x_158 = x_150; } else { - lean_dec_ref(x_143); - x_154 = lean_box(0); + lean_dec_ref(x_150); + x_158 = lean_box(0); } -if (lean_is_scalar(x_154)) { - x_155 = lean_alloc_ctor(0, 4, 0); -} else { - x_155 = x_154; -} -lean_ctor_set(x_155, 0, x_151); -lean_ctor_set(x_155, 1, x_152); -lean_ctor_set(x_155, 2, x_138); -lean_ctor_set(x_155, 3, x_153); -if (lean_is_scalar(x_150)) { - x_156 = lean_alloc_ctor(0, 6, 0); -} else { - x_156 = x_150; -} -lean_ctor_set(x_156, 0, x_145); -lean_ctor_set(x_156, 1, x_146); -lean_ctor_set(x_156, 2, x_155); -lean_ctor_set(x_156, 3, x_147); -lean_ctor_set(x_156, 4, x_148); -lean_ctor_set(x_156, 5, x_149); -if (lean_is_scalar(x_16)) { - x_157 = lean_alloc_ctor(1, 2, 0); -} else { - x_157 = x_16; - lean_ctor_set_tag(x_157, 1); -} -lean_ctor_set(x_157, 0, x_144); -lean_ctor_set(x_157, 1, x_156); -return x_157; -} -else -{ -lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; -x_158 = lean_ctor_get(x_142, 2); -lean_inc(x_158); -x_159 = lean_ctor_get(x_141, 0); +x_159 = lean_ctor_get(x_151, 0); lean_inc(x_159); -lean_dec(x_141); -x_160 = lean_ctor_get(x_142, 0); +x_160 = lean_ctor_get(x_151, 1); lean_inc(x_160); -x_161 = lean_ctor_get(x_142, 1); +x_161 = lean_ctor_get(x_151, 3); lean_inc(x_161); -x_162 = lean_ctor_get(x_142, 3); +x_162 = lean_ctor_get(x_151, 4); lean_inc(x_162); -x_163 = lean_ctor_get(x_142, 4); -lean_inc(x_163); -x_164 = lean_ctor_get(x_142, 5); -lean_inc(x_164); -if (lean_is_exclusive(x_142)) { - lean_ctor_release(x_142, 0); - lean_ctor_release(x_142, 1); - lean_ctor_release(x_142, 2); - lean_ctor_release(x_142, 3); - lean_ctor_release(x_142, 4); - lean_ctor_release(x_142, 5); - x_165 = x_142; +if (lean_is_exclusive(x_151)) { + lean_ctor_release(x_151, 0); + lean_ctor_release(x_151, 1); + lean_ctor_release(x_151, 2); + lean_ctor_release(x_151, 3); + lean_ctor_release(x_151, 4); + x_163 = x_151; } else { - lean_dec_ref(x_142); - x_165 = lean_box(0); + lean_dec_ref(x_151); + x_163 = lean_box(0); } -x_166 = lean_ctor_get(x_158, 0); -lean_inc(x_166); -x_167 = lean_ctor_get(x_158, 1); -lean_inc(x_167); -x_168 = lean_ctor_get(x_158, 3); -lean_inc(x_168); -if (lean_is_exclusive(x_158)) { - lean_ctor_release(x_158, 0); - lean_ctor_release(x_158, 1); - lean_ctor_release(x_158, 2); - lean_ctor_release(x_158, 3); - x_169 = x_158; +if (lean_is_scalar(x_163)) { + x_164 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_158); - x_169 = lean_box(0); + x_164 = x_163; } -if (lean_is_scalar(x_169)) { - x_170 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_164, 0, x_159); +lean_ctor_set(x_164, 1, x_160); +lean_ctor_set(x_164, 2, x_145); +lean_ctor_set(x_164, 3, x_161); +lean_ctor_set(x_164, 4, x_162); +if (lean_is_scalar(x_158)) { + x_165 = lean_alloc_ctor(0, 6, 0); } else { - x_170 = x_169; + x_165 = x_158; } -lean_ctor_set(x_170, 0, x_166); -lean_ctor_set(x_170, 1, x_167); -lean_ctor_set(x_170, 2, x_138); -lean_ctor_set(x_170, 3, x_168); -if (lean_is_scalar(x_165)) { - x_171 = lean_alloc_ctor(0, 6, 0); -} else { - x_171 = x_165; -} -lean_ctor_set(x_171, 0, x_160); -lean_ctor_set(x_171, 1, x_161); -lean_ctor_set(x_171, 2, x_170); -lean_ctor_set(x_171, 3, x_162); -lean_ctor_set(x_171, 4, x_163); -lean_ctor_set(x_171, 5, x_164); +lean_ctor_set(x_165, 0, x_153); +lean_ctor_set(x_165, 1, x_154); +lean_ctor_set(x_165, 2, x_164); +lean_ctor_set(x_165, 3, x_155); +lean_ctor_set(x_165, 4, x_156); +lean_ctor_set(x_165, 5, x_157); if (lean_is_scalar(x_16)) { - x_172 = lean_alloc_ctor(0, 2, 0); + x_166 = lean_alloc_ctor(1, 2, 0); } else { - x_172 = x_16; + x_166 = x_16; + lean_ctor_set_tag(x_166, 1); } -lean_ctor_set(x_172, 0, x_159); -lean_ctor_set(x_172, 1, x_171); -return x_172; +lean_ctor_set(x_166, 0, x_152); +lean_ctor_set(x_166, 1, x_165); +return x_166; +} +else +{ +lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; 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; lean_object* x_180; lean_object* x_181; lean_object* x_182; +x_167 = lean_ctor_get(x_150, 2); +lean_inc(x_167); +x_168 = lean_ctor_get(x_149, 0); +lean_inc(x_168); +lean_dec(x_149); +x_169 = lean_ctor_get(x_150, 0); +lean_inc(x_169); +x_170 = lean_ctor_get(x_150, 1); +lean_inc(x_170); +x_171 = lean_ctor_get(x_150, 3); +lean_inc(x_171); +x_172 = lean_ctor_get(x_150, 4); +lean_inc(x_172); +x_173 = lean_ctor_get(x_150, 5); +lean_inc(x_173); +if (lean_is_exclusive(x_150)) { + lean_ctor_release(x_150, 0); + lean_ctor_release(x_150, 1); + lean_ctor_release(x_150, 2); + lean_ctor_release(x_150, 3); + lean_ctor_release(x_150, 4); + lean_ctor_release(x_150, 5); + x_174 = x_150; +} else { + lean_dec_ref(x_150); + x_174 = lean_box(0); +} +x_175 = lean_ctor_get(x_167, 0); +lean_inc(x_175); +x_176 = lean_ctor_get(x_167, 1); +lean_inc(x_176); +x_177 = lean_ctor_get(x_167, 3); +lean_inc(x_177); +x_178 = lean_ctor_get(x_167, 4); +lean_inc(x_178); +if (lean_is_exclusive(x_167)) { + lean_ctor_release(x_167, 0); + lean_ctor_release(x_167, 1); + lean_ctor_release(x_167, 2); + lean_ctor_release(x_167, 3); + lean_ctor_release(x_167, 4); + x_179 = x_167; +} else { + lean_dec_ref(x_167); + x_179 = lean_box(0); +} +if (lean_is_scalar(x_179)) { + x_180 = lean_alloc_ctor(0, 5, 0); +} else { + x_180 = x_179; +} +lean_ctor_set(x_180, 0, x_175); +lean_ctor_set(x_180, 1, x_176); +lean_ctor_set(x_180, 2, x_145); +lean_ctor_set(x_180, 3, x_177); +lean_ctor_set(x_180, 4, x_178); +if (lean_is_scalar(x_174)) { + x_181 = lean_alloc_ctor(0, 6, 0); +} else { + x_181 = x_174; +} +lean_ctor_set(x_181, 0, x_169); +lean_ctor_set(x_181, 1, x_170); +lean_ctor_set(x_181, 2, x_180); +lean_ctor_set(x_181, 3, x_171); +lean_ctor_set(x_181, 4, x_172); +lean_ctor_set(x_181, 5, x_173); +if (lean_is_scalar(x_16)) { + x_182 = lean_alloc_ctor(0, 2, 0); +} else { + x_182 = x_16; +} +lean_ctor_set(x_182, 0, x_168); +lean_ctor_set(x_182, 1, x_181); +return x_182; } } } } else { -lean_object* x_185; +lean_object* x_195; lean_dec(x_16); lean_dec(x_14); lean_dec(x_12); lean_dec(x_10); lean_dec(x_9); lean_dec(x_6); -x_185 = lean_apply_2(x_2, x_3, x_15); -return x_185; +x_195 = lean_apply_2(x_2, x_3, x_15); +return x_195; } } else { -uint8_t x_186; +uint8_t x_196; lean_dec(x_3); lean_dec(x_12); lean_dec(x_11); @@ -43596,376 +44984,388 @@ lean_dec(x_10); lean_dec(x_9); lean_dec(x_6); lean_dec(x_2); -x_186 = !lean_is_exclusive(x_13); -if (x_186 == 0) +x_196 = !lean_is_exclusive(x_13); +if (x_196 == 0) { return x_13; } else { -lean_object* x_187; lean_object* x_188; lean_object* x_189; -x_187 = lean_ctor_get(x_13, 0); -x_188 = lean_ctor_get(x_13, 1); -lean_inc(x_188); -lean_inc(x_187); -lean_dec(x_13); -x_189 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_189, 0, x_187); -lean_ctor_set(x_189, 1, x_188); -return x_189; -} -} -} -else -{ -lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; -x_190 = lean_ctor_get(x_3, 0); -x_191 = lean_ctor_get(x_3, 1); -x_192 = lean_ctor_get(x_3, 2); -x_193 = lean_ctor_get(x_3, 3); -x_194 = lean_ctor_get(x_3, 4); -lean_inc(x_194); -lean_inc(x_193); -lean_inc(x_192); -lean_inc(x_191); -lean_inc(x_190); -lean_dec(x_3); -x_195 = lean_array_get_size(x_192); -lean_inc(x_1); -x_196 = l_List_foldl___main___at_Lean_Meta_withExistingLocalDecls___spec__1(x_191, x_1); -lean_inc(x_194); -lean_inc(x_193); -lean_inc(x_192); -lean_inc(x_196); -lean_inc(x_190); -x_197 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_197, 0, x_190); -lean_ctor_set(x_197, 1, x_196); -lean_ctor_set(x_197, 2, x_192); -lean_ctor_set(x_197, 3, x_193); -lean_ctor_set(x_197, 4, x_194); +lean_object* x_197; lean_object* x_198; lean_object* x_199; +x_197 = lean_ctor_get(x_13, 0); +x_198 = lean_ctor_get(x_13, 1); +lean_inc(x_198); lean_inc(x_197); -x_198 = l_List_foldlM___main___at_Lean_Meta_withExistingLocalDecls___spec__2(x_192, x_1, x_197, x_4); -lean_dec(x_1); -if (lean_obj_tag(x_198) == 0) -{ -lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; uint8_t x_203; -x_199 = lean_ctor_get(x_198, 0); -lean_inc(x_199); -x_200 = lean_ctor_get(x_198, 1); -lean_inc(x_200); -if (lean_is_exclusive(x_198)) { - lean_ctor_release(x_198, 0); - lean_ctor_release(x_198, 1); - x_201 = x_198; -} else { - lean_dec_ref(x_198); - x_201 = lean_box(0); +lean_dec(x_13); +x_199 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_199, 0, x_197); +lean_ctor_set(x_199, 1, x_198); +return x_199; } -x_202 = lean_array_get_size(x_199); -x_203 = lean_nat_dec_eq(x_202, x_195); -lean_dec(x_195); -lean_dec(x_202); -if (x_203 == 0) +} +} +else { -lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_249; lean_object* x_250; lean_object* x_251; lean_object* x_252; lean_object* x_253; -lean_dec(x_197); -x_204 = lean_ctor_get(x_200, 2); +lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; +x_200 = lean_ctor_get(x_3, 0); +x_201 = lean_ctor_get(x_3, 1); +x_202 = lean_ctor_get(x_3, 2); +x_203 = lean_ctor_get(x_3, 3); +x_204 = lean_ctor_get(x_3, 4); lean_inc(x_204); -x_205 = lean_ctor_get(x_200, 0); -lean_inc(x_205); -x_206 = lean_ctor_get(x_200, 1); +lean_inc(x_203); +lean_inc(x_202); +lean_inc(x_201); +lean_inc(x_200); +lean_dec(x_3); +x_205 = lean_array_get_size(x_202); +lean_inc(x_1); +x_206 = l_List_foldl___main___at_Lean_Meta_withExistingLocalDecls___spec__1(x_201, x_1); +lean_inc(x_204); +lean_inc(x_203); +lean_inc(x_202); lean_inc(x_206); -x_207 = lean_ctor_get(x_200, 3); +lean_inc(x_200); +x_207 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_207, 0, x_200); +lean_ctor_set(x_207, 1, x_206); +lean_ctor_set(x_207, 2, x_202); +lean_ctor_set(x_207, 3, x_203); +lean_ctor_set(x_207, 4, x_204); lean_inc(x_207); -x_208 = lean_ctor_get(x_200, 4); -lean_inc(x_208); -x_209 = lean_ctor_get(x_200, 5); +x_208 = l_List_foldlM___main___at_Lean_Meta_withExistingLocalDecls___spec__2(x_202, x_1, x_207, x_4); +lean_dec(x_1); +if (lean_obj_tag(x_208) == 0) +{ +lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; uint8_t x_213; +x_209 = lean_ctor_get(x_208, 0); lean_inc(x_209); -if (lean_is_exclusive(x_200)) { - lean_ctor_release(x_200, 0); - lean_ctor_release(x_200, 1); - lean_ctor_release(x_200, 2); - lean_ctor_release(x_200, 3); - lean_ctor_release(x_200, 4); - lean_ctor_release(x_200, 5); - x_210 = x_200; +x_210 = lean_ctor_get(x_208, 1); +lean_inc(x_210); +if (lean_is_exclusive(x_208)) { + lean_ctor_release(x_208, 0); + lean_ctor_release(x_208, 1); + x_211 = x_208; } else { - lean_dec_ref(x_200); - x_210 = lean_box(0); + lean_dec_ref(x_208); + x_211 = lean_box(0); } -x_211 = lean_ctor_get(x_204, 0); -lean_inc(x_211); -x_212 = lean_ctor_get(x_204, 1); -lean_inc(x_212); -x_213 = lean_ctor_get(x_204, 2); -lean_inc(x_213); -x_214 = lean_ctor_get(x_204, 3); +x_212 = lean_array_get_size(x_209); +x_213 = lean_nat_dec_eq(x_212, x_205); +lean_dec(x_205); +lean_dec(x_212); +if (x_213 == 0) +{ +lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; lean_object* x_224; lean_object* x_225; lean_object* x_226; lean_object* x_227; lean_object* x_228; lean_object* x_262; lean_object* x_263; lean_object* x_264; lean_object* x_265; lean_object* x_266; +lean_dec(x_207); +x_214 = lean_ctor_get(x_210, 2); lean_inc(x_214); -if (lean_is_exclusive(x_204)) { - lean_ctor_release(x_204, 0); - lean_ctor_release(x_204, 1); - lean_ctor_release(x_204, 2); - lean_ctor_release(x_204, 3); - x_215 = x_204; -} else { - lean_dec_ref(x_204); - x_215 = lean_box(0); -} -x_249 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_215)) { - x_250 = lean_alloc_ctor(0, 4, 0); -} else { - x_250 = x_215; -} -lean_ctor_set(x_250, 0, x_211); -lean_ctor_set(x_250, 1, x_212); -lean_ctor_set(x_250, 2, x_249); -lean_ctor_set(x_250, 3, x_214); -if (lean_is_scalar(x_210)) { - x_251 = lean_alloc_ctor(0, 6, 0); -} else { - x_251 = x_210; -} -lean_ctor_set(x_251, 0, x_205); -lean_ctor_set(x_251, 1, x_206); -lean_ctor_set(x_251, 2, x_250); -lean_ctor_set(x_251, 3, x_207); -lean_ctor_set(x_251, 4, x_208); -lean_ctor_set(x_251, 5, x_209); -x_252 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_252, 0, x_190); -lean_ctor_set(x_252, 1, x_196); -lean_ctor_set(x_252, 2, x_199); -lean_ctor_set(x_252, 3, x_193); -lean_ctor_set(x_252, 4, x_194); -x_253 = lean_apply_2(x_2, x_252, x_251); -if (lean_obj_tag(x_253) == 0) -{ -lean_object* x_254; lean_object* x_255; lean_object* x_256; -x_254 = lean_ctor_get(x_253, 0); -lean_inc(x_254); -x_255 = lean_ctor_get(x_253, 1); -lean_inc(x_255); -lean_dec(x_253); -x_256 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_256, 0, x_254); -x_216 = x_256; -x_217 = x_255; -goto block_248; -} -else -{ -lean_object* x_257; lean_object* x_258; lean_object* x_259; -x_257 = lean_ctor_get(x_253, 0); -lean_inc(x_257); -x_258 = lean_ctor_get(x_253, 1); -lean_inc(x_258); -lean_dec(x_253); -x_259 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_259, 0, x_257); -x_216 = x_259; -x_217 = x_258; -goto block_248; -} -block_248: -{ -if (lean_obj_tag(x_216) == 0) -{ -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; lean_object* x_231; lean_object* x_232; -x_218 = lean_ctor_get(x_217, 2); +x_215 = lean_ctor_get(x_210, 0); +lean_inc(x_215); +x_216 = lean_ctor_get(x_210, 1); +lean_inc(x_216); +x_217 = lean_ctor_get(x_210, 3); +lean_inc(x_217); +x_218 = lean_ctor_get(x_210, 4); lean_inc(x_218); -x_219 = lean_ctor_get(x_216, 0); +x_219 = lean_ctor_get(x_210, 5); lean_inc(x_219); -lean_dec(x_216); -x_220 = lean_ctor_get(x_217, 0); -lean_inc(x_220); -x_221 = lean_ctor_get(x_217, 1); +if (lean_is_exclusive(x_210)) { + lean_ctor_release(x_210, 0); + lean_ctor_release(x_210, 1); + lean_ctor_release(x_210, 2); + lean_ctor_release(x_210, 3); + lean_ctor_release(x_210, 4); + lean_ctor_release(x_210, 5); + x_220 = x_210; +} else { + lean_dec_ref(x_210); + x_220 = lean_box(0); +} +x_221 = lean_ctor_get(x_214, 0); lean_inc(x_221); -x_222 = lean_ctor_get(x_217, 3); +x_222 = lean_ctor_get(x_214, 1); lean_inc(x_222); -x_223 = lean_ctor_get(x_217, 4); +x_223 = lean_ctor_get(x_214, 2); lean_inc(x_223); -x_224 = lean_ctor_get(x_217, 5); +x_224 = lean_ctor_get(x_214, 3); lean_inc(x_224); -if (lean_is_exclusive(x_217)) { - lean_ctor_release(x_217, 0); - lean_ctor_release(x_217, 1); - lean_ctor_release(x_217, 2); - lean_ctor_release(x_217, 3); - lean_ctor_release(x_217, 4); - lean_ctor_release(x_217, 5); - x_225 = x_217; +x_225 = lean_ctor_get(x_214, 4); +lean_inc(x_225); +if (lean_is_exclusive(x_214)) { + lean_ctor_release(x_214, 0); + lean_ctor_release(x_214, 1); + lean_ctor_release(x_214, 2); + lean_ctor_release(x_214, 3); + lean_ctor_release(x_214, 4); + x_226 = x_214; } else { - lean_dec_ref(x_217); - x_225 = lean_box(0); + lean_dec_ref(x_214); + x_226 = lean_box(0); } -x_226 = lean_ctor_get(x_218, 0); -lean_inc(x_226); -x_227 = lean_ctor_get(x_218, 1); -lean_inc(x_227); -x_228 = lean_ctor_get(x_218, 3); -lean_inc(x_228); -if (lean_is_exclusive(x_218)) { - lean_ctor_release(x_218, 0); - lean_ctor_release(x_218, 1); - lean_ctor_release(x_218, 2); - lean_ctor_release(x_218, 3); - x_229 = x_218; +x_262 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_226)) { + x_263 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_218); - x_229 = lean_box(0); + x_263 = x_226; } -if (lean_is_scalar(x_229)) { - x_230 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_263, 0, x_221); +lean_ctor_set(x_263, 1, x_222); +lean_ctor_set(x_263, 2, x_262); +lean_ctor_set(x_263, 3, x_224); +lean_ctor_set(x_263, 4, x_225); +if (lean_is_scalar(x_220)) { + x_264 = lean_alloc_ctor(0, 6, 0); } else { - x_230 = x_229; + x_264 = x_220; } -lean_ctor_set(x_230, 0, x_226); -lean_ctor_set(x_230, 1, x_227); -lean_ctor_set(x_230, 2, x_213); -lean_ctor_set(x_230, 3, x_228); -if (lean_is_scalar(x_225)) { - x_231 = lean_alloc_ctor(0, 6, 0); -} else { - x_231 = x_225; -} -lean_ctor_set(x_231, 0, x_220); -lean_ctor_set(x_231, 1, x_221); -lean_ctor_set(x_231, 2, x_230); -lean_ctor_set(x_231, 3, x_222); -lean_ctor_set(x_231, 4, x_223); -lean_ctor_set(x_231, 5, x_224); -if (lean_is_scalar(x_201)) { - x_232 = lean_alloc_ctor(1, 2, 0); -} else { - x_232 = x_201; - lean_ctor_set_tag(x_232, 1); -} -lean_ctor_set(x_232, 0, x_219); -lean_ctor_set(x_232, 1, x_231); -return x_232; +lean_ctor_set(x_264, 0, x_215); +lean_ctor_set(x_264, 1, x_216); +lean_ctor_set(x_264, 2, x_263); +lean_ctor_set(x_264, 3, x_217); +lean_ctor_set(x_264, 4, x_218); +lean_ctor_set(x_264, 5, x_219); +x_265 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_265, 0, x_200); +lean_ctor_set(x_265, 1, x_206); +lean_ctor_set(x_265, 2, x_209); +lean_ctor_set(x_265, 3, x_203); +lean_ctor_set(x_265, 4, x_204); +x_266 = lean_apply_2(x_2, x_265, x_264); +if (lean_obj_tag(x_266) == 0) +{ +lean_object* x_267; lean_object* x_268; lean_object* x_269; +x_267 = lean_ctor_get(x_266, 0); +lean_inc(x_267); +x_268 = lean_ctor_get(x_266, 1); +lean_inc(x_268); +lean_dec(x_266); +x_269 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_269, 0, x_267); +x_227 = x_269; +x_228 = x_268; +goto block_261; } else { -lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_object* x_236; lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; lean_object* x_242; lean_object* x_243; lean_object* x_244; lean_object* x_245; lean_object* x_246; lean_object* x_247; -x_233 = lean_ctor_get(x_217, 2); +lean_object* x_270; lean_object* x_271; lean_object* x_272; +x_270 = lean_ctor_get(x_266, 0); +lean_inc(x_270); +x_271 = lean_ctor_get(x_266, 1); +lean_inc(x_271); +lean_dec(x_266); +x_272 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_272, 0, x_270); +x_227 = x_272; +x_228 = x_271; +goto block_261; +} +block_261: +{ +if (lean_obj_tag(x_227) == 0) +{ +lean_object* x_229; lean_object* x_230; lean_object* x_231; lean_object* x_232; lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_object* x_236; lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; lean_object* x_242; lean_object* x_243; lean_object* x_244; +x_229 = lean_ctor_get(x_228, 2); +lean_inc(x_229); +x_230 = lean_ctor_get(x_227, 0); +lean_inc(x_230); +lean_dec(x_227); +x_231 = lean_ctor_get(x_228, 0); +lean_inc(x_231); +x_232 = lean_ctor_get(x_228, 1); +lean_inc(x_232); +x_233 = lean_ctor_get(x_228, 3); lean_inc(x_233); -x_234 = lean_ctor_get(x_216, 0); +x_234 = lean_ctor_get(x_228, 4); lean_inc(x_234); -lean_dec(x_216); -x_235 = lean_ctor_get(x_217, 0); +x_235 = lean_ctor_get(x_228, 5); lean_inc(x_235); -x_236 = lean_ctor_get(x_217, 1); -lean_inc(x_236); -x_237 = lean_ctor_get(x_217, 3); +if (lean_is_exclusive(x_228)) { + lean_ctor_release(x_228, 0); + lean_ctor_release(x_228, 1); + lean_ctor_release(x_228, 2); + lean_ctor_release(x_228, 3); + lean_ctor_release(x_228, 4); + lean_ctor_release(x_228, 5); + x_236 = x_228; +} else { + lean_dec_ref(x_228); + x_236 = lean_box(0); +} +x_237 = lean_ctor_get(x_229, 0); lean_inc(x_237); -x_238 = lean_ctor_get(x_217, 4); +x_238 = lean_ctor_get(x_229, 1); lean_inc(x_238); -x_239 = lean_ctor_get(x_217, 5); +x_239 = lean_ctor_get(x_229, 3); lean_inc(x_239); -if (lean_is_exclusive(x_217)) { - lean_ctor_release(x_217, 0); - lean_ctor_release(x_217, 1); - lean_ctor_release(x_217, 2); - lean_ctor_release(x_217, 3); - lean_ctor_release(x_217, 4); - lean_ctor_release(x_217, 5); - x_240 = x_217; +x_240 = lean_ctor_get(x_229, 4); +lean_inc(x_240); +if (lean_is_exclusive(x_229)) { + lean_ctor_release(x_229, 0); + lean_ctor_release(x_229, 1); + lean_ctor_release(x_229, 2); + lean_ctor_release(x_229, 3); + lean_ctor_release(x_229, 4); + x_241 = x_229; } else { - lean_dec_ref(x_217); - x_240 = lean_box(0); + lean_dec_ref(x_229); + x_241 = lean_box(0); } -x_241 = lean_ctor_get(x_233, 0); -lean_inc(x_241); -x_242 = lean_ctor_get(x_233, 1); -lean_inc(x_242); -x_243 = lean_ctor_get(x_233, 3); -lean_inc(x_243); -if (lean_is_exclusive(x_233)) { - lean_ctor_release(x_233, 0); - lean_ctor_release(x_233, 1); - lean_ctor_release(x_233, 2); - lean_ctor_release(x_233, 3); - x_244 = x_233; +if (lean_is_scalar(x_241)) { + x_242 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_233); - x_244 = lean_box(0); + x_242 = x_241; } -if (lean_is_scalar(x_244)) { - x_245 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_242, 0, x_237); +lean_ctor_set(x_242, 1, x_238); +lean_ctor_set(x_242, 2, x_223); +lean_ctor_set(x_242, 3, x_239); +lean_ctor_set(x_242, 4, x_240); +if (lean_is_scalar(x_236)) { + x_243 = lean_alloc_ctor(0, 6, 0); } else { - x_245 = x_244; + x_243 = x_236; } -lean_ctor_set(x_245, 0, x_241); -lean_ctor_set(x_245, 1, x_242); -lean_ctor_set(x_245, 2, x_213); -lean_ctor_set(x_245, 3, x_243); -if (lean_is_scalar(x_240)) { - x_246 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_243, 0, x_231); +lean_ctor_set(x_243, 1, x_232); +lean_ctor_set(x_243, 2, x_242); +lean_ctor_set(x_243, 3, x_233); +lean_ctor_set(x_243, 4, x_234); +lean_ctor_set(x_243, 5, x_235); +if (lean_is_scalar(x_211)) { + x_244 = lean_alloc_ctor(1, 2, 0); } else { - x_246 = x_240; -} -lean_ctor_set(x_246, 0, x_235); -lean_ctor_set(x_246, 1, x_236); -lean_ctor_set(x_246, 2, x_245); -lean_ctor_set(x_246, 3, x_237); -lean_ctor_set(x_246, 4, x_238); -lean_ctor_set(x_246, 5, x_239); -if (lean_is_scalar(x_201)) { - x_247 = lean_alloc_ctor(0, 2, 0); -} else { - x_247 = x_201; -} -lean_ctor_set(x_247, 0, x_234); -lean_ctor_set(x_247, 1, x_246); -return x_247; -} + x_244 = x_211; + lean_ctor_set_tag(x_244, 1); } +lean_ctor_set(x_244, 0, x_230); +lean_ctor_set(x_244, 1, x_243); +return x_244; } else { -lean_object* x_260; -lean_dec(x_201); -lean_dec(x_199); -lean_dec(x_196); -lean_dec(x_194); -lean_dec(x_193); -lean_dec(x_190); -x_260 = lean_apply_2(x_2, x_197, x_200); +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; lean_object* x_252; lean_object* x_253; lean_object* x_254; lean_object* x_255; lean_object* x_256; lean_object* x_257; lean_object* x_258; lean_object* x_259; lean_object* x_260; +x_245 = lean_ctor_get(x_228, 2); +lean_inc(x_245); +x_246 = lean_ctor_get(x_227, 0); +lean_inc(x_246); +lean_dec(x_227); +x_247 = lean_ctor_get(x_228, 0); +lean_inc(x_247); +x_248 = lean_ctor_get(x_228, 1); +lean_inc(x_248); +x_249 = lean_ctor_get(x_228, 3); +lean_inc(x_249); +x_250 = lean_ctor_get(x_228, 4); +lean_inc(x_250); +x_251 = lean_ctor_get(x_228, 5); +lean_inc(x_251); +if (lean_is_exclusive(x_228)) { + lean_ctor_release(x_228, 0); + lean_ctor_release(x_228, 1); + lean_ctor_release(x_228, 2); + lean_ctor_release(x_228, 3); + lean_ctor_release(x_228, 4); + lean_ctor_release(x_228, 5); + x_252 = x_228; +} else { + lean_dec_ref(x_228); + x_252 = lean_box(0); +} +x_253 = lean_ctor_get(x_245, 0); +lean_inc(x_253); +x_254 = lean_ctor_get(x_245, 1); +lean_inc(x_254); +x_255 = lean_ctor_get(x_245, 3); +lean_inc(x_255); +x_256 = lean_ctor_get(x_245, 4); +lean_inc(x_256); +if (lean_is_exclusive(x_245)) { + lean_ctor_release(x_245, 0); + lean_ctor_release(x_245, 1); + lean_ctor_release(x_245, 2); + lean_ctor_release(x_245, 3); + lean_ctor_release(x_245, 4); + x_257 = x_245; +} else { + lean_dec_ref(x_245); + x_257 = lean_box(0); +} +if (lean_is_scalar(x_257)) { + x_258 = lean_alloc_ctor(0, 5, 0); +} else { + x_258 = x_257; +} +lean_ctor_set(x_258, 0, x_253); +lean_ctor_set(x_258, 1, x_254); +lean_ctor_set(x_258, 2, x_223); +lean_ctor_set(x_258, 3, x_255); +lean_ctor_set(x_258, 4, x_256); +if (lean_is_scalar(x_252)) { + x_259 = lean_alloc_ctor(0, 6, 0); +} else { + x_259 = x_252; +} +lean_ctor_set(x_259, 0, x_247); +lean_ctor_set(x_259, 1, x_248); +lean_ctor_set(x_259, 2, x_258); +lean_ctor_set(x_259, 3, x_249); +lean_ctor_set(x_259, 4, x_250); +lean_ctor_set(x_259, 5, x_251); +if (lean_is_scalar(x_211)) { + x_260 = lean_alloc_ctor(0, 2, 0); +} else { + x_260 = x_211; +} +lean_ctor_set(x_260, 0, x_246); +lean_ctor_set(x_260, 1, x_259); return x_260; } } +} else { -lean_object* x_261; lean_object* x_262; lean_object* x_263; lean_object* x_264; -lean_dec(x_197); -lean_dec(x_196); -lean_dec(x_195); -lean_dec(x_194); -lean_dec(x_193); -lean_dec(x_190); +lean_object* x_273; +lean_dec(x_211); +lean_dec(x_209); +lean_dec(x_206); +lean_dec(x_204); +lean_dec(x_203); +lean_dec(x_200); +x_273 = lean_apply_2(x_2, x_207, x_210); +return x_273; +} +} +else +{ +lean_object* x_274; lean_object* x_275; lean_object* x_276; lean_object* x_277; +lean_dec(x_207); +lean_dec(x_206); +lean_dec(x_205); +lean_dec(x_204); +lean_dec(x_203); +lean_dec(x_200); lean_dec(x_2); -x_261 = lean_ctor_get(x_198, 0); -lean_inc(x_261); -x_262 = lean_ctor_get(x_198, 1); -lean_inc(x_262); -if (lean_is_exclusive(x_198)) { - lean_ctor_release(x_198, 0); - lean_ctor_release(x_198, 1); - x_263 = x_198; +x_274 = lean_ctor_get(x_208, 0); +lean_inc(x_274); +x_275 = lean_ctor_get(x_208, 1); +lean_inc(x_275); +if (lean_is_exclusive(x_208)) { + lean_ctor_release(x_208, 0); + lean_ctor_release(x_208, 1); + x_276 = x_208; } else { - lean_dec_ref(x_198); - x_263 = lean_box(0); + lean_dec_ref(x_208); + x_276 = lean_box(0); } -if (lean_is_scalar(x_263)) { - x_264 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_276)) { + x_277 = lean_alloc_ctor(1, 2, 0); } else { - x_264 = x_263; + x_277 = x_276; } -lean_ctor_set(x_264, 0, x_261); -lean_ctor_set(x_264, 1, x_262); -return x_264; +lean_ctor_set(x_277, 0, x_274); +lean_ctor_set(x_277, 1, x_275); +return x_277; } } } @@ -44397,33 +45797,33 @@ lean_ctor_set(x_13, 3, x_8); lean_ctor_set(x_13, 4, x_9); if (x_12 == 0) { -lean_object* x_179; +lean_object* x_189; lean_dec(x_2); -x_179 = lean_box(0); -x_14 = x_179; -goto block_178; +x_189 = lean_box(0); +x_14 = x_189; +goto block_188; } else { -lean_object* x_180; uint8_t x_181; -x_180 = lean_unsigned_to_nat(0u); -x_181 = l_Array_isEqvAux___main___at_Lean_Meta_withLocalContext___spec__1(x_2, x_4, lean_box(0), x_2, x_7, x_180); +lean_object* x_190; uint8_t x_191; +x_190 = lean_unsigned_to_nat(0u); +x_191 = l_Array_isEqvAux___main___at_Lean_Meta_withLocalContext___spec__1(x_2, x_4, lean_box(0), x_2, x_7, x_190); lean_dec(x_2); -if (x_181 == 0) +if (x_191 == 0) { -lean_object* x_182; -x_182 = lean_box(0); -x_14 = x_182; -goto block_178; +lean_object* x_192; +x_192 = lean_box(0); +x_14 = x_192; +goto block_188; } else { -lean_object* x_183; -x_183 = lean_apply_2(x_3, x_13, x_5); -return x_183; +lean_object* x_193; +x_193 = lean_apply_2(x_3, x_13, x_5); +return x_193; } } -block_178: +block_188: { uint8_t x_15; lean_dec(x_14); @@ -44435,40 +45835,40 @@ x_16 = lean_ctor_get(x_5, 2); x_17 = !lean_is_exclusive(x_16); if (x_17 == 0) { -lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_70; lean_object* x_71; +lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_74; lean_object* x_75; x_18 = lean_ctor_get(x_16, 2); -x_70 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_16, 2, x_70); -x_71 = lean_apply_2(x_3, x_13, x_5); -if (lean_obj_tag(x_71) == 0) +x_74 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_16, 2, x_74); +x_75 = lean_apply_2(x_3, x_13, x_5); +if (lean_obj_tag(x_75) == 0) { -lean_object* x_72; lean_object* x_73; lean_object* x_74; -x_72 = lean_ctor_get(x_71, 0); -lean_inc(x_72); -x_73 = lean_ctor_get(x_71, 1); -lean_inc(x_73); -lean_dec(x_71); -x_74 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_74, 0, x_72); -x_19 = x_74; -x_20 = x_73; -goto block_69; +lean_object* x_76; lean_object* x_77; lean_object* x_78; +x_76 = lean_ctor_get(x_75, 0); +lean_inc(x_76); +x_77 = lean_ctor_get(x_75, 1); +lean_inc(x_77); +lean_dec(x_75); +x_78 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_78, 0, x_76); +x_19 = x_78; +x_20 = x_77; +goto block_73; } else { -lean_object* x_75; lean_object* x_76; lean_object* x_77; -x_75 = lean_ctor_get(x_71, 0); -lean_inc(x_75); -x_76 = lean_ctor_get(x_71, 1); -lean_inc(x_76); -lean_dec(x_71); -x_77 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_77, 0, x_75); -x_19 = x_77; -x_20 = x_76; -goto block_69; +lean_object* x_79; lean_object* x_80; lean_object* x_81; +x_79 = lean_ctor_get(x_75, 0); +lean_inc(x_79); +x_80 = lean_ctor_get(x_75, 1); +lean_inc(x_80); +lean_dec(x_75); +x_81 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_81, 0, x_79); +x_19 = x_81; +x_20 = x_80; +goto block_73; } -block_69: +block_73: { if (lean_obj_tag(x_19) == 0) { @@ -44498,598 +45898,635 @@ return x_27; } else { -lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; +lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; x_28 = lean_ctor_get(x_21, 0); x_29 = lean_ctor_get(x_21, 1); x_30 = lean_ctor_get(x_21, 3); +x_31 = lean_ctor_get(x_21, 4); +lean_inc(x_31); lean_inc(x_30); lean_inc(x_29); lean_inc(x_28); lean_dec(x_21); -x_31 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_31, 0, x_28); -lean_ctor_set(x_31, 1, x_29); -lean_ctor_set(x_31, 2, x_18); -lean_ctor_set(x_31, 3, x_30); -lean_ctor_set(x_20, 2, x_31); -x_32 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_32, 0, x_22); -lean_ctor_set(x_32, 1, x_20); -return x_32; +x_32 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_32, 0, x_28); +lean_ctor_set(x_32, 1, x_29); +lean_ctor_set(x_32, 2, x_18); +lean_ctor_set(x_32, 3, x_30); +lean_ctor_set(x_32, 4, x_31); +lean_ctor_set(x_20, 2, x_32); +x_33 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_33, 0, x_22); +lean_ctor_set(x_33, 1, x_20); +return x_33; } } else { -lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; -x_33 = lean_ctor_get(x_20, 0); -x_34 = lean_ctor_get(x_20, 1); -x_35 = lean_ctor_get(x_20, 3); -x_36 = lean_ctor_get(x_20, 4); -x_37 = lean_ctor_get(x_20, 5); +lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; +x_34 = lean_ctor_get(x_20, 0); +x_35 = lean_ctor_get(x_20, 1); +x_36 = lean_ctor_get(x_20, 3); +x_37 = lean_ctor_get(x_20, 4); +x_38 = lean_ctor_get(x_20, 5); +lean_inc(x_38); lean_inc(x_37); lean_inc(x_36); lean_inc(x_35); lean_inc(x_34); -lean_inc(x_33); lean_dec(x_20); -x_38 = lean_ctor_get(x_21, 0); -lean_inc(x_38); -x_39 = lean_ctor_get(x_21, 1); +x_39 = lean_ctor_get(x_21, 0); lean_inc(x_39); -x_40 = lean_ctor_get(x_21, 3); +x_40 = lean_ctor_get(x_21, 1); lean_inc(x_40); +x_41 = lean_ctor_get(x_21, 3); +lean_inc(x_41); +x_42 = lean_ctor_get(x_21, 4); +lean_inc(x_42); if (lean_is_exclusive(x_21)) { lean_ctor_release(x_21, 0); lean_ctor_release(x_21, 1); lean_ctor_release(x_21, 2); lean_ctor_release(x_21, 3); - x_41 = x_21; + lean_ctor_release(x_21, 4); + x_43 = x_21; } else { lean_dec_ref(x_21); - x_41 = lean_box(0); + x_43 = lean_box(0); } -if (lean_is_scalar(x_41)) { - x_42 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_43)) { + x_44 = lean_alloc_ctor(0, 5, 0); } else { - x_42 = x_41; + x_44 = x_43; } -lean_ctor_set(x_42, 0, x_38); -lean_ctor_set(x_42, 1, x_39); -lean_ctor_set(x_42, 2, x_18); -lean_ctor_set(x_42, 3, x_40); -x_43 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_43, 0, x_33); -lean_ctor_set(x_43, 1, x_34); -lean_ctor_set(x_43, 2, x_42); -lean_ctor_set(x_43, 3, x_35); -lean_ctor_set(x_43, 4, x_36); -lean_ctor_set(x_43, 5, x_37); -x_44 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_44, 0, x_22); -lean_ctor_set(x_44, 1, x_43); -return x_44; +lean_ctor_set(x_44, 0, x_39); +lean_ctor_set(x_44, 1, x_40); +lean_ctor_set(x_44, 2, x_18); +lean_ctor_set(x_44, 3, x_41); +lean_ctor_set(x_44, 4, x_42); +x_45 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_45, 0, x_34); +lean_ctor_set(x_45, 1, x_35); +lean_ctor_set(x_45, 2, x_44); +lean_ctor_set(x_45, 3, x_36); +lean_ctor_set(x_45, 4, x_37); +lean_ctor_set(x_45, 5, x_38); +x_46 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_46, 0, x_22); +lean_ctor_set(x_46, 1, x_45); +return x_46; } } else { -lean_object* x_45; lean_object* x_46; uint8_t x_47; -x_45 = lean_ctor_get(x_20, 2); -lean_inc(x_45); -x_46 = lean_ctor_get(x_19, 0); -lean_inc(x_46); +lean_object* x_47; lean_object* x_48; uint8_t x_49; +x_47 = lean_ctor_get(x_20, 2); +lean_inc(x_47); +x_48 = lean_ctor_get(x_19, 0); +lean_inc(x_48); lean_dec(x_19); -x_47 = !lean_is_exclusive(x_20); -if (x_47 == 0) -{ -lean_object* x_48; uint8_t x_49; -x_48 = lean_ctor_get(x_20, 2); -lean_dec(x_48); -x_49 = !lean_is_exclusive(x_45); +x_49 = !lean_is_exclusive(x_20); if (x_49 == 0) { -lean_object* x_50; lean_object* x_51; -x_50 = lean_ctor_get(x_45, 2); +lean_object* x_50; uint8_t x_51; +x_50 = lean_ctor_get(x_20, 2); lean_dec(x_50); -lean_ctor_set(x_45, 2, x_18); -x_51 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_51, 0, x_46); -lean_ctor_set(x_51, 1, x_20); -return x_51; +x_51 = !lean_is_exclusive(x_47); +if (x_51 == 0) +{ +lean_object* x_52; lean_object* x_53; +x_52 = lean_ctor_get(x_47, 2); +lean_dec(x_52); +lean_ctor_set(x_47, 2, x_18); +x_53 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_53, 0, x_48); +lean_ctor_set(x_53, 1, x_20); +return x_53; } else { -lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; -x_52 = lean_ctor_get(x_45, 0); -x_53 = lean_ctor_get(x_45, 1); -x_54 = lean_ctor_get(x_45, 3); +lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; +x_54 = lean_ctor_get(x_47, 0); +x_55 = lean_ctor_get(x_47, 1); +x_56 = lean_ctor_get(x_47, 3); +x_57 = lean_ctor_get(x_47, 4); +lean_inc(x_57); +lean_inc(x_56); +lean_inc(x_55); lean_inc(x_54); -lean_inc(x_53); -lean_inc(x_52); -lean_dec(x_45); -x_55 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_55, 0, x_52); -lean_ctor_set(x_55, 1, x_53); -lean_ctor_set(x_55, 2, x_18); -lean_ctor_set(x_55, 3, x_54); -lean_ctor_set(x_20, 2, x_55); -x_56 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_56, 0, x_46); -lean_ctor_set(x_56, 1, x_20); -return x_56; +lean_dec(x_47); +x_58 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_58, 0, x_54); +lean_ctor_set(x_58, 1, x_55); +lean_ctor_set(x_58, 2, x_18); +lean_ctor_set(x_58, 3, x_56); +lean_ctor_set(x_58, 4, x_57); +lean_ctor_set(x_20, 2, x_58); +x_59 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_59, 0, x_48); +lean_ctor_set(x_59, 1, x_20); +return x_59; } } else { -lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; -x_57 = lean_ctor_get(x_20, 0); -x_58 = lean_ctor_get(x_20, 1); -x_59 = lean_ctor_get(x_20, 3); -x_60 = lean_ctor_get(x_20, 4); -x_61 = lean_ctor_get(x_20, 5); +lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; +x_60 = lean_ctor_get(x_20, 0); +x_61 = lean_ctor_get(x_20, 1); +x_62 = lean_ctor_get(x_20, 3); +x_63 = lean_ctor_get(x_20, 4); +x_64 = lean_ctor_get(x_20, 5); +lean_inc(x_64); +lean_inc(x_63); +lean_inc(x_62); lean_inc(x_61); lean_inc(x_60); -lean_inc(x_59); -lean_inc(x_58); -lean_inc(x_57); lean_dec(x_20); -x_62 = lean_ctor_get(x_45, 0); -lean_inc(x_62); -x_63 = lean_ctor_get(x_45, 1); -lean_inc(x_63); -x_64 = lean_ctor_get(x_45, 3); -lean_inc(x_64); -if (lean_is_exclusive(x_45)) { - lean_ctor_release(x_45, 0); - lean_ctor_release(x_45, 1); - lean_ctor_release(x_45, 2); - lean_ctor_release(x_45, 3); - x_65 = x_45; +x_65 = lean_ctor_get(x_47, 0); +lean_inc(x_65); +x_66 = lean_ctor_get(x_47, 1); +lean_inc(x_66); +x_67 = lean_ctor_get(x_47, 3); +lean_inc(x_67); +x_68 = lean_ctor_get(x_47, 4); +lean_inc(x_68); +if (lean_is_exclusive(x_47)) { + lean_ctor_release(x_47, 0); + lean_ctor_release(x_47, 1); + lean_ctor_release(x_47, 2); + lean_ctor_release(x_47, 3); + lean_ctor_release(x_47, 4); + x_69 = x_47; } else { - lean_dec_ref(x_45); - x_65 = lean_box(0); + lean_dec_ref(x_47); + x_69 = lean_box(0); } -if (lean_is_scalar(x_65)) { - x_66 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_69)) { + x_70 = lean_alloc_ctor(0, 5, 0); } else { - x_66 = x_65; + x_70 = x_69; } -lean_ctor_set(x_66, 0, x_62); -lean_ctor_set(x_66, 1, x_63); -lean_ctor_set(x_66, 2, x_18); -lean_ctor_set(x_66, 3, x_64); -x_67 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_67, 0, x_57); -lean_ctor_set(x_67, 1, x_58); -lean_ctor_set(x_67, 2, x_66); -lean_ctor_set(x_67, 3, x_59); -lean_ctor_set(x_67, 4, x_60); -lean_ctor_set(x_67, 5, x_61); -x_68 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_68, 0, x_46); -lean_ctor_set(x_68, 1, x_67); -return x_68; +lean_ctor_set(x_70, 0, x_65); +lean_ctor_set(x_70, 1, x_66); +lean_ctor_set(x_70, 2, x_18); +lean_ctor_set(x_70, 3, x_67); +lean_ctor_set(x_70, 4, x_68); +x_71 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_71, 0, x_60); +lean_ctor_set(x_71, 1, x_61); +lean_ctor_set(x_71, 2, x_70); +lean_ctor_set(x_71, 3, x_62); +lean_ctor_set(x_71, 4, x_63); +lean_ctor_set(x_71, 5, x_64); +x_72 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_72, 0, x_48); +lean_ctor_set(x_72, 1, x_71); +return x_72; } } } } else { -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_115; lean_object* x_116; lean_object* x_117; -x_78 = lean_ctor_get(x_16, 0); -x_79 = lean_ctor_get(x_16, 1); -x_80 = lean_ctor_get(x_16, 2); -x_81 = lean_ctor_get(x_16, 3); -lean_inc(x_81); -lean_inc(x_80); -lean_inc(x_79); -lean_inc(x_78); -lean_dec(x_16); -x_115 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_116 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_116, 0, x_78); -lean_ctor_set(x_116, 1, x_79); -lean_ctor_set(x_116, 2, x_115); -lean_ctor_set(x_116, 3, x_81); -lean_ctor_set(x_5, 2, x_116); -x_117 = lean_apply_2(x_3, x_13, x_5); -if (lean_obj_tag(x_117) == 0) -{ -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); -x_120 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_120, 0, x_118); -x_82 = x_120; -x_83 = x_119; -goto block_114; -} -else -{ -lean_object* x_121; lean_object* x_122; lean_object* x_123; -x_121 = lean_ctor_get(x_117, 0); -lean_inc(x_121); -x_122 = lean_ctor_get(x_117, 1); -lean_inc(x_122); -lean_dec(x_117); -x_123 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_123, 0, x_121); -x_82 = x_123; -x_83 = x_122; -goto block_114; -} -block_114: -{ -if (lean_obj_tag(x_82) == 0) -{ -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; -x_84 = lean_ctor_get(x_83, 2); -lean_inc(x_84); -x_85 = lean_ctor_get(x_82, 0); -lean_inc(x_85); -lean_dec(x_82); -x_86 = lean_ctor_get(x_83, 0); +lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_122; lean_object* x_123; lean_object* x_124; +x_82 = lean_ctor_get(x_16, 0); +x_83 = lean_ctor_get(x_16, 1); +x_84 = lean_ctor_get(x_16, 2); +x_85 = lean_ctor_get(x_16, 3); +x_86 = lean_ctor_get(x_16, 4); lean_inc(x_86); -x_87 = lean_ctor_get(x_83, 1); -lean_inc(x_87); -x_88 = lean_ctor_get(x_83, 3); -lean_inc(x_88); -x_89 = lean_ctor_get(x_83, 4); -lean_inc(x_89); -x_90 = lean_ctor_get(x_83, 5); -lean_inc(x_90); -if (lean_is_exclusive(x_83)) { - lean_ctor_release(x_83, 0); - lean_ctor_release(x_83, 1); - lean_ctor_release(x_83, 2); - lean_ctor_release(x_83, 3); - lean_ctor_release(x_83, 4); - lean_ctor_release(x_83, 5); - x_91 = x_83; -} else { - lean_dec_ref(x_83); - x_91 = lean_box(0); -} -x_92 = lean_ctor_get(x_84, 0); -lean_inc(x_92); -x_93 = lean_ctor_get(x_84, 1); -lean_inc(x_93); -x_94 = lean_ctor_get(x_84, 3); -lean_inc(x_94); -if (lean_is_exclusive(x_84)) { - lean_ctor_release(x_84, 0); - lean_ctor_release(x_84, 1); - lean_ctor_release(x_84, 2); - lean_ctor_release(x_84, 3); - x_95 = x_84; -} else { - lean_dec_ref(x_84); - x_95 = lean_box(0); -} -if (lean_is_scalar(x_95)) { - x_96 = lean_alloc_ctor(0, 4, 0); -} else { - x_96 = x_95; -} -lean_ctor_set(x_96, 0, x_92); -lean_ctor_set(x_96, 1, x_93); -lean_ctor_set(x_96, 2, x_80); -lean_ctor_set(x_96, 3, x_94); -if (lean_is_scalar(x_91)) { - x_97 = lean_alloc_ctor(0, 6, 0); -} else { - x_97 = x_91; -} -lean_ctor_set(x_97, 0, x_86); -lean_ctor_set(x_97, 1, x_87); -lean_ctor_set(x_97, 2, x_96); -lean_ctor_set(x_97, 3, x_88); -lean_ctor_set(x_97, 4, x_89); -lean_ctor_set(x_97, 5, x_90); -x_98 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_98, 0, x_85); -lean_ctor_set(x_98, 1, x_97); -return x_98; -} -else +lean_inc(x_85); +lean_inc(x_84); +lean_inc(x_83); +lean_inc(x_82); +lean_dec(x_16); +x_122 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_123 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_123, 0, x_82); +lean_ctor_set(x_123, 1, x_83); +lean_ctor_set(x_123, 2, x_122); +lean_ctor_set(x_123, 3, x_85); +lean_ctor_set(x_123, 4, x_86); +lean_ctor_set(x_5, 2, x_123); +x_124 = lean_apply_2(x_3, x_13, x_5); +if (lean_obj_tag(x_124) == 0) { -lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; 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_99 = lean_ctor_get(x_83, 2); -lean_inc(x_99); -x_100 = lean_ctor_get(x_82, 0); -lean_inc(x_100); -lean_dec(x_82); -x_101 = lean_ctor_get(x_83, 0); -lean_inc(x_101); -x_102 = lean_ctor_get(x_83, 1); -lean_inc(x_102); -x_103 = lean_ctor_get(x_83, 3); -lean_inc(x_103); -x_104 = lean_ctor_get(x_83, 4); -lean_inc(x_104); -x_105 = lean_ctor_get(x_83, 5); -lean_inc(x_105); -if (lean_is_exclusive(x_83)) { - lean_ctor_release(x_83, 0); - lean_ctor_release(x_83, 1); - lean_ctor_release(x_83, 2); - lean_ctor_release(x_83, 3); - lean_ctor_release(x_83, 4); - lean_ctor_release(x_83, 5); - x_106 = x_83; -} else { - lean_dec_ref(x_83); - x_106 = lean_box(0); -} -x_107 = lean_ctor_get(x_99, 0); -lean_inc(x_107); -x_108 = lean_ctor_get(x_99, 1); -lean_inc(x_108); -x_109 = lean_ctor_get(x_99, 3); -lean_inc(x_109); -if (lean_is_exclusive(x_99)) { - lean_ctor_release(x_99, 0); - lean_ctor_release(x_99, 1); - lean_ctor_release(x_99, 2); - lean_ctor_release(x_99, 3); - x_110 = x_99; -} else { - lean_dec_ref(x_99); - x_110 = lean_box(0); -} -if (lean_is_scalar(x_110)) { - x_111 = lean_alloc_ctor(0, 4, 0); -} else { - x_111 = x_110; -} -lean_ctor_set(x_111, 0, x_107); -lean_ctor_set(x_111, 1, x_108); -lean_ctor_set(x_111, 2, x_80); -lean_ctor_set(x_111, 3, x_109); -if (lean_is_scalar(x_106)) { - x_112 = lean_alloc_ctor(0, 6, 0); -} else { - x_112 = x_106; -} -lean_ctor_set(x_112, 0, x_101); -lean_ctor_set(x_112, 1, x_102); -lean_ctor_set(x_112, 2, x_111); -lean_ctor_set(x_112, 3, x_103); -lean_ctor_set(x_112, 4, x_104); -lean_ctor_set(x_112, 5, x_105); -x_113 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_113, 0, x_100); -lean_ctor_set(x_113, 1, x_112); -return x_113; -} -} -} -} -else -{ -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_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; -x_124 = lean_ctor_get(x_5, 2); -x_125 = lean_ctor_get(x_5, 0); -x_126 = lean_ctor_get(x_5, 1); -x_127 = lean_ctor_get(x_5, 3); -x_128 = lean_ctor_get(x_5, 4); -x_129 = lean_ctor_get(x_5, 5); -lean_inc(x_129); -lean_inc(x_128); -lean_inc(x_127); -lean_inc(x_124); -lean_inc(x_126); +lean_object* x_125; lean_object* x_126; lean_object* x_127; +x_125 = lean_ctor_get(x_124, 0); lean_inc(x_125); -lean_dec(x_5); -x_130 = lean_ctor_get(x_124, 0); -lean_inc(x_130); -x_131 = lean_ctor_get(x_124, 1); +x_126 = lean_ctor_get(x_124, 1); +lean_inc(x_126); +lean_dec(x_124); +x_127 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_127, 0, x_125); +x_87 = x_127; +x_88 = x_126; +goto block_121; +} +else +{ +lean_object* x_128; lean_object* x_129; lean_object* x_130; +x_128 = lean_ctor_get(x_124, 0); +lean_inc(x_128); +x_129 = lean_ctor_get(x_124, 1); +lean_inc(x_129); +lean_dec(x_124); +x_130 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_130, 0, x_128); +x_87 = x_130; +x_88 = x_129; +goto block_121; +} +block_121: +{ +if (lean_obj_tag(x_87) == 0) +{ +lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; +x_89 = lean_ctor_get(x_88, 2); +lean_inc(x_89); +x_90 = lean_ctor_get(x_87, 0); +lean_inc(x_90); +lean_dec(x_87); +x_91 = lean_ctor_get(x_88, 0); +lean_inc(x_91); +x_92 = lean_ctor_get(x_88, 1); +lean_inc(x_92); +x_93 = lean_ctor_get(x_88, 3); +lean_inc(x_93); +x_94 = lean_ctor_get(x_88, 4); +lean_inc(x_94); +x_95 = lean_ctor_get(x_88, 5); +lean_inc(x_95); +if (lean_is_exclusive(x_88)) { + lean_ctor_release(x_88, 0); + lean_ctor_release(x_88, 1); + lean_ctor_release(x_88, 2); + lean_ctor_release(x_88, 3); + lean_ctor_release(x_88, 4); + lean_ctor_release(x_88, 5); + x_96 = x_88; +} else { + lean_dec_ref(x_88); + x_96 = lean_box(0); +} +x_97 = lean_ctor_get(x_89, 0); +lean_inc(x_97); +x_98 = lean_ctor_get(x_89, 1); +lean_inc(x_98); +x_99 = lean_ctor_get(x_89, 3); +lean_inc(x_99); +x_100 = lean_ctor_get(x_89, 4); +lean_inc(x_100); +if (lean_is_exclusive(x_89)) { + lean_ctor_release(x_89, 0); + lean_ctor_release(x_89, 1); + lean_ctor_release(x_89, 2); + lean_ctor_release(x_89, 3); + lean_ctor_release(x_89, 4); + x_101 = x_89; +} else { + lean_dec_ref(x_89); + x_101 = lean_box(0); +} +if (lean_is_scalar(x_101)) { + x_102 = lean_alloc_ctor(0, 5, 0); +} else { + x_102 = x_101; +} +lean_ctor_set(x_102, 0, x_97); +lean_ctor_set(x_102, 1, x_98); +lean_ctor_set(x_102, 2, x_84); +lean_ctor_set(x_102, 3, x_99); +lean_ctor_set(x_102, 4, x_100); +if (lean_is_scalar(x_96)) { + x_103 = lean_alloc_ctor(0, 6, 0); +} else { + x_103 = x_96; +} +lean_ctor_set(x_103, 0, x_91); +lean_ctor_set(x_103, 1, x_92); +lean_ctor_set(x_103, 2, x_102); +lean_ctor_set(x_103, 3, x_93); +lean_ctor_set(x_103, 4, x_94); +lean_ctor_set(x_103, 5, x_95); +x_104 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_104, 0, x_90); +lean_ctor_set(x_104, 1, x_103); +return x_104; +} +else +{ +lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; +x_105 = lean_ctor_get(x_88, 2); +lean_inc(x_105); +x_106 = lean_ctor_get(x_87, 0); +lean_inc(x_106); +lean_dec(x_87); +x_107 = lean_ctor_get(x_88, 0); +lean_inc(x_107); +x_108 = lean_ctor_get(x_88, 1); +lean_inc(x_108); +x_109 = lean_ctor_get(x_88, 3); +lean_inc(x_109); +x_110 = lean_ctor_get(x_88, 4); +lean_inc(x_110); +x_111 = lean_ctor_get(x_88, 5); +lean_inc(x_111); +if (lean_is_exclusive(x_88)) { + lean_ctor_release(x_88, 0); + lean_ctor_release(x_88, 1); + lean_ctor_release(x_88, 2); + lean_ctor_release(x_88, 3); + lean_ctor_release(x_88, 4); + lean_ctor_release(x_88, 5); + x_112 = x_88; +} else { + lean_dec_ref(x_88); + x_112 = lean_box(0); +} +x_113 = lean_ctor_get(x_105, 0); +lean_inc(x_113); +x_114 = lean_ctor_get(x_105, 1); +lean_inc(x_114); +x_115 = lean_ctor_get(x_105, 3); +lean_inc(x_115); +x_116 = lean_ctor_get(x_105, 4); +lean_inc(x_116); +if (lean_is_exclusive(x_105)) { + lean_ctor_release(x_105, 0); + lean_ctor_release(x_105, 1); + lean_ctor_release(x_105, 2); + lean_ctor_release(x_105, 3); + lean_ctor_release(x_105, 4); + x_117 = x_105; +} else { + lean_dec_ref(x_105); + x_117 = lean_box(0); +} +if (lean_is_scalar(x_117)) { + x_118 = lean_alloc_ctor(0, 5, 0); +} else { + x_118 = x_117; +} +lean_ctor_set(x_118, 0, x_113); +lean_ctor_set(x_118, 1, x_114); +lean_ctor_set(x_118, 2, x_84); +lean_ctor_set(x_118, 3, x_115); +lean_ctor_set(x_118, 4, x_116); +if (lean_is_scalar(x_112)) { + x_119 = lean_alloc_ctor(0, 6, 0); +} else { + x_119 = x_112; +} +lean_ctor_set(x_119, 0, x_107); +lean_ctor_set(x_119, 1, x_108); +lean_ctor_set(x_119, 2, x_118); +lean_ctor_set(x_119, 3, x_109); +lean_ctor_set(x_119, 4, x_110); +lean_ctor_set(x_119, 5, x_111); +x_120 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_120, 0, x_106); +lean_ctor_set(x_120, 1, x_119); +return x_120; +} +} +} +} +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; 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_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; +x_131 = lean_ctor_get(x_5, 2); +x_132 = lean_ctor_get(x_5, 0); +x_133 = lean_ctor_get(x_5, 1); +x_134 = lean_ctor_get(x_5, 3); +x_135 = lean_ctor_get(x_5, 4); +x_136 = lean_ctor_get(x_5, 5); +lean_inc(x_136); +lean_inc(x_135); +lean_inc(x_134); lean_inc(x_131); -x_132 = lean_ctor_get(x_124, 2); -lean_inc(x_132); -x_133 = lean_ctor_get(x_124, 3); lean_inc(x_133); -if (lean_is_exclusive(x_124)) { - lean_ctor_release(x_124, 0); - lean_ctor_release(x_124, 1); - lean_ctor_release(x_124, 2); - lean_ctor_release(x_124, 3); - x_134 = x_124; -} else { - lean_dec_ref(x_124); - x_134 = lean_box(0); -} -x_168 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_134)) { - x_169 = lean_alloc_ctor(0, 4, 0); -} else { - x_169 = x_134; -} -lean_ctor_set(x_169, 0, x_130); -lean_ctor_set(x_169, 1, x_131); -lean_ctor_set(x_169, 2, x_168); -lean_ctor_set(x_169, 3, x_133); -x_170 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_170, 0, x_125); -lean_ctor_set(x_170, 1, x_126); -lean_ctor_set(x_170, 2, x_169); -lean_ctor_set(x_170, 3, x_127); -lean_ctor_set(x_170, 4, x_128); -lean_ctor_set(x_170, 5, x_129); -x_171 = lean_apply_2(x_3, x_13, x_170); -if (lean_obj_tag(x_171) == 0) -{ -lean_object* x_172; lean_object* x_173; lean_object* x_174; -x_172 = lean_ctor_get(x_171, 0); -lean_inc(x_172); -x_173 = lean_ctor_get(x_171, 1); -lean_inc(x_173); -lean_dec(x_171); -x_174 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_174, 0, x_172); -x_135 = x_174; -x_136 = x_173; -goto block_167; -} -else -{ -lean_object* x_175; lean_object* x_176; lean_object* x_177; -x_175 = lean_ctor_get(x_171, 0); -lean_inc(x_175); -x_176 = lean_ctor_get(x_171, 1); -lean_inc(x_176); -lean_dec(x_171); -x_177 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_177, 0, x_175); -x_135 = x_177; -x_136 = x_176; -goto block_167; -} -block_167: -{ -if (lean_obj_tag(x_135) == 0) -{ -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; -x_137 = lean_ctor_get(x_136, 2); +lean_inc(x_132); +lean_dec(x_5); +x_137 = lean_ctor_get(x_131, 0); lean_inc(x_137); -x_138 = lean_ctor_get(x_135, 0); +x_138 = lean_ctor_get(x_131, 1); lean_inc(x_138); -lean_dec(x_135); -x_139 = lean_ctor_get(x_136, 0); +x_139 = lean_ctor_get(x_131, 2); lean_inc(x_139); -x_140 = lean_ctor_get(x_136, 1); +x_140 = lean_ctor_get(x_131, 3); lean_inc(x_140); -x_141 = lean_ctor_get(x_136, 3); +x_141 = lean_ctor_get(x_131, 4); lean_inc(x_141); -x_142 = lean_ctor_get(x_136, 4); -lean_inc(x_142); -x_143 = lean_ctor_get(x_136, 5); -lean_inc(x_143); -if (lean_is_exclusive(x_136)) { - lean_ctor_release(x_136, 0); - lean_ctor_release(x_136, 1); - lean_ctor_release(x_136, 2); - lean_ctor_release(x_136, 3); - lean_ctor_release(x_136, 4); - lean_ctor_release(x_136, 5); - x_144 = x_136; +if (lean_is_exclusive(x_131)) { + lean_ctor_release(x_131, 0); + lean_ctor_release(x_131, 1); + lean_ctor_release(x_131, 2); + lean_ctor_release(x_131, 3); + lean_ctor_release(x_131, 4); + x_142 = x_131; } else { - lean_dec_ref(x_136); - x_144 = lean_box(0); + lean_dec_ref(x_131); + x_142 = lean_box(0); } -x_145 = lean_ctor_get(x_137, 0); -lean_inc(x_145); -x_146 = lean_ctor_get(x_137, 1); -lean_inc(x_146); -x_147 = lean_ctor_get(x_137, 3); -lean_inc(x_147); -if (lean_is_exclusive(x_137)) { - lean_ctor_release(x_137, 0); - lean_ctor_release(x_137, 1); - lean_ctor_release(x_137, 2); - lean_ctor_release(x_137, 3); - x_148 = x_137; +x_178 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_142)) { + x_179 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_137); - x_148 = lean_box(0); + x_179 = x_142; } -if (lean_is_scalar(x_148)) { - x_149 = lean_alloc_ctor(0, 4, 0); -} else { - x_149 = x_148; -} -lean_ctor_set(x_149, 0, x_145); -lean_ctor_set(x_149, 1, x_146); -lean_ctor_set(x_149, 2, x_132); -lean_ctor_set(x_149, 3, x_147); -if (lean_is_scalar(x_144)) { - x_150 = lean_alloc_ctor(0, 6, 0); -} else { - x_150 = x_144; -} -lean_ctor_set(x_150, 0, x_139); -lean_ctor_set(x_150, 1, x_140); -lean_ctor_set(x_150, 2, x_149); -lean_ctor_set(x_150, 3, x_141); -lean_ctor_set(x_150, 4, x_142); -lean_ctor_set(x_150, 5, x_143); -x_151 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_151, 0, x_138); -lean_ctor_set(x_151, 1, x_150); -return x_151; +lean_ctor_set(x_179, 0, x_137); +lean_ctor_set(x_179, 1, x_138); +lean_ctor_set(x_179, 2, x_178); +lean_ctor_set(x_179, 3, x_140); +lean_ctor_set(x_179, 4, x_141); +x_180 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_180, 0, x_132); +lean_ctor_set(x_180, 1, x_133); +lean_ctor_set(x_180, 2, x_179); +lean_ctor_set(x_180, 3, x_134); +lean_ctor_set(x_180, 4, x_135); +lean_ctor_set(x_180, 5, x_136); +x_181 = lean_apply_2(x_3, x_13, 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_inc(x_183); +lean_dec(x_181); +x_184 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_184, 0, x_182); +x_143 = x_184; +x_144 = x_183; +goto block_177; } else { -lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; -x_152 = lean_ctor_get(x_136, 2); -lean_inc(x_152); -x_153 = lean_ctor_get(x_135, 0); +lean_object* x_185; lean_object* x_186; lean_object* x_187; +x_185 = lean_ctor_get(x_181, 0); +lean_inc(x_185); +x_186 = lean_ctor_get(x_181, 1); +lean_inc(x_186); +lean_dec(x_181); +x_187 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_187, 0, x_185); +x_143 = x_187; +x_144 = x_186; +goto block_177; +} +block_177: +{ +if (lean_obj_tag(x_143) == 0) +{ +lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; +x_145 = lean_ctor_get(x_144, 2); +lean_inc(x_145); +x_146 = lean_ctor_get(x_143, 0); +lean_inc(x_146); +lean_dec(x_143); +x_147 = lean_ctor_get(x_144, 0); +lean_inc(x_147); +x_148 = lean_ctor_get(x_144, 1); +lean_inc(x_148); +x_149 = lean_ctor_get(x_144, 3); +lean_inc(x_149); +x_150 = lean_ctor_get(x_144, 4); +lean_inc(x_150); +x_151 = lean_ctor_get(x_144, 5); +lean_inc(x_151); +if (lean_is_exclusive(x_144)) { + lean_ctor_release(x_144, 0); + lean_ctor_release(x_144, 1); + lean_ctor_release(x_144, 2); + lean_ctor_release(x_144, 3); + lean_ctor_release(x_144, 4); + lean_ctor_release(x_144, 5); + x_152 = x_144; +} else { + lean_dec_ref(x_144); + x_152 = lean_box(0); +} +x_153 = lean_ctor_get(x_145, 0); lean_inc(x_153); -lean_dec(x_135); -x_154 = lean_ctor_get(x_136, 0); +x_154 = lean_ctor_get(x_145, 1); lean_inc(x_154); -x_155 = lean_ctor_get(x_136, 1); +x_155 = lean_ctor_get(x_145, 3); lean_inc(x_155); -x_156 = lean_ctor_get(x_136, 3); +x_156 = lean_ctor_get(x_145, 4); lean_inc(x_156); -x_157 = lean_ctor_get(x_136, 4); -lean_inc(x_157); -x_158 = lean_ctor_get(x_136, 5); -lean_inc(x_158); -if (lean_is_exclusive(x_136)) { - lean_ctor_release(x_136, 0); - lean_ctor_release(x_136, 1); - lean_ctor_release(x_136, 2); - lean_ctor_release(x_136, 3); - lean_ctor_release(x_136, 4); - lean_ctor_release(x_136, 5); - x_159 = x_136; +if (lean_is_exclusive(x_145)) { + lean_ctor_release(x_145, 0); + lean_ctor_release(x_145, 1); + lean_ctor_release(x_145, 2); + lean_ctor_release(x_145, 3); + lean_ctor_release(x_145, 4); + x_157 = x_145; } else { - lean_dec_ref(x_136); - x_159 = lean_box(0); + lean_dec_ref(x_145); + x_157 = lean_box(0); } -x_160 = lean_ctor_get(x_152, 0); -lean_inc(x_160); -x_161 = lean_ctor_get(x_152, 1); +if (lean_is_scalar(x_157)) { + x_158 = lean_alloc_ctor(0, 5, 0); +} else { + x_158 = x_157; +} +lean_ctor_set(x_158, 0, x_153); +lean_ctor_set(x_158, 1, x_154); +lean_ctor_set(x_158, 2, x_139); +lean_ctor_set(x_158, 3, x_155); +lean_ctor_set(x_158, 4, x_156); +if (lean_is_scalar(x_152)) { + x_159 = lean_alloc_ctor(0, 6, 0); +} else { + x_159 = x_152; +} +lean_ctor_set(x_159, 0, x_147); +lean_ctor_set(x_159, 1, x_148); +lean_ctor_set(x_159, 2, x_158); +lean_ctor_set(x_159, 3, x_149); +lean_ctor_set(x_159, 4, x_150); +lean_ctor_set(x_159, 5, x_151); +x_160 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_160, 0, x_146); +lean_ctor_set(x_160, 1, x_159); +return x_160; +} +else +{ +lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; lean_object* x_173; lean_object* x_174; lean_object* x_175; lean_object* x_176; +x_161 = lean_ctor_get(x_144, 2); lean_inc(x_161); -x_162 = lean_ctor_get(x_152, 3); +x_162 = lean_ctor_get(x_143, 0); lean_inc(x_162); -if (lean_is_exclusive(x_152)) { - lean_ctor_release(x_152, 0); - lean_ctor_release(x_152, 1); - lean_ctor_release(x_152, 2); - lean_ctor_release(x_152, 3); - x_163 = x_152; +lean_dec(x_143); +x_163 = lean_ctor_get(x_144, 0); +lean_inc(x_163); +x_164 = lean_ctor_get(x_144, 1); +lean_inc(x_164); +x_165 = lean_ctor_get(x_144, 3); +lean_inc(x_165); +x_166 = lean_ctor_get(x_144, 4); +lean_inc(x_166); +x_167 = lean_ctor_get(x_144, 5); +lean_inc(x_167); +if (lean_is_exclusive(x_144)) { + lean_ctor_release(x_144, 0); + lean_ctor_release(x_144, 1); + lean_ctor_release(x_144, 2); + lean_ctor_release(x_144, 3); + lean_ctor_release(x_144, 4); + lean_ctor_release(x_144, 5); + x_168 = x_144; } else { - lean_dec_ref(x_152); - x_163 = lean_box(0); + lean_dec_ref(x_144); + x_168 = lean_box(0); } -if (lean_is_scalar(x_163)) { - x_164 = lean_alloc_ctor(0, 4, 0); +x_169 = lean_ctor_get(x_161, 0); +lean_inc(x_169); +x_170 = lean_ctor_get(x_161, 1); +lean_inc(x_170); +x_171 = lean_ctor_get(x_161, 3); +lean_inc(x_171); +x_172 = lean_ctor_get(x_161, 4); +lean_inc(x_172); +if (lean_is_exclusive(x_161)) { + lean_ctor_release(x_161, 0); + lean_ctor_release(x_161, 1); + lean_ctor_release(x_161, 2); + lean_ctor_release(x_161, 3); + lean_ctor_release(x_161, 4); + x_173 = x_161; } else { - x_164 = x_163; + lean_dec_ref(x_161); + x_173 = lean_box(0); } -lean_ctor_set(x_164, 0, x_160); -lean_ctor_set(x_164, 1, x_161); -lean_ctor_set(x_164, 2, x_132); -lean_ctor_set(x_164, 3, x_162); -if (lean_is_scalar(x_159)) { - x_165 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_173)) { + x_174 = lean_alloc_ctor(0, 5, 0); } else { - x_165 = x_159; + x_174 = x_173; } -lean_ctor_set(x_165, 0, x_154); -lean_ctor_set(x_165, 1, x_155); -lean_ctor_set(x_165, 2, x_164); -lean_ctor_set(x_165, 3, x_156); -lean_ctor_set(x_165, 4, x_157); -lean_ctor_set(x_165, 5, x_158); -x_166 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_166, 0, x_153); -lean_ctor_set(x_166, 1, x_165); -return x_166; +lean_ctor_set(x_174, 0, x_169); +lean_ctor_set(x_174, 1, x_170); +lean_ctor_set(x_174, 2, x_139); +lean_ctor_set(x_174, 3, x_171); +lean_ctor_set(x_174, 4, x_172); +if (lean_is_scalar(x_168)) { + x_175 = lean_alloc_ctor(0, 6, 0); +} else { + x_175 = x_168; +} +lean_ctor_set(x_175, 0, x_163); +lean_ctor_set(x_175, 1, x_164); +lean_ctor_set(x_175, 2, x_174); +lean_ctor_set(x_175, 3, x_165); +lean_ctor_set(x_175, 4, x_166); +lean_ctor_set(x_175, 5, x_167); +x_176 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_176, 0, x_162); +lean_ctor_set(x_176, 1, x_175); +return x_176; } } } @@ -45531,106 +46968,77 @@ return x_2; lean_object* l_Lean_Meta_mkAuxDefinition(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { _start: { -lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; uint8_t x_15; lean_object* x_16; +lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; uint8_t x_11; lean_object* x_12; x_6 = lean_ctor_get(x_5, 0); lean_inc(x_6); -x_7 = lean_ctor_get(x_5, 1); +x_7 = lean_ctor_get(x_4, 0); lean_inc(x_7); -x_8 = lean_ctor_get(x_5, 2); +x_8 = lean_ctor_get(x_7, 0); lean_inc(x_8); -x_9 = lean_ctor_get(x_5, 3); +lean_dec(x_7); +x_9 = lean_ctor_get(x_5, 1); lean_inc(x_9); -x_10 = lean_ctor_get(x_5, 4); +x_10 = lean_ctor_get(x_4, 1); lean_inc(x_10); -x_11 = lean_ctor_get(x_5, 5); -lean_inc(x_11); -x_12 = lean_ctor_get(x_4, 0); -lean_inc(x_12); +x_11 = 0; +x_12 = l_Lean_mkAuxDefinition(x_6, x_8, x_9, x_10, x_1, x_2, x_3, x_11); +if (lean_obj_tag(x_12) == 0) +{ +lean_object* x_13; lean_object* x_14; lean_object* x_15; +lean_dec(x_4); x_13 = lean_ctor_get(x_12, 0); lean_inc(x_13); lean_dec(x_12); -x_14 = lean_ctor_get(x_4, 1); -lean_inc(x_14); -lean_dec(x_4); -x_15 = 0; -lean_inc(x_7); -x_16 = l_Lean_mkAuxDefinition(x_6, x_13, x_7, x_14, x_1, x_2, x_3, x_15); -if (lean_obj_tag(x_16) == 0) +x_14 = lean_alloc_ctor(20, 2, 0); +lean_ctor_set(x_14, 0, x_13); +lean_ctor_set(x_14, 1, x_8); +x_15 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_15, 0, x_14); +lean_ctor_set(x_15, 1, x_5); +return x_15; +} +else { -lean_object* x_17; lean_object* x_18; lean_object* x_19; -lean_dec(x_11); -lean_dec(x_10); -lean_dec(x_9); +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; uint8_t x_24; lean_dec(x_8); -lean_dec(x_7); -x_17 = lean_ctor_get(x_16, 0); +x_16 = lean_ctor_get(x_12, 0); +lean_inc(x_16); +lean_dec(x_12); +x_17 = lean_ctor_get(x_16, 1); lean_inc(x_17); +x_18 = lean_ctor_get(x_16, 0); +lean_inc(x_18); lean_dec(x_16); -x_18 = lean_alloc_ctor(20, 2, 0); -lean_ctor_set(x_18, 0, x_17); -lean_ctor_set(x_18, 1, x_13); -x_19 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_19, 0, x_18); -lean_ctor_set(x_19, 1, x_5); -return x_19; -} -else -{ -uint8_t x_20; -lean_dec(x_13); -x_20 = !lean_is_exclusive(x_5); -if (x_20 == 0) -{ -lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; -x_21 = lean_ctor_get(x_5, 5); +x_19 = lean_ctor_get(x_17, 0); +lean_inc(x_19); +x_20 = lean_ctor_get(x_17, 1); +lean_inc(x_20); +lean_dec(x_17); +x_21 = l_Lean_Meta_setEnv(x_19, x_4, x_5); +x_22 = lean_ctor_get(x_21, 1); +lean_inc(x_22); lean_dec(x_21); -x_22 = lean_ctor_get(x_5, 4); -lean_dec(x_22); -x_23 = lean_ctor_get(x_5, 3); -lean_dec(x_23); -x_24 = lean_ctor_get(x_5, 2); -lean_dec(x_24); -x_25 = lean_ctor_get(x_5, 1); +x_23 = l_Lean_Meta_setMCtx(x_20, x_4, x_22); +lean_dec(x_4); +x_24 = !lean_is_exclusive(x_23); +if (x_24 == 0) +{ +lean_object* x_25; +x_25 = lean_ctor_get(x_23, 0); lean_dec(x_25); -x_26 = lean_ctor_get(x_5, 0); -lean_dec(x_26); -x_27 = lean_ctor_get(x_16, 0); -lean_inc(x_27); -lean_dec(x_16); -x_28 = lean_ctor_get(x_27, 0); -lean_inc(x_28); -x_29 = lean_ctor_get(x_27, 1); -lean_inc(x_29); -lean_dec(x_27); -lean_ctor_set(x_5, 0, x_29); -x_30 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_30, 0, x_28); -lean_ctor_set(x_30, 1, x_5); -return x_30; +lean_ctor_set(x_23, 0, x_18); +return x_23; } else { -lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; -lean_dec(x_5); -x_31 = lean_ctor_get(x_16, 0); -lean_inc(x_31); -lean_dec(x_16); -x_32 = lean_ctor_get(x_31, 0); -lean_inc(x_32); -x_33 = lean_ctor_get(x_31, 1); -lean_inc(x_33); -lean_dec(x_31); -x_34 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_34, 0, x_33); -lean_ctor_set(x_34, 1, x_7); -lean_ctor_set(x_34, 2, x_8); -lean_ctor_set(x_34, 3, x_9); -lean_ctor_set(x_34, 4, x_10); -lean_ctor_set(x_34, 5, x_11); -x_35 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_35, 0, x_32); -lean_ctor_set(x_35, 1, x_34); -return x_35; +lean_object* x_26; lean_object* x_27; +x_26 = lean_ctor_get(x_23, 1); +lean_inc(x_26); +lean_dec(x_23); +x_27 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_27, 0, x_18); +lean_ctor_set(x_27, 1, x_26); +return x_27; } } } @@ -46021,11 +47429,12 @@ lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; x_1 = l_Std_PersistentHashMap_empty___at_Lean_Meta_run___spec__1; x_2 = l_Lean_Meta_run___rarg___closed__4; x_3 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_4 = lean_alloc_ctor(0, 4, 0); +x_4 = lean_alloc_ctor(0, 5, 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); lean_ctor_set(x_4, 3, x_1); +lean_ctor_set(x_4, 4, x_1); return x_4; } } diff --git a/stage0/stdlib/Lean/Meta/ExprDefEq.c b/stage0/stdlib/Lean/Meta/ExprDefEq.c index 94da1f729d..ede5261c85 100644 --- a/stage0/stdlib/Lean/Meta/ExprDefEq.c +++ b/stage0/stdlib/Lean/Meta/ExprDefEq.c @@ -3665,105 +3665,105 @@ x_37 = lean_ctor_get(x_31, 2); x_38 = !lean_is_exclusive(x_37); if (x_38 == 0) { -lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_91; uint8_t x_92; +lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_95; uint8_t x_96; x_39 = lean_ctor_get(x_37, 2); -x_91 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_37, 2, x_91); -x_92 = !lean_is_exclusive(x_5); -if (x_92 == 0) +x_95 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_37, 2, x_95); +x_96 = !lean_is_exclusive(x_5); +if (x_96 == 0) { -lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; -x_93 = lean_ctor_get(x_5, 2); -x_94 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_94, 0, x_33); -lean_ctor_set(x_94, 1, x_10); -x_95 = lean_array_push(x_93, x_94); -lean_ctor_set(x_5, 2, x_95); -x_96 = l_Lean_Meta_isDefEqBindingDomain___main(x_1, x_2, x_35, x_4, x_5, x_31); -if (lean_obj_tag(x_96) == 0) +lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; +x_97 = lean_ctor_get(x_5, 2); +x_98 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_98, 0, x_33); +lean_ctor_set(x_98, 1, x_10); +x_99 = lean_array_push(x_97, x_98); +lean_ctor_set(x_5, 2, x_99); +x_100 = l_Lean_Meta_isDefEqBindingDomain___main(x_1, x_2, x_35, x_4, x_5, x_31); +if (lean_obj_tag(x_100) == 0) { -lean_object* x_97; lean_object* x_98; lean_object* x_99; -x_97 = lean_ctor_get(x_96, 0); -lean_inc(x_97); -x_98 = lean_ctor_get(x_96, 1); -lean_inc(x_98); -lean_dec(x_96); -x_99 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_99, 0, x_97); -x_40 = x_99; -x_41 = x_98; -goto block_90; -} -else -{ -lean_object* x_100; lean_object* x_101; lean_object* x_102; -x_100 = lean_ctor_get(x_96, 0); -lean_inc(x_100); -x_101 = lean_ctor_get(x_96, 1); +lean_object* x_101; lean_object* x_102; lean_object* x_103; +x_101 = lean_ctor_get(x_100, 0); lean_inc(x_101); -lean_dec(x_96); -x_102 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_102, 0, x_100); -x_40 = x_102; -x_41 = x_101; -goto block_90; -} +x_102 = lean_ctor_get(x_100, 1); +lean_inc(x_102); +lean_dec(x_100); +x_103 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_103, 0, x_101); +x_40 = x_103; +x_41 = x_102; +goto block_94; } else { -lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; -x_103 = lean_ctor_get(x_5, 0); -x_104 = lean_ctor_get(x_5, 1); -x_105 = lean_ctor_get(x_5, 2); -x_106 = lean_ctor_get(x_5, 3); -x_107 = lean_ctor_get(x_5, 4); -lean_inc(x_107); -lean_inc(x_106); -lean_inc(x_105); +lean_object* x_104; lean_object* x_105; lean_object* x_106; +x_104 = lean_ctor_get(x_100, 0); lean_inc(x_104); -lean_inc(x_103); -lean_dec(x_5); -x_108 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_108, 0, x_33); -lean_ctor_set(x_108, 1, x_10); -x_109 = lean_array_push(x_105, x_108); -x_110 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_110, 0, x_103); -lean_ctor_set(x_110, 1, x_104); -lean_ctor_set(x_110, 2, x_109); -lean_ctor_set(x_110, 3, x_106); -lean_ctor_set(x_110, 4, x_107); -x_111 = l_Lean_Meta_isDefEqBindingDomain___main(x_1, x_2, x_35, x_4, x_110, x_31); -if (lean_obj_tag(x_111) == 0) -{ -lean_object* x_112; lean_object* x_113; lean_object* x_114; -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_alloc_ctor(1, 1, 0); -lean_ctor_set(x_114, 0, x_112); -x_40 = x_114; -x_41 = x_113; -goto block_90; +x_105 = lean_ctor_get(x_100, 1); +lean_inc(x_105); +lean_dec(x_100); +x_106 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_106, 0, x_104); +x_40 = x_106; +x_41 = x_105; +goto block_94; +} } else { -lean_object* x_115; lean_object* x_116; lean_object* x_117; -x_115 = lean_ctor_get(x_111, 0); -lean_inc(x_115); -x_116 = lean_ctor_get(x_111, 1); +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; +x_107 = lean_ctor_get(x_5, 0); +x_108 = lean_ctor_get(x_5, 1); +x_109 = lean_ctor_get(x_5, 2); +x_110 = lean_ctor_get(x_5, 3); +x_111 = lean_ctor_get(x_5, 4); +lean_inc(x_111); +lean_inc(x_110); +lean_inc(x_109); +lean_inc(x_108); +lean_inc(x_107); +lean_dec(x_5); +x_112 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_112, 0, x_33); +lean_ctor_set(x_112, 1, x_10); +x_113 = lean_array_push(x_109, x_112); +x_114 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_114, 0, x_107); +lean_ctor_set(x_114, 1, x_108); +lean_ctor_set(x_114, 2, x_113); +lean_ctor_set(x_114, 3, x_110); +lean_ctor_set(x_114, 4, x_111); +x_115 = l_Lean_Meta_isDefEqBindingDomain___main(x_1, x_2, x_35, x_4, x_114, x_31); +if (lean_obj_tag(x_115) == 0) +{ +lean_object* x_116; lean_object* x_117; lean_object* x_118; +x_116 = lean_ctor_get(x_115, 0); lean_inc(x_116); -lean_dec(x_111); -x_117 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_117, 0, x_115); -x_40 = x_117; -x_41 = x_116; -goto block_90; +x_117 = lean_ctor_get(x_115, 1); +lean_inc(x_117); +lean_dec(x_115); +x_118 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_118, 0, x_116); +x_40 = x_118; +x_41 = x_117; +goto block_94; +} +else +{ +lean_object* x_119; lean_object* x_120; lean_object* x_121; +x_119 = lean_ctor_get(x_115, 0); +lean_inc(x_119); +x_120 = lean_ctor_get(x_115, 1); +lean_inc(x_120); +lean_dec(x_115); +x_121 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_121, 0, x_119); +x_40 = x_121; +x_41 = x_120; +goto block_94; } } -block_90: +block_94: { if (lean_obj_tag(x_40) == 0) { @@ -3798,708 +3798,745 @@ return x_48; } else { -lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; +lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; x_49 = lean_ctor_get(x_42, 0); x_50 = lean_ctor_get(x_42, 1); x_51 = lean_ctor_get(x_42, 3); +x_52 = lean_ctor_get(x_42, 4); +lean_inc(x_52); lean_inc(x_51); lean_inc(x_50); lean_inc(x_49); lean_dec(x_42); -x_52 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_52, 0, x_49); -lean_ctor_set(x_52, 1, x_50); -lean_ctor_set(x_52, 2, x_39); -lean_ctor_set(x_52, 3, x_51); -lean_ctor_set(x_41, 2, x_52); +x_53 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_53, 0, x_49); +lean_ctor_set(x_53, 1, x_50); +lean_ctor_set(x_53, 2, x_39); +lean_ctor_set(x_53, 3, x_51); +lean_ctor_set(x_53, 4, x_52); +lean_ctor_set(x_41, 2, x_53); if (lean_is_scalar(x_32)) { - x_53 = lean_alloc_ctor(1, 2, 0); + x_54 = lean_alloc_ctor(1, 2, 0); } else { - x_53 = x_32; - lean_ctor_set_tag(x_53, 1); + x_54 = x_32; + lean_ctor_set_tag(x_54, 1); } -lean_ctor_set(x_53, 0, x_43); -lean_ctor_set(x_53, 1, x_41); -return x_53; +lean_ctor_set(x_54, 0, x_43); +lean_ctor_set(x_54, 1, x_41); +return x_54; } } else { -lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; -x_54 = lean_ctor_get(x_41, 0); -x_55 = lean_ctor_get(x_41, 1); -x_56 = lean_ctor_get(x_41, 3); -x_57 = lean_ctor_get(x_41, 4); -x_58 = lean_ctor_get(x_41, 5); +lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; +x_55 = lean_ctor_get(x_41, 0); +x_56 = lean_ctor_get(x_41, 1); +x_57 = lean_ctor_get(x_41, 3); +x_58 = lean_ctor_get(x_41, 4); +x_59 = lean_ctor_get(x_41, 5); +lean_inc(x_59); lean_inc(x_58); lean_inc(x_57); lean_inc(x_56); lean_inc(x_55); -lean_inc(x_54); lean_dec(x_41); -x_59 = lean_ctor_get(x_42, 0); -lean_inc(x_59); -x_60 = lean_ctor_get(x_42, 1); +x_60 = lean_ctor_get(x_42, 0); lean_inc(x_60); -x_61 = lean_ctor_get(x_42, 3); +x_61 = lean_ctor_get(x_42, 1); lean_inc(x_61); +x_62 = lean_ctor_get(x_42, 3); +lean_inc(x_62); +x_63 = lean_ctor_get(x_42, 4); +lean_inc(x_63); if (lean_is_exclusive(x_42)) { lean_ctor_release(x_42, 0); lean_ctor_release(x_42, 1); lean_ctor_release(x_42, 2); lean_ctor_release(x_42, 3); - x_62 = x_42; + lean_ctor_release(x_42, 4); + x_64 = x_42; } else { lean_dec_ref(x_42); - x_62 = lean_box(0); + x_64 = lean_box(0); } -if (lean_is_scalar(x_62)) { - x_63 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_64)) { + x_65 = lean_alloc_ctor(0, 5, 0); } else { - x_63 = x_62; + x_65 = x_64; } -lean_ctor_set(x_63, 0, x_59); -lean_ctor_set(x_63, 1, x_60); -lean_ctor_set(x_63, 2, x_39); -lean_ctor_set(x_63, 3, x_61); -x_64 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_64, 0, x_54); -lean_ctor_set(x_64, 1, x_55); -lean_ctor_set(x_64, 2, x_63); -lean_ctor_set(x_64, 3, x_56); -lean_ctor_set(x_64, 4, x_57); -lean_ctor_set(x_64, 5, x_58); +lean_ctor_set(x_65, 0, x_60); +lean_ctor_set(x_65, 1, x_61); +lean_ctor_set(x_65, 2, x_39); +lean_ctor_set(x_65, 3, x_62); +lean_ctor_set(x_65, 4, x_63); +x_66 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_66, 0, x_55); +lean_ctor_set(x_66, 1, x_56); +lean_ctor_set(x_66, 2, x_65); +lean_ctor_set(x_66, 3, x_57); +lean_ctor_set(x_66, 4, x_58); +lean_ctor_set(x_66, 5, x_59); if (lean_is_scalar(x_32)) { - x_65 = lean_alloc_ctor(1, 2, 0); + x_67 = lean_alloc_ctor(1, 2, 0); } else { - x_65 = x_32; - lean_ctor_set_tag(x_65, 1); + x_67 = x_32; + lean_ctor_set_tag(x_67, 1); } -lean_ctor_set(x_65, 0, x_43); -lean_ctor_set(x_65, 1, x_64); -return x_65; +lean_ctor_set(x_67, 0, x_43); +lean_ctor_set(x_67, 1, x_66); +return x_67; } } else { -lean_object* x_66; lean_object* x_67; uint8_t x_68; -x_66 = lean_ctor_get(x_41, 2); -lean_inc(x_66); -x_67 = lean_ctor_get(x_40, 0); -lean_inc(x_67); +lean_object* x_68; lean_object* x_69; uint8_t x_70; +x_68 = lean_ctor_get(x_41, 2); +lean_inc(x_68); +x_69 = lean_ctor_get(x_40, 0); +lean_inc(x_69); lean_dec(x_40); -x_68 = !lean_is_exclusive(x_41); -if (x_68 == 0) -{ -lean_object* x_69; uint8_t x_70; -x_69 = lean_ctor_get(x_41, 2); -lean_dec(x_69); -x_70 = !lean_is_exclusive(x_66); +x_70 = !lean_is_exclusive(x_41); if (x_70 == 0) { -lean_object* x_71; lean_object* x_72; -x_71 = lean_ctor_get(x_66, 2); +lean_object* x_71; uint8_t x_72; +x_71 = lean_ctor_get(x_41, 2); lean_dec(x_71); -lean_ctor_set(x_66, 2, x_39); +x_72 = !lean_is_exclusive(x_68); +if (x_72 == 0) +{ +lean_object* x_73; lean_object* x_74; +x_73 = lean_ctor_get(x_68, 2); +lean_dec(x_73); +lean_ctor_set(x_68, 2, x_39); if (lean_is_scalar(x_32)) { - x_72 = lean_alloc_ctor(0, 2, 0); + x_74 = lean_alloc_ctor(0, 2, 0); } else { - x_72 = x_32; + x_74 = x_32; } -lean_ctor_set(x_72, 0, x_67); -lean_ctor_set(x_72, 1, x_41); -return x_72; +lean_ctor_set(x_74, 0, x_69); +lean_ctor_set(x_74, 1, x_41); +return x_74; } else { -lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; -x_73 = lean_ctor_get(x_66, 0); -x_74 = lean_ctor_get(x_66, 1); -x_75 = lean_ctor_get(x_66, 3); +lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; +x_75 = lean_ctor_get(x_68, 0); +x_76 = lean_ctor_get(x_68, 1); +x_77 = lean_ctor_get(x_68, 3); +x_78 = lean_ctor_get(x_68, 4); +lean_inc(x_78); +lean_inc(x_77); +lean_inc(x_76); lean_inc(x_75); -lean_inc(x_74); -lean_inc(x_73); -lean_dec(x_66); -x_76 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_76, 0, x_73); -lean_ctor_set(x_76, 1, x_74); -lean_ctor_set(x_76, 2, x_39); -lean_ctor_set(x_76, 3, x_75); -lean_ctor_set(x_41, 2, x_76); +lean_dec(x_68); +x_79 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_79, 0, x_75); +lean_ctor_set(x_79, 1, x_76); +lean_ctor_set(x_79, 2, x_39); +lean_ctor_set(x_79, 3, x_77); +lean_ctor_set(x_79, 4, x_78); +lean_ctor_set(x_41, 2, x_79); if (lean_is_scalar(x_32)) { - x_77 = lean_alloc_ctor(0, 2, 0); + x_80 = lean_alloc_ctor(0, 2, 0); } else { - x_77 = x_32; + x_80 = x_32; } -lean_ctor_set(x_77, 0, x_67); -lean_ctor_set(x_77, 1, x_41); -return x_77; +lean_ctor_set(x_80, 0, x_69); +lean_ctor_set(x_80, 1, x_41); +return x_80; } } else { -lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; -x_78 = lean_ctor_get(x_41, 0); -x_79 = lean_ctor_get(x_41, 1); -x_80 = lean_ctor_get(x_41, 3); -x_81 = lean_ctor_get(x_41, 4); -x_82 = lean_ctor_get(x_41, 5); +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; +x_81 = lean_ctor_get(x_41, 0); +x_82 = lean_ctor_get(x_41, 1); +x_83 = lean_ctor_get(x_41, 3); +x_84 = lean_ctor_get(x_41, 4); +x_85 = lean_ctor_get(x_41, 5); +lean_inc(x_85); +lean_inc(x_84); +lean_inc(x_83); lean_inc(x_82); lean_inc(x_81); -lean_inc(x_80); -lean_inc(x_79); -lean_inc(x_78); lean_dec(x_41); -x_83 = lean_ctor_get(x_66, 0); -lean_inc(x_83); -x_84 = lean_ctor_get(x_66, 1); -lean_inc(x_84); -x_85 = lean_ctor_get(x_66, 3); -lean_inc(x_85); -if (lean_is_exclusive(x_66)) { - lean_ctor_release(x_66, 0); - lean_ctor_release(x_66, 1); - lean_ctor_release(x_66, 2); - lean_ctor_release(x_66, 3); - x_86 = x_66; +x_86 = lean_ctor_get(x_68, 0); +lean_inc(x_86); +x_87 = lean_ctor_get(x_68, 1); +lean_inc(x_87); +x_88 = lean_ctor_get(x_68, 3); +lean_inc(x_88); +x_89 = lean_ctor_get(x_68, 4); +lean_inc(x_89); +if (lean_is_exclusive(x_68)) { + lean_ctor_release(x_68, 0); + lean_ctor_release(x_68, 1); + lean_ctor_release(x_68, 2); + lean_ctor_release(x_68, 3); + lean_ctor_release(x_68, 4); + x_90 = x_68; } else { - lean_dec_ref(x_66); - x_86 = lean_box(0); + lean_dec_ref(x_68); + x_90 = lean_box(0); } -if (lean_is_scalar(x_86)) { - x_87 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_90)) { + x_91 = lean_alloc_ctor(0, 5, 0); } else { - x_87 = x_86; + x_91 = x_90; } -lean_ctor_set(x_87, 0, x_83); -lean_ctor_set(x_87, 1, x_84); -lean_ctor_set(x_87, 2, x_39); -lean_ctor_set(x_87, 3, x_85); -x_88 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_88, 0, x_78); -lean_ctor_set(x_88, 1, x_79); -lean_ctor_set(x_88, 2, x_87); -lean_ctor_set(x_88, 3, x_80); -lean_ctor_set(x_88, 4, x_81); -lean_ctor_set(x_88, 5, x_82); +lean_ctor_set(x_91, 0, x_86); +lean_ctor_set(x_91, 1, x_87); +lean_ctor_set(x_91, 2, x_39); +lean_ctor_set(x_91, 3, x_88); +lean_ctor_set(x_91, 4, x_89); +x_92 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_92, 0, x_81); +lean_ctor_set(x_92, 1, x_82); +lean_ctor_set(x_92, 2, x_91); +lean_ctor_set(x_92, 3, x_83); +lean_ctor_set(x_92, 4, x_84); +lean_ctor_set(x_92, 5, x_85); if (lean_is_scalar(x_32)) { - x_89 = lean_alloc_ctor(0, 2, 0); + x_93 = lean_alloc_ctor(0, 2, 0); } else { - x_89 = x_32; + x_93 = x_32; } -lean_ctor_set(x_89, 0, x_67); -lean_ctor_set(x_89, 1, x_88); -return x_89; +lean_ctor_set(x_93, 0, x_69); +lean_ctor_set(x_93, 1, x_92); +return x_93; } } } } else { -lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_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; -x_118 = lean_ctor_get(x_37, 0); -x_119 = lean_ctor_get(x_37, 1); -x_120 = lean_ctor_get(x_37, 2); -x_121 = lean_ctor_get(x_37, 3); -lean_inc(x_121); -lean_inc(x_120); -lean_inc(x_119); -lean_inc(x_118); -lean_dec(x_37); -x_155 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_156 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_156, 0, x_118); -lean_ctor_set(x_156, 1, x_119); -lean_ctor_set(x_156, 2, x_155); -lean_ctor_set(x_156, 3, x_121); -lean_ctor_set(x_31, 2, x_156); -x_157 = lean_ctor_get(x_5, 0); -lean_inc(x_157); -x_158 = lean_ctor_get(x_5, 1); -lean_inc(x_158); -x_159 = lean_ctor_get(x_5, 2); -lean_inc(x_159); -x_160 = lean_ctor_get(x_5, 3); -lean_inc(x_160); -x_161 = lean_ctor_get(x_5, 4); -lean_inc(x_161); -if (lean_is_exclusive(x_5)) { - lean_ctor_release(x_5, 0); - lean_ctor_release(x_5, 1); - lean_ctor_release(x_5, 2); - lean_ctor_release(x_5, 3); - lean_ctor_release(x_5, 4); - x_162 = x_5; -} else { - lean_dec_ref(x_5); - x_162 = lean_box(0); -} -x_163 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_163, 0, x_33); -lean_ctor_set(x_163, 1, x_10); -x_164 = lean_array_push(x_159, x_163); -if (lean_is_scalar(x_162)) { - x_165 = lean_alloc_ctor(0, 5, 0); -} else { - x_165 = x_162; -} -lean_ctor_set(x_165, 0, x_157); -lean_ctor_set(x_165, 1, x_158); -lean_ctor_set(x_165, 2, x_164); -lean_ctor_set(x_165, 3, x_160); -lean_ctor_set(x_165, 4, x_161); -x_166 = l_Lean_Meta_isDefEqBindingDomain___main(x_1, x_2, x_35, x_4, x_165, x_31); -if (lean_obj_tag(x_166) == 0) -{ -lean_object* x_167; lean_object* x_168; lean_object* x_169; -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, 1, 0); -lean_ctor_set(x_169, 0, x_167); -x_122 = x_169; -x_123 = x_168; -goto block_154; -} -else -{ -lean_object* x_170; lean_object* x_171; lean_object* x_172; -x_170 = lean_ctor_get(x_166, 0); -lean_inc(x_170); -x_171 = lean_ctor_get(x_166, 1); -lean_inc(x_171); -lean_dec(x_166); -x_172 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_172, 0, x_170); -x_122 = x_172; -x_123 = x_171; -goto block_154; -} -block_154: -{ -if (lean_obj_tag(x_122) == 0) -{ -lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; -x_124 = lean_ctor_get(x_123, 2); -lean_inc(x_124); -x_125 = lean_ctor_get(x_122, 0); -lean_inc(x_125); -lean_dec(x_122); -x_126 = lean_ctor_get(x_123, 0); +lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; lean_object* x_173; +x_122 = lean_ctor_get(x_37, 0); +x_123 = lean_ctor_get(x_37, 1); +x_124 = lean_ctor_get(x_37, 2); +x_125 = lean_ctor_get(x_37, 3); +x_126 = lean_ctor_get(x_37, 4); lean_inc(x_126); -x_127 = lean_ctor_get(x_123, 1); -lean_inc(x_127); -x_128 = lean_ctor_get(x_123, 3); -lean_inc(x_128); -x_129 = lean_ctor_get(x_123, 4); -lean_inc(x_129); -x_130 = lean_ctor_get(x_123, 5); -lean_inc(x_130); -if (lean_is_exclusive(x_123)) { - lean_ctor_release(x_123, 0); - lean_ctor_release(x_123, 1); - lean_ctor_release(x_123, 2); - lean_ctor_release(x_123, 3); - lean_ctor_release(x_123, 4); - lean_ctor_release(x_123, 5); - x_131 = x_123; -} else { - lean_dec_ref(x_123); - x_131 = lean_box(0); -} -x_132 = lean_ctor_get(x_124, 0); -lean_inc(x_132); -x_133 = lean_ctor_get(x_124, 1); -lean_inc(x_133); -x_134 = lean_ctor_get(x_124, 3); -lean_inc(x_134); -if (lean_is_exclusive(x_124)) { - lean_ctor_release(x_124, 0); - lean_ctor_release(x_124, 1); - lean_ctor_release(x_124, 2); - lean_ctor_release(x_124, 3); - x_135 = x_124; -} else { - lean_dec_ref(x_124); - x_135 = lean_box(0); -} -if (lean_is_scalar(x_135)) { - x_136 = lean_alloc_ctor(0, 4, 0); -} else { - x_136 = x_135; -} -lean_ctor_set(x_136, 0, x_132); -lean_ctor_set(x_136, 1, x_133); -lean_ctor_set(x_136, 2, x_120); -lean_ctor_set(x_136, 3, x_134); -if (lean_is_scalar(x_131)) { - x_137 = lean_alloc_ctor(0, 6, 0); -} else { - x_137 = x_131; -} -lean_ctor_set(x_137, 0, x_126); -lean_ctor_set(x_137, 1, x_127); -lean_ctor_set(x_137, 2, x_136); -lean_ctor_set(x_137, 3, x_128); -lean_ctor_set(x_137, 4, x_129); -lean_ctor_set(x_137, 5, x_130); -if (lean_is_scalar(x_32)) { - x_138 = lean_alloc_ctor(1, 2, 0); -} else { - x_138 = x_32; - lean_ctor_set_tag(x_138, 1); -} -lean_ctor_set(x_138, 0, x_125); -lean_ctor_set(x_138, 1, x_137); -return x_138; -} -else -{ -lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_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; -x_139 = lean_ctor_get(x_123, 2); -lean_inc(x_139); -x_140 = lean_ctor_get(x_122, 0); -lean_inc(x_140); -lean_dec(x_122); -x_141 = lean_ctor_get(x_123, 0); -lean_inc(x_141); -x_142 = lean_ctor_get(x_123, 1); -lean_inc(x_142); -x_143 = lean_ctor_get(x_123, 3); -lean_inc(x_143); -x_144 = lean_ctor_get(x_123, 4); -lean_inc(x_144); -x_145 = lean_ctor_get(x_123, 5); -lean_inc(x_145); -if (lean_is_exclusive(x_123)) { - lean_ctor_release(x_123, 0); - lean_ctor_release(x_123, 1); - lean_ctor_release(x_123, 2); - lean_ctor_release(x_123, 3); - lean_ctor_release(x_123, 4); - lean_ctor_release(x_123, 5); - x_146 = x_123; -} else { - lean_dec_ref(x_123); - x_146 = lean_box(0); -} -x_147 = lean_ctor_get(x_139, 0); -lean_inc(x_147); -x_148 = lean_ctor_get(x_139, 1); -lean_inc(x_148); -x_149 = lean_ctor_get(x_139, 3); -lean_inc(x_149); -if (lean_is_exclusive(x_139)) { - lean_ctor_release(x_139, 0); - lean_ctor_release(x_139, 1); - lean_ctor_release(x_139, 2); - lean_ctor_release(x_139, 3); - x_150 = x_139; -} else { - lean_dec_ref(x_139); - x_150 = lean_box(0); -} -if (lean_is_scalar(x_150)) { - x_151 = lean_alloc_ctor(0, 4, 0); -} else { - x_151 = x_150; -} -lean_ctor_set(x_151, 0, x_147); -lean_ctor_set(x_151, 1, x_148); -lean_ctor_set(x_151, 2, x_120); -lean_ctor_set(x_151, 3, x_149); -if (lean_is_scalar(x_146)) { - x_152 = lean_alloc_ctor(0, 6, 0); -} else { - x_152 = x_146; -} -lean_ctor_set(x_152, 0, x_141); -lean_ctor_set(x_152, 1, x_142); -lean_ctor_set(x_152, 2, x_151); -lean_ctor_set(x_152, 3, x_143); -lean_ctor_set(x_152, 4, x_144); -lean_ctor_set(x_152, 5, x_145); -if (lean_is_scalar(x_32)) { - x_153 = lean_alloc_ctor(0, 2, 0); -} else { - x_153 = x_32; -} -lean_ctor_set(x_153, 0, x_140); -lean_ctor_set(x_153, 1, x_152); -return x_153; -} -} -} -} -else -{ -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; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; lean_object* x_224; lean_object* x_225; lean_object* x_226; lean_object* x_227; lean_object* x_228; lean_object* x_229; -x_173 = lean_ctor_get(x_31, 2); -x_174 = lean_ctor_get(x_31, 0); -x_175 = lean_ctor_get(x_31, 1); -x_176 = lean_ctor_get(x_31, 3); -x_177 = lean_ctor_get(x_31, 4); -x_178 = lean_ctor_get(x_31, 5); -lean_inc(x_178); -lean_inc(x_177); -lean_inc(x_176); -lean_inc(x_173); -lean_inc(x_175); -lean_inc(x_174); -lean_dec(x_31); -x_179 = lean_ctor_get(x_173, 0); -lean_inc(x_179); -x_180 = lean_ctor_get(x_173, 1); -lean_inc(x_180); -x_181 = lean_ctor_get(x_173, 2); -lean_inc(x_181); -x_182 = lean_ctor_get(x_173, 3); -lean_inc(x_182); -if (lean_is_exclusive(x_173)) { - lean_ctor_release(x_173, 0); - lean_ctor_release(x_173, 1); - lean_ctor_release(x_173, 2); - lean_ctor_release(x_173, 3); - x_183 = x_173; -} else { - lean_dec_ref(x_173); - x_183 = lean_box(0); -} -x_217 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_183)) { - x_218 = lean_alloc_ctor(0, 4, 0); -} else { - x_218 = x_183; -} -lean_ctor_set(x_218, 0, x_179); -lean_ctor_set(x_218, 1, x_180); -lean_ctor_set(x_218, 2, x_217); -lean_ctor_set(x_218, 3, x_182); -x_219 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_219, 0, x_174); -lean_ctor_set(x_219, 1, x_175); -lean_ctor_set(x_219, 2, x_218); -lean_ctor_set(x_219, 3, x_176); -lean_ctor_set(x_219, 4, x_177); -lean_ctor_set(x_219, 5, x_178); -x_220 = lean_ctor_get(x_5, 0); -lean_inc(x_220); -x_221 = lean_ctor_get(x_5, 1); -lean_inc(x_221); -x_222 = lean_ctor_get(x_5, 2); -lean_inc(x_222); -x_223 = lean_ctor_get(x_5, 3); -lean_inc(x_223); -x_224 = lean_ctor_get(x_5, 4); -lean_inc(x_224); +lean_inc(x_125); +lean_inc(x_124); +lean_inc(x_123); +lean_inc(x_122); +lean_dec(x_37); +x_162 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_163 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_163, 0, x_122); +lean_ctor_set(x_163, 1, x_123); +lean_ctor_set(x_163, 2, x_162); +lean_ctor_set(x_163, 3, x_125); +lean_ctor_set(x_163, 4, x_126); +lean_ctor_set(x_31, 2, x_163); +x_164 = lean_ctor_get(x_5, 0); +lean_inc(x_164); +x_165 = lean_ctor_get(x_5, 1); +lean_inc(x_165); +x_166 = lean_ctor_get(x_5, 2); +lean_inc(x_166); +x_167 = lean_ctor_get(x_5, 3); +lean_inc(x_167); +x_168 = lean_ctor_get(x_5, 4); +lean_inc(x_168); if (lean_is_exclusive(x_5)) { lean_ctor_release(x_5, 0); lean_ctor_release(x_5, 1); lean_ctor_release(x_5, 2); lean_ctor_release(x_5, 3); lean_ctor_release(x_5, 4); - x_225 = x_5; + x_169 = x_5; } else { lean_dec_ref(x_5); - x_225 = lean_box(0); + x_169 = lean_box(0); } -x_226 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_226, 0, x_33); -lean_ctor_set(x_226, 1, x_10); -x_227 = lean_array_push(x_222, x_226); -if (lean_is_scalar(x_225)) { +x_170 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_170, 0, x_33); +lean_ctor_set(x_170, 1, x_10); +x_171 = lean_array_push(x_166, x_170); +if (lean_is_scalar(x_169)) { + x_172 = lean_alloc_ctor(0, 5, 0); +} else { + x_172 = x_169; +} +lean_ctor_set(x_172, 0, x_164); +lean_ctor_set(x_172, 1, x_165); +lean_ctor_set(x_172, 2, x_171); +lean_ctor_set(x_172, 3, x_167); +lean_ctor_set(x_172, 4, x_168); +x_173 = l_Lean_Meta_isDefEqBindingDomain___main(x_1, x_2, x_35, x_4, x_172, x_31); +if (lean_obj_tag(x_173) == 0) +{ +lean_object* x_174; lean_object* x_175; lean_object* x_176; +x_174 = lean_ctor_get(x_173, 0); +lean_inc(x_174); +x_175 = lean_ctor_get(x_173, 1); +lean_inc(x_175); +lean_dec(x_173); +x_176 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_176, 0, x_174); +x_127 = x_176; +x_128 = x_175; +goto block_161; +} +else +{ +lean_object* x_177; lean_object* x_178; lean_object* x_179; +x_177 = lean_ctor_get(x_173, 0); +lean_inc(x_177); +x_178 = lean_ctor_get(x_173, 1); +lean_inc(x_178); +lean_dec(x_173); +x_179 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_179, 0, x_177); +x_127 = x_179; +x_128 = x_178; +goto block_161; +} +block_161: +{ +if (lean_obj_tag(x_127) == 0) +{ +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; +x_129 = lean_ctor_get(x_128, 2); +lean_inc(x_129); +x_130 = lean_ctor_get(x_127, 0); +lean_inc(x_130); +lean_dec(x_127); +x_131 = lean_ctor_get(x_128, 0); +lean_inc(x_131); +x_132 = lean_ctor_get(x_128, 1); +lean_inc(x_132); +x_133 = lean_ctor_get(x_128, 3); +lean_inc(x_133); +x_134 = lean_ctor_get(x_128, 4); +lean_inc(x_134); +x_135 = lean_ctor_get(x_128, 5); +lean_inc(x_135); +if (lean_is_exclusive(x_128)) { + lean_ctor_release(x_128, 0); + lean_ctor_release(x_128, 1); + lean_ctor_release(x_128, 2); + lean_ctor_release(x_128, 3); + lean_ctor_release(x_128, 4); + lean_ctor_release(x_128, 5); + x_136 = x_128; +} else { + lean_dec_ref(x_128); + x_136 = lean_box(0); +} +x_137 = lean_ctor_get(x_129, 0); +lean_inc(x_137); +x_138 = lean_ctor_get(x_129, 1); +lean_inc(x_138); +x_139 = lean_ctor_get(x_129, 3); +lean_inc(x_139); +x_140 = lean_ctor_get(x_129, 4); +lean_inc(x_140); +if (lean_is_exclusive(x_129)) { + lean_ctor_release(x_129, 0); + lean_ctor_release(x_129, 1); + lean_ctor_release(x_129, 2); + lean_ctor_release(x_129, 3); + lean_ctor_release(x_129, 4); + x_141 = x_129; +} else { + lean_dec_ref(x_129); + x_141 = lean_box(0); +} +if (lean_is_scalar(x_141)) { + x_142 = lean_alloc_ctor(0, 5, 0); +} else { + x_142 = x_141; +} +lean_ctor_set(x_142, 0, x_137); +lean_ctor_set(x_142, 1, x_138); +lean_ctor_set(x_142, 2, x_124); +lean_ctor_set(x_142, 3, x_139); +lean_ctor_set(x_142, 4, x_140); +if (lean_is_scalar(x_136)) { + x_143 = lean_alloc_ctor(0, 6, 0); +} else { + x_143 = x_136; +} +lean_ctor_set(x_143, 0, x_131); +lean_ctor_set(x_143, 1, x_132); +lean_ctor_set(x_143, 2, x_142); +lean_ctor_set(x_143, 3, x_133); +lean_ctor_set(x_143, 4, x_134); +lean_ctor_set(x_143, 5, x_135); +if (lean_is_scalar(x_32)) { + x_144 = lean_alloc_ctor(1, 2, 0); +} else { + x_144 = x_32; + lean_ctor_set_tag(x_144, 1); +} +lean_ctor_set(x_144, 0, x_130); +lean_ctor_set(x_144, 1, x_143); +return x_144; +} +else +{ +lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_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; +x_145 = lean_ctor_get(x_128, 2); +lean_inc(x_145); +x_146 = lean_ctor_get(x_127, 0); +lean_inc(x_146); +lean_dec(x_127); +x_147 = lean_ctor_get(x_128, 0); +lean_inc(x_147); +x_148 = lean_ctor_get(x_128, 1); +lean_inc(x_148); +x_149 = lean_ctor_get(x_128, 3); +lean_inc(x_149); +x_150 = lean_ctor_get(x_128, 4); +lean_inc(x_150); +x_151 = lean_ctor_get(x_128, 5); +lean_inc(x_151); +if (lean_is_exclusive(x_128)) { + lean_ctor_release(x_128, 0); + lean_ctor_release(x_128, 1); + lean_ctor_release(x_128, 2); + lean_ctor_release(x_128, 3); + lean_ctor_release(x_128, 4); + lean_ctor_release(x_128, 5); + x_152 = x_128; +} else { + lean_dec_ref(x_128); + x_152 = lean_box(0); +} +x_153 = lean_ctor_get(x_145, 0); +lean_inc(x_153); +x_154 = lean_ctor_get(x_145, 1); +lean_inc(x_154); +x_155 = lean_ctor_get(x_145, 3); +lean_inc(x_155); +x_156 = lean_ctor_get(x_145, 4); +lean_inc(x_156); +if (lean_is_exclusive(x_145)) { + lean_ctor_release(x_145, 0); + lean_ctor_release(x_145, 1); + lean_ctor_release(x_145, 2); + lean_ctor_release(x_145, 3); + lean_ctor_release(x_145, 4); + x_157 = x_145; +} else { + lean_dec_ref(x_145); + x_157 = lean_box(0); +} +if (lean_is_scalar(x_157)) { + x_158 = lean_alloc_ctor(0, 5, 0); +} else { + x_158 = x_157; +} +lean_ctor_set(x_158, 0, x_153); +lean_ctor_set(x_158, 1, x_154); +lean_ctor_set(x_158, 2, x_124); +lean_ctor_set(x_158, 3, x_155); +lean_ctor_set(x_158, 4, x_156); +if (lean_is_scalar(x_152)) { + x_159 = lean_alloc_ctor(0, 6, 0); +} else { + x_159 = x_152; +} +lean_ctor_set(x_159, 0, x_147); +lean_ctor_set(x_159, 1, x_148); +lean_ctor_set(x_159, 2, x_158); +lean_ctor_set(x_159, 3, x_149); +lean_ctor_set(x_159, 4, x_150); +lean_ctor_set(x_159, 5, x_151); +if (lean_is_scalar(x_32)) { + x_160 = lean_alloc_ctor(0, 2, 0); +} else { + x_160 = x_32; +} +lean_ctor_set(x_160, 0, x_146); +lean_ctor_set(x_160, 1, x_159); +return x_160; +} +} +} +} +else +{ +lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; 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_227; lean_object* x_228; lean_object* x_229; lean_object* x_230; lean_object* x_231; lean_object* x_232; lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_object* x_236; lean_object* x_237; lean_object* x_238; lean_object* x_239; +x_180 = lean_ctor_get(x_31, 2); +x_181 = lean_ctor_get(x_31, 0); +x_182 = lean_ctor_get(x_31, 1); +x_183 = lean_ctor_get(x_31, 3); +x_184 = lean_ctor_get(x_31, 4); +x_185 = lean_ctor_get(x_31, 5); +lean_inc(x_185); +lean_inc(x_184); +lean_inc(x_183); +lean_inc(x_180); +lean_inc(x_182); +lean_inc(x_181); +lean_dec(x_31); +x_186 = lean_ctor_get(x_180, 0); +lean_inc(x_186); +x_187 = lean_ctor_get(x_180, 1); +lean_inc(x_187); +x_188 = lean_ctor_get(x_180, 2); +lean_inc(x_188); +x_189 = lean_ctor_get(x_180, 3); +lean_inc(x_189); +x_190 = lean_ctor_get(x_180, 4); +lean_inc(x_190); +if (lean_is_exclusive(x_180)) { + lean_ctor_release(x_180, 0); + lean_ctor_release(x_180, 1); + lean_ctor_release(x_180, 2); + lean_ctor_release(x_180, 3); + lean_ctor_release(x_180, 4); + x_191 = x_180; +} else { + lean_dec_ref(x_180); + x_191 = lean_box(0); +} +x_227 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_191)) { x_228 = lean_alloc_ctor(0, 5, 0); } else { - x_228 = x_225; + x_228 = x_191; } -lean_ctor_set(x_228, 0, x_220); -lean_ctor_set(x_228, 1, x_221); +lean_ctor_set(x_228, 0, x_186); +lean_ctor_set(x_228, 1, x_187); lean_ctor_set(x_228, 2, x_227); -lean_ctor_set(x_228, 3, x_223); -lean_ctor_set(x_228, 4, x_224); -x_229 = l_Lean_Meta_isDefEqBindingDomain___main(x_1, x_2, x_35, x_4, x_228, x_219); -if (lean_obj_tag(x_229) == 0) -{ -lean_object* x_230; lean_object* x_231; lean_object* x_232; -x_230 = lean_ctor_get(x_229, 0); +lean_ctor_set(x_228, 3, x_189); +lean_ctor_set(x_228, 4, x_190); +x_229 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_229, 0, x_181); +lean_ctor_set(x_229, 1, x_182); +lean_ctor_set(x_229, 2, x_228); +lean_ctor_set(x_229, 3, x_183); +lean_ctor_set(x_229, 4, x_184); +lean_ctor_set(x_229, 5, x_185); +x_230 = lean_ctor_get(x_5, 0); lean_inc(x_230); -x_231 = lean_ctor_get(x_229, 1); +x_231 = lean_ctor_get(x_5, 1); lean_inc(x_231); -lean_dec(x_229); -x_232 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_232, 0, x_230); -x_184 = x_232; -x_185 = x_231; -goto block_216; -} -else -{ -lean_object* x_233; lean_object* x_234; lean_object* x_235; -x_233 = lean_ctor_get(x_229, 0); +x_232 = lean_ctor_get(x_5, 2); +lean_inc(x_232); +x_233 = lean_ctor_get(x_5, 3); lean_inc(x_233); -x_234 = lean_ctor_get(x_229, 1); +x_234 = lean_ctor_get(x_5, 4); lean_inc(x_234); -lean_dec(x_229); -x_235 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_235, 0, x_233); -x_184 = x_235; -x_185 = x_234; -goto block_216; -} -block_216: -{ -if (lean_obj_tag(x_184) == 0) -{ -lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; -x_186 = lean_ctor_get(x_185, 2); -lean_inc(x_186); -x_187 = lean_ctor_get(x_184, 0); -lean_inc(x_187); -lean_dec(x_184); -x_188 = lean_ctor_get(x_185, 0); -lean_inc(x_188); -x_189 = lean_ctor_get(x_185, 1); -lean_inc(x_189); -x_190 = lean_ctor_get(x_185, 3); -lean_inc(x_190); -x_191 = lean_ctor_get(x_185, 4); -lean_inc(x_191); -x_192 = lean_ctor_get(x_185, 5); -lean_inc(x_192); -if (lean_is_exclusive(x_185)) { - lean_ctor_release(x_185, 0); - lean_ctor_release(x_185, 1); - lean_ctor_release(x_185, 2); - lean_ctor_release(x_185, 3); - lean_ctor_release(x_185, 4); - lean_ctor_release(x_185, 5); - x_193 = x_185; +if (lean_is_exclusive(x_5)) { + lean_ctor_release(x_5, 0); + lean_ctor_release(x_5, 1); + lean_ctor_release(x_5, 2); + lean_ctor_release(x_5, 3); + lean_ctor_release(x_5, 4); + x_235 = x_5; } else { - lean_dec_ref(x_185); - x_193 = lean_box(0); + lean_dec_ref(x_5); + x_235 = lean_box(0); } -x_194 = lean_ctor_get(x_186, 0); +x_236 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_236, 0, x_33); +lean_ctor_set(x_236, 1, x_10); +x_237 = lean_array_push(x_232, x_236); +if (lean_is_scalar(x_235)) { + x_238 = lean_alloc_ctor(0, 5, 0); +} else { + x_238 = x_235; +} +lean_ctor_set(x_238, 0, x_230); +lean_ctor_set(x_238, 1, x_231); +lean_ctor_set(x_238, 2, x_237); +lean_ctor_set(x_238, 3, x_233); +lean_ctor_set(x_238, 4, x_234); +x_239 = l_Lean_Meta_isDefEqBindingDomain___main(x_1, x_2, x_35, x_4, x_238, x_229); +if (lean_obj_tag(x_239) == 0) +{ +lean_object* x_240; lean_object* x_241; lean_object* x_242; +x_240 = lean_ctor_get(x_239, 0); +lean_inc(x_240); +x_241 = lean_ctor_get(x_239, 1); +lean_inc(x_241); +lean_dec(x_239); +x_242 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_242, 0, x_240); +x_192 = x_242; +x_193 = x_241; +goto block_226; +} +else +{ +lean_object* x_243; lean_object* x_244; lean_object* x_245; +x_243 = lean_ctor_get(x_239, 0); +lean_inc(x_243); +x_244 = lean_ctor_get(x_239, 1); +lean_inc(x_244); +lean_dec(x_239); +x_245 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_245, 0, x_243); +x_192 = x_245; +x_193 = x_244; +goto block_226; +} +block_226: +{ +if (lean_obj_tag(x_192) == 0) +{ +lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; +x_194 = lean_ctor_get(x_193, 2); lean_inc(x_194); -x_195 = lean_ctor_get(x_186, 1); +x_195 = lean_ctor_get(x_192, 0); lean_inc(x_195); -x_196 = lean_ctor_get(x_186, 3); +lean_dec(x_192); +x_196 = lean_ctor_get(x_193, 0); lean_inc(x_196); -if (lean_is_exclusive(x_186)) { - lean_ctor_release(x_186, 0); - lean_ctor_release(x_186, 1); - lean_ctor_release(x_186, 2); - lean_ctor_release(x_186, 3); - x_197 = x_186; +x_197 = lean_ctor_get(x_193, 1); +lean_inc(x_197); +x_198 = lean_ctor_get(x_193, 3); +lean_inc(x_198); +x_199 = lean_ctor_get(x_193, 4); +lean_inc(x_199); +x_200 = lean_ctor_get(x_193, 5); +lean_inc(x_200); +if (lean_is_exclusive(x_193)) { + lean_ctor_release(x_193, 0); + lean_ctor_release(x_193, 1); + lean_ctor_release(x_193, 2); + lean_ctor_release(x_193, 3); + lean_ctor_release(x_193, 4); + lean_ctor_release(x_193, 5); + x_201 = x_193; } else { - lean_dec_ref(x_186); - x_197 = lean_box(0); + lean_dec_ref(x_193); + x_201 = lean_box(0); } -if (lean_is_scalar(x_197)) { - x_198 = lean_alloc_ctor(0, 4, 0); -} else { - x_198 = x_197; -} -lean_ctor_set(x_198, 0, x_194); -lean_ctor_set(x_198, 1, x_195); -lean_ctor_set(x_198, 2, x_181); -lean_ctor_set(x_198, 3, x_196); -if (lean_is_scalar(x_193)) { - x_199 = lean_alloc_ctor(0, 6, 0); -} else { - x_199 = x_193; -} -lean_ctor_set(x_199, 0, x_188); -lean_ctor_set(x_199, 1, x_189); -lean_ctor_set(x_199, 2, x_198); -lean_ctor_set(x_199, 3, x_190); -lean_ctor_set(x_199, 4, x_191); -lean_ctor_set(x_199, 5, x_192); -if (lean_is_scalar(x_32)) { - x_200 = lean_alloc_ctor(1, 2, 0); -} else { - x_200 = x_32; - lean_ctor_set_tag(x_200, 1); -} -lean_ctor_set(x_200, 0, x_187); -lean_ctor_set(x_200, 1, x_199); -return x_200; -} -else -{ -lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; -x_201 = lean_ctor_get(x_185, 2); -lean_inc(x_201); -x_202 = lean_ctor_get(x_184, 0); +x_202 = lean_ctor_get(x_194, 0); lean_inc(x_202); -lean_dec(x_184); -x_203 = lean_ctor_get(x_185, 0); +x_203 = lean_ctor_get(x_194, 1); lean_inc(x_203); -x_204 = lean_ctor_get(x_185, 1); +x_204 = lean_ctor_get(x_194, 3); lean_inc(x_204); -x_205 = lean_ctor_get(x_185, 3); +x_205 = lean_ctor_get(x_194, 4); lean_inc(x_205); -x_206 = lean_ctor_get(x_185, 4); -lean_inc(x_206); -x_207 = lean_ctor_get(x_185, 5); -lean_inc(x_207); -if (lean_is_exclusive(x_185)) { - lean_ctor_release(x_185, 0); - lean_ctor_release(x_185, 1); - lean_ctor_release(x_185, 2); - lean_ctor_release(x_185, 3); - lean_ctor_release(x_185, 4); - lean_ctor_release(x_185, 5); - x_208 = x_185; +if (lean_is_exclusive(x_194)) { + lean_ctor_release(x_194, 0); + lean_ctor_release(x_194, 1); + lean_ctor_release(x_194, 2); + lean_ctor_release(x_194, 3); + lean_ctor_release(x_194, 4); + x_206 = x_194; } else { - lean_dec_ref(x_185); - x_208 = lean_box(0); + lean_dec_ref(x_194); + x_206 = lean_box(0); } -x_209 = lean_ctor_get(x_201, 0); -lean_inc(x_209); -x_210 = lean_ctor_get(x_201, 1); -lean_inc(x_210); -x_211 = lean_ctor_get(x_201, 3); -lean_inc(x_211); -if (lean_is_exclusive(x_201)) { - lean_ctor_release(x_201, 0); - lean_ctor_release(x_201, 1); - lean_ctor_release(x_201, 2); - lean_ctor_release(x_201, 3); - x_212 = x_201; +if (lean_is_scalar(x_206)) { + x_207 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_201); - x_212 = lean_box(0); + x_207 = x_206; } -if (lean_is_scalar(x_212)) { - x_213 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_207, 0, x_202); +lean_ctor_set(x_207, 1, x_203); +lean_ctor_set(x_207, 2, x_188); +lean_ctor_set(x_207, 3, x_204); +lean_ctor_set(x_207, 4, x_205); +if (lean_is_scalar(x_201)) { + x_208 = lean_alloc_ctor(0, 6, 0); } else { - x_213 = x_212; + x_208 = x_201; } -lean_ctor_set(x_213, 0, x_209); -lean_ctor_set(x_213, 1, x_210); -lean_ctor_set(x_213, 2, x_181); -lean_ctor_set(x_213, 3, x_211); -if (lean_is_scalar(x_208)) { - x_214 = lean_alloc_ctor(0, 6, 0); -} else { - x_214 = x_208; -} -lean_ctor_set(x_214, 0, x_203); -lean_ctor_set(x_214, 1, x_204); -lean_ctor_set(x_214, 2, x_213); -lean_ctor_set(x_214, 3, x_205); -lean_ctor_set(x_214, 4, x_206); -lean_ctor_set(x_214, 5, x_207); +lean_ctor_set(x_208, 0, x_196); +lean_ctor_set(x_208, 1, x_197); +lean_ctor_set(x_208, 2, x_207); +lean_ctor_set(x_208, 3, x_198); +lean_ctor_set(x_208, 4, x_199); +lean_ctor_set(x_208, 5, x_200); if (lean_is_scalar(x_32)) { - x_215 = lean_alloc_ctor(0, 2, 0); + x_209 = lean_alloc_ctor(1, 2, 0); } else { - x_215 = x_32; + x_209 = x_32; + lean_ctor_set_tag(x_209, 1); } -lean_ctor_set(x_215, 0, x_202); -lean_ctor_set(x_215, 1, x_214); -return x_215; +lean_ctor_set(x_209, 0, x_195); +lean_ctor_set(x_209, 1, x_208); +return x_209; +} +else +{ +lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; lean_object* x_224; lean_object* x_225; +x_210 = lean_ctor_get(x_193, 2); +lean_inc(x_210); +x_211 = lean_ctor_get(x_192, 0); +lean_inc(x_211); +lean_dec(x_192); +x_212 = lean_ctor_get(x_193, 0); +lean_inc(x_212); +x_213 = lean_ctor_get(x_193, 1); +lean_inc(x_213); +x_214 = lean_ctor_get(x_193, 3); +lean_inc(x_214); +x_215 = lean_ctor_get(x_193, 4); +lean_inc(x_215); +x_216 = lean_ctor_get(x_193, 5); +lean_inc(x_216); +if (lean_is_exclusive(x_193)) { + lean_ctor_release(x_193, 0); + lean_ctor_release(x_193, 1); + lean_ctor_release(x_193, 2); + lean_ctor_release(x_193, 3); + lean_ctor_release(x_193, 4); + lean_ctor_release(x_193, 5); + x_217 = x_193; +} else { + lean_dec_ref(x_193); + x_217 = lean_box(0); +} +x_218 = lean_ctor_get(x_210, 0); +lean_inc(x_218); +x_219 = lean_ctor_get(x_210, 1); +lean_inc(x_219); +x_220 = lean_ctor_get(x_210, 3); +lean_inc(x_220); +x_221 = lean_ctor_get(x_210, 4); +lean_inc(x_221); +if (lean_is_exclusive(x_210)) { + lean_ctor_release(x_210, 0); + lean_ctor_release(x_210, 1); + lean_ctor_release(x_210, 2); + lean_ctor_release(x_210, 3); + lean_ctor_release(x_210, 4); + x_222 = x_210; +} else { + lean_dec_ref(x_210); + x_222 = lean_box(0); +} +if (lean_is_scalar(x_222)) { + x_223 = lean_alloc_ctor(0, 5, 0); +} else { + x_223 = x_222; +} +lean_ctor_set(x_223, 0, x_218); +lean_ctor_set(x_223, 1, x_219); +lean_ctor_set(x_223, 2, x_188); +lean_ctor_set(x_223, 3, x_220); +lean_ctor_set(x_223, 4, x_221); +if (lean_is_scalar(x_217)) { + x_224 = lean_alloc_ctor(0, 6, 0); +} else { + x_224 = x_217; +} +lean_ctor_set(x_224, 0, x_212); +lean_ctor_set(x_224, 1, x_213); +lean_ctor_set(x_224, 2, x_223); +lean_ctor_set(x_224, 3, x_214); +lean_ctor_set(x_224, 4, x_215); +lean_ctor_set(x_224, 5, x_216); +if (lean_is_scalar(x_32)) { + x_225 = lean_alloc_ctor(0, 2, 0); +} else { + x_225 = x_32; +} +lean_ctor_set(x_225, 0, x_211); +lean_ctor_set(x_225, 1, x_224); +return x_225; } } } @@ -4507,84 +4544,84 @@ return x_215; } else { -uint8_t x_236; +uint8_t x_246; lean_dec(x_10); lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); -x_236 = !lean_is_exclusive(x_25); -if (x_236 == 0) +x_246 = !lean_is_exclusive(x_25); +if (x_246 == 0) { return x_25; } else { -lean_object* x_237; lean_object* x_238; lean_object* x_239; -x_237 = lean_ctor_get(x_25, 0); -x_238 = lean_ctor_get(x_25, 1); -lean_inc(x_238); -lean_inc(x_237); +lean_object* x_247; lean_object* x_248; lean_object* x_249; +x_247 = lean_ctor_get(x_25, 0); +x_248 = lean_ctor_get(x_25, 1); +lean_inc(x_248); +lean_inc(x_247); lean_dec(x_25); -x_239 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_239, 0, x_237); -lean_ctor_set(x_239, 1, x_238); -return x_239; +x_249 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_249, 0, x_247); +lean_ctor_set(x_249, 1, x_248); +return x_249; } } } } else { -uint8_t x_240; +uint8_t x_250; lean_dec(x_14); lean_dec(x_10); lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); -x_240 = !lean_is_exclusive(x_17); -if (x_240 == 0) +x_250 = !lean_is_exclusive(x_17); +if (x_250 == 0) { return x_17; } else { -lean_object* x_241; lean_object* x_242; lean_object* x_243; -x_241 = lean_ctor_get(x_17, 0); -x_242 = lean_ctor_get(x_17, 1); -lean_inc(x_242); -lean_inc(x_241); +lean_object* x_251; lean_object* x_252; lean_object* x_253; +x_251 = lean_ctor_get(x_17, 0); +x_252 = lean_ctor_get(x_17, 1); +lean_inc(x_252); +lean_inc(x_251); lean_dec(x_17); -x_243 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_243, 0, x_241); -lean_ctor_set(x_243, 1, x_242); -return x_243; +x_253 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_253, 0, x_251); +lean_ctor_set(x_253, 1, x_252); +return x_253; } } } else { -uint8_t x_244; +uint8_t x_254; lean_dec(x_10); lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); -x_244 = !lean_is_exclusive(x_11); -if (x_244 == 0) +x_254 = !lean_is_exclusive(x_11); +if (x_254 == 0) { return x_11; } else { -lean_object* x_245; lean_object* x_246; lean_object* x_247; -x_245 = lean_ctor_get(x_11, 0); -x_246 = lean_ctor_get(x_11, 1); -lean_inc(x_246); -lean_inc(x_245); +lean_object* x_255; lean_object* x_256; lean_object* x_257; +x_255 = lean_ctor_get(x_11, 0); +x_256 = lean_ctor_get(x_11, 1); +lean_inc(x_256); +lean_inc(x_255); lean_dec(x_11); -x_247 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_247, 0, x_245); -lean_ctor_set(x_247, 1, x_246); -return x_247; +x_257 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_257, 0, x_255); +lean_ctor_set(x_257, 1, x_256); +return x_257; } } } @@ -4745,105 +4782,105 @@ x_41 = lean_ctor_get(x_35, 2); x_42 = !lean_is_exclusive(x_41); if (x_42 == 0) { -lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_95; uint8_t x_96; +lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_99; uint8_t x_100; x_43 = lean_ctor_get(x_41, 2); -x_95 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_41, 2, x_95); -x_96 = !lean_is_exclusive(x_7); -if (x_96 == 0) +x_99 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_41, 2, x_99); +x_100 = !lean_is_exclusive(x_7); +if (x_100 == 0) { -lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; -x_97 = lean_ctor_get(x_7, 2); -x_98 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_98, 0, x_37); -lean_ctor_set(x_98, 1, x_14); -x_99 = lean_array_push(x_97, x_98); -lean_ctor_set(x_7, 2, x_99); -x_100 = l_Lean_Meta_isDefEqBindingDomain___main___at___private_Lean_Meta_ExprDefEq_6__isDefEqBindingAux___main___spec__1(x_1, x_2, x_3, x_4, x_5, x_39, x_7, x_35); -if (lean_obj_tag(x_100) == 0) +lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; +x_101 = lean_ctor_get(x_7, 2); +x_102 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_102, 0, x_37); +lean_ctor_set(x_102, 1, x_14); +x_103 = lean_array_push(x_101, x_102); +lean_ctor_set(x_7, 2, x_103); +x_104 = l_Lean_Meta_isDefEqBindingDomain___main___at___private_Lean_Meta_ExprDefEq_6__isDefEqBindingAux___main___spec__1(x_1, x_2, x_3, x_4, x_5, x_39, x_7, x_35); +if (lean_obj_tag(x_104) == 0) { -lean_object* x_101; lean_object* x_102; lean_object* x_103; -x_101 = lean_ctor_get(x_100, 0); -lean_inc(x_101); -x_102 = lean_ctor_get(x_100, 1); -lean_inc(x_102); -lean_dec(x_100); -x_103 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_103, 0, x_101); -x_44 = x_103; -x_45 = x_102; -goto block_94; -} -else -{ -lean_object* x_104; lean_object* x_105; lean_object* x_106; -x_104 = lean_ctor_get(x_100, 0); -lean_inc(x_104); -x_105 = lean_ctor_get(x_100, 1); +lean_object* x_105; lean_object* x_106; lean_object* x_107; +x_105 = lean_ctor_get(x_104, 0); lean_inc(x_105); -lean_dec(x_100); -x_106 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_106, 0, x_104); -x_44 = x_106; -x_45 = x_105; -goto block_94; -} +x_106 = lean_ctor_get(x_104, 1); +lean_inc(x_106); +lean_dec(x_104); +x_107 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_107, 0, x_105); +x_44 = x_107; +x_45 = x_106; +goto block_98; } else { -lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; -x_107 = lean_ctor_get(x_7, 0); -x_108 = lean_ctor_get(x_7, 1); -x_109 = lean_ctor_get(x_7, 2); -x_110 = lean_ctor_get(x_7, 3); -x_111 = lean_ctor_get(x_7, 4); -lean_inc(x_111); -lean_inc(x_110); -lean_inc(x_109); +lean_object* x_108; lean_object* x_109; lean_object* x_110; +x_108 = lean_ctor_get(x_104, 0); lean_inc(x_108); -lean_inc(x_107); -lean_dec(x_7); -x_112 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_112, 0, x_37); -lean_ctor_set(x_112, 1, x_14); -x_113 = lean_array_push(x_109, x_112); -x_114 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_114, 0, x_107); -lean_ctor_set(x_114, 1, x_108); -lean_ctor_set(x_114, 2, x_113); -lean_ctor_set(x_114, 3, x_110); -lean_ctor_set(x_114, 4, x_111); -x_115 = l_Lean_Meta_isDefEqBindingDomain___main___at___private_Lean_Meta_ExprDefEq_6__isDefEqBindingAux___main___spec__1(x_1, x_2, x_3, x_4, x_5, x_39, x_114, x_35); -if (lean_obj_tag(x_115) == 0) -{ -lean_object* x_116; lean_object* x_117; lean_object* x_118; -x_116 = lean_ctor_get(x_115, 0); -lean_inc(x_116); -x_117 = lean_ctor_get(x_115, 1); -lean_inc(x_117); -lean_dec(x_115); -x_118 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_118, 0, x_116); -x_44 = x_118; -x_45 = x_117; -goto block_94; +x_109 = lean_ctor_get(x_104, 1); +lean_inc(x_109); +lean_dec(x_104); +x_110 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_110, 0, x_108); +x_44 = x_110; +x_45 = x_109; +goto block_98; +} } else { -lean_object* x_119; lean_object* x_120; lean_object* x_121; -x_119 = lean_ctor_get(x_115, 0); -lean_inc(x_119); -x_120 = lean_ctor_get(x_115, 1); +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; +x_111 = lean_ctor_get(x_7, 0); +x_112 = lean_ctor_get(x_7, 1); +x_113 = lean_ctor_get(x_7, 2); +x_114 = lean_ctor_get(x_7, 3); +x_115 = lean_ctor_get(x_7, 4); +lean_inc(x_115); +lean_inc(x_114); +lean_inc(x_113); +lean_inc(x_112); +lean_inc(x_111); +lean_dec(x_7); +x_116 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_116, 0, x_37); +lean_ctor_set(x_116, 1, x_14); +x_117 = lean_array_push(x_113, x_116); +x_118 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_118, 0, x_111); +lean_ctor_set(x_118, 1, x_112); +lean_ctor_set(x_118, 2, x_117); +lean_ctor_set(x_118, 3, x_114); +lean_ctor_set(x_118, 4, x_115); +x_119 = l_Lean_Meta_isDefEqBindingDomain___main___at___private_Lean_Meta_ExprDefEq_6__isDefEqBindingAux___main___spec__1(x_1, x_2, x_3, x_4, x_5, x_39, x_118, x_35); +if (lean_obj_tag(x_119) == 0) +{ +lean_object* x_120; lean_object* x_121; lean_object* x_122; +x_120 = lean_ctor_get(x_119, 0); lean_inc(x_120); -lean_dec(x_115); -x_121 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_121, 0, x_119); -x_44 = x_121; -x_45 = x_120; -goto block_94; +x_121 = lean_ctor_get(x_119, 1); +lean_inc(x_121); +lean_dec(x_119); +x_122 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_122, 0, x_120); +x_44 = x_122; +x_45 = x_121; +goto block_98; +} +else +{ +lean_object* x_123; lean_object* x_124; lean_object* x_125; +x_123 = lean_ctor_get(x_119, 0); +lean_inc(x_123); +x_124 = lean_ctor_get(x_119, 1); +lean_inc(x_124); +lean_dec(x_119); +x_125 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_125, 0, x_123); +x_44 = x_125; +x_45 = x_124; +goto block_98; } } -block_94: +block_98: { if (lean_obj_tag(x_44) == 0) { @@ -4878,708 +4915,745 @@ 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_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; x_53 = lean_ctor_get(x_46, 0); x_54 = lean_ctor_get(x_46, 1); x_55 = lean_ctor_get(x_46, 3); +x_56 = lean_ctor_get(x_46, 4); +lean_inc(x_56); lean_inc(x_55); lean_inc(x_54); lean_inc(x_53); lean_dec(x_46); -x_56 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_56, 0, x_53); -lean_ctor_set(x_56, 1, x_54); -lean_ctor_set(x_56, 2, x_43); -lean_ctor_set(x_56, 3, x_55); -lean_ctor_set(x_45, 2, x_56); +x_57 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_57, 0, x_53); +lean_ctor_set(x_57, 1, x_54); +lean_ctor_set(x_57, 2, x_43); +lean_ctor_set(x_57, 3, x_55); +lean_ctor_set(x_57, 4, x_56); +lean_ctor_set(x_45, 2, x_57); if (lean_is_scalar(x_36)) { - x_57 = lean_alloc_ctor(1, 2, 0); + x_58 = lean_alloc_ctor(1, 2, 0); } else { - x_57 = x_36; - lean_ctor_set_tag(x_57, 1); + x_58 = x_36; + lean_ctor_set_tag(x_58, 1); } -lean_ctor_set(x_57, 0, x_47); -lean_ctor_set(x_57, 1, x_45); -return x_57; +lean_ctor_set(x_58, 0, x_47); +lean_ctor_set(x_58, 1, x_45); +return x_58; } } else { -lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; -x_58 = lean_ctor_get(x_45, 0); -x_59 = lean_ctor_get(x_45, 1); -x_60 = lean_ctor_get(x_45, 3); -x_61 = lean_ctor_get(x_45, 4); -x_62 = lean_ctor_get(x_45, 5); +lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; +x_59 = lean_ctor_get(x_45, 0); +x_60 = lean_ctor_get(x_45, 1); +x_61 = lean_ctor_get(x_45, 3); +x_62 = lean_ctor_get(x_45, 4); +x_63 = lean_ctor_get(x_45, 5); +lean_inc(x_63); lean_inc(x_62); lean_inc(x_61); lean_inc(x_60); lean_inc(x_59); -lean_inc(x_58); lean_dec(x_45); -x_63 = lean_ctor_get(x_46, 0); -lean_inc(x_63); -x_64 = lean_ctor_get(x_46, 1); +x_64 = lean_ctor_get(x_46, 0); lean_inc(x_64); -x_65 = lean_ctor_get(x_46, 3); +x_65 = lean_ctor_get(x_46, 1); lean_inc(x_65); +x_66 = lean_ctor_get(x_46, 3); +lean_inc(x_66); +x_67 = lean_ctor_get(x_46, 4); +lean_inc(x_67); if (lean_is_exclusive(x_46)) { lean_ctor_release(x_46, 0); lean_ctor_release(x_46, 1); lean_ctor_release(x_46, 2); lean_ctor_release(x_46, 3); - x_66 = x_46; + lean_ctor_release(x_46, 4); + x_68 = x_46; } else { lean_dec_ref(x_46); - x_66 = lean_box(0); + x_68 = lean_box(0); } -if (lean_is_scalar(x_66)) { - x_67 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_68)) { + x_69 = lean_alloc_ctor(0, 5, 0); } else { - x_67 = x_66; + x_69 = x_68; } -lean_ctor_set(x_67, 0, x_63); -lean_ctor_set(x_67, 1, x_64); -lean_ctor_set(x_67, 2, x_43); -lean_ctor_set(x_67, 3, x_65); -x_68 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_68, 0, x_58); -lean_ctor_set(x_68, 1, x_59); -lean_ctor_set(x_68, 2, x_67); -lean_ctor_set(x_68, 3, x_60); -lean_ctor_set(x_68, 4, x_61); -lean_ctor_set(x_68, 5, x_62); +lean_ctor_set(x_69, 0, x_64); +lean_ctor_set(x_69, 1, x_65); +lean_ctor_set(x_69, 2, x_43); +lean_ctor_set(x_69, 3, x_66); +lean_ctor_set(x_69, 4, x_67); +x_70 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_70, 0, x_59); +lean_ctor_set(x_70, 1, x_60); +lean_ctor_set(x_70, 2, x_69); +lean_ctor_set(x_70, 3, x_61); +lean_ctor_set(x_70, 4, x_62); +lean_ctor_set(x_70, 5, x_63); if (lean_is_scalar(x_36)) { - x_69 = lean_alloc_ctor(1, 2, 0); + x_71 = lean_alloc_ctor(1, 2, 0); } else { - x_69 = x_36; - lean_ctor_set_tag(x_69, 1); + x_71 = x_36; + lean_ctor_set_tag(x_71, 1); } -lean_ctor_set(x_69, 0, x_47); -lean_ctor_set(x_69, 1, x_68); -return x_69; +lean_ctor_set(x_71, 0, x_47); +lean_ctor_set(x_71, 1, x_70); +return x_71; } } else { -lean_object* x_70; lean_object* x_71; uint8_t x_72; -x_70 = lean_ctor_get(x_45, 2); -lean_inc(x_70); -x_71 = lean_ctor_get(x_44, 0); -lean_inc(x_71); +lean_object* x_72; lean_object* x_73; uint8_t x_74; +x_72 = lean_ctor_get(x_45, 2); +lean_inc(x_72); +x_73 = lean_ctor_get(x_44, 0); +lean_inc(x_73); lean_dec(x_44); -x_72 = !lean_is_exclusive(x_45); -if (x_72 == 0) -{ -lean_object* x_73; uint8_t x_74; -x_73 = lean_ctor_get(x_45, 2); -lean_dec(x_73); -x_74 = !lean_is_exclusive(x_70); +x_74 = !lean_is_exclusive(x_45); if (x_74 == 0) { -lean_object* x_75; lean_object* x_76; -x_75 = lean_ctor_get(x_70, 2); +lean_object* x_75; uint8_t x_76; +x_75 = lean_ctor_get(x_45, 2); lean_dec(x_75); -lean_ctor_set(x_70, 2, x_43); +x_76 = !lean_is_exclusive(x_72); +if (x_76 == 0) +{ +lean_object* x_77; lean_object* x_78; +x_77 = lean_ctor_get(x_72, 2); +lean_dec(x_77); +lean_ctor_set(x_72, 2, x_43); if (lean_is_scalar(x_36)) { - x_76 = lean_alloc_ctor(0, 2, 0); + x_78 = lean_alloc_ctor(0, 2, 0); } else { - x_76 = x_36; + x_78 = x_36; } -lean_ctor_set(x_76, 0, x_71); -lean_ctor_set(x_76, 1, x_45); -return x_76; +lean_ctor_set(x_78, 0, x_73); +lean_ctor_set(x_78, 1, x_45); +return x_78; } else { -lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; -x_77 = lean_ctor_get(x_70, 0); -x_78 = lean_ctor_get(x_70, 1); -x_79 = lean_ctor_get(x_70, 3); +lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; +x_79 = lean_ctor_get(x_72, 0); +x_80 = lean_ctor_get(x_72, 1); +x_81 = lean_ctor_get(x_72, 3); +x_82 = lean_ctor_get(x_72, 4); +lean_inc(x_82); +lean_inc(x_81); +lean_inc(x_80); lean_inc(x_79); -lean_inc(x_78); -lean_inc(x_77); -lean_dec(x_70); -x_80 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_80, 0, x_77); -lean_ctor_set(x_80, 1, x_78); -lean_ctor_set(x_80, 2, x_43); -lean_ctor_set(x_80, 3, x_79); -lean_ctor_set(x_45, 2, x_80); +lean_dec(x_72); +x_83 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_83, 0, x_79); +lean_ctor_set(x_83, 1, x_80); +lean_ctor_set(x_83, 2, x_43); +lean_ctor_set(x_83, 3, x_81); +lean_ctor_set(x_83, 4, x_82); +lean_ctor_set(x_45, 2, x_83); if (lean_is_scalar(x_36)) { - x_81 = lean_alloc_ctor(0, 2, 0); + x_84 = lean_alloc_ctor(0, 2, 0); } else { - x_81 = x_36; + x_84 = x_36; } -lean_ctor_set(x_81, 0, x_71); -lean_ctor_set(x_81, 1, x_45); -return x_81; +lean_ctor_set(x_84, 0, x_73); +lean_ctor_set(x_84, 1, x_45); +return x_84; } } else { -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; -x_82 = lean_ctor_get(x_45, 0); -x_83 = lean_ctor_get(x_45, 1); -x_84 = lean_ctor_get(x_45, 3); -x_85 = lean_ctor_get(x_45, 4); -x_86 = lean_ctor_get(x_45, 5); +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; +x_85 = lean_ctor_get(x_45, 0); +x_86 = lean_ctor_get(x_45, 1); +x_87 = lean_ctor_get(x_45, 3); +x_88 = lean_ctor_get(x_45, 4); +x_89 = lean_ctor_get(x_45, 5); +lean_inc(x_89); +lean_inc(x_88); +lean_inc(x_87); lean_inc(x_86); lean_inc(x_85); -lean_inc(x_84); -lean_inc(x_83); -lean_inc(x_82); lean_dec(x_45); -x_87 = lean_ctor_get(x_70, 0); -lean_inc(x_87); -x_88 = lean_ctor_get(x_70, 1); -lean_inc(x_88); -x_89 = lean_ctor_get(x_70, 3); -lean_inc(x_89); -if (lean_is_exclusive(x_70)) { - lean_ctor_release(x_70, 0); - lean_ctor_release(x_70, 1); - lean_ctor_release(x_70, 2); - lean_ctor_release(x_70, 3); - x_90 = x_70; +x_90 = lean_ctor_get(x_72, 0); +lean_inc(x_90); +x_91 = lean_ctor_get(x_72, 1); +lean_inc(x_91); +x_92 = lean_ctor_get(x_72, 3); +lean_inc(x_92); +x_93 = lean_ctor_get(x_72, 4); +lean_inc(x_93); +if (lean_is_exclusive(x_72)) { + lean_ctor_release(x_72, 0); + lean_ctor_release(x_72, 1); + lean_ctor_release(x_72, 2); + lean_ctor_release(x_72, 3); + lean_ctor_release(x_72, 4); + x_94 = x_72; } else { - lean_dec_ref(x_70); - x_90 = lean_box(0); + lean_dec_ref(x_72); + x_94 = lean_box(0); } -if (lean_is_scalar(x_90)) { - x_91 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_94)) { + x_95 = lean_alloc_ctor(0, 5, 0); } else { - x_91 = x_90; + x_95 = x_94; } -lean_ctor_set(x_91, 0, x_87); -lean_ctor_set(x_91, 1, x_88); -lean_ctor_set(x_91, 2, x_43); -lean_ctor_set(x_91, 3, x_89); -x_92 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_92, 0, x_82); -lean_ctor_set(x_92, 1, x_83); -lean_ctor_set(x_92, 2, x_91); -lean_ctor_set(x_92, 3, x_84); -lean_ctor_set(x_92, 4, x_85); -lean_ctor_set(x_92, 5, x_86); +lean_ctor_set(x_95, 0, x_90); +lean_ctor_set(x_95, 1, x_91); +lean_ctor_set(x_95, 2, x_43); +lean_ctor_set(x_95, 3, x_92); +lean_ctor_set(x_95, 4, x_93); +x_96 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_96, 0, x_85); +lean_ctor_set(x_96, 1, x_86); +lean_ctor_set(x_96, 2, x_95); +lean_ctor_set(x_96, 3, x_87); +lean_ctor_set(x_96, 4, x_88); +lean_ctor_set(x_96, 5, x_89); if (lean_is_scalar(x_36)) { - x_93 = lean_alloc_ctor(0, 2, 0); + x_97 = lean_alloc_ctor(0, 2, 0); } else { - x_93 = x_36; + x_97 = x_36; } -lean_ctor_set(x_93, 0, x_71); -lean_ctor_set(x_93, 1, x_92); -return x_93; +lean_ctor_set(x_97, 0, x_73); +lean_ctor_set(x_97, 1, x_96); +return x_97; } } } } else { -lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; -x_122 = lean_ctor_get(x_41, 0); -x_123 = lean_ctor_get(x_41, 1); -x_124 = lean_ctor_get(x_41, 2); -x_125 = lean_ctor_get(x_41, 3); -lean_inc(x_125); -lean_inc(x_124); -lean_inc(x_123); -lean_inc(x_122); -lean_dec(x_41); -x_159 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_160 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_160, 0, x_122); -lean_ctor_set(x_160, 1, x_123); -lean_ctor_set(x_160, 2, x_159); -lean_ctor_set(x_160, 3, x_125); -lean_ctor_set(x_35, 2, x_160); -x_161 = lean_ctor_get(x_7, 0); -lean_inc(x_161); -x_162 = lean_ctor_get(x_7, 1); -lean_inc(x_162); -x_163 = lean_ctor_get(x_7, 2); -lean_inc(x_163); -x_164 = lean_ctor_get(x_7, 3); -lean_inc(x_164); -x_165 = lean_ctor_get(x_7, 4); -lean_inc(x_165); -if (lean_is_exclusive(x_7)) { - lean_ctor_release(x_7, 0); - lean_ctor_release(x_7, 1); - lean_ctor_release(x_7, 2); - lean_ctor_release(x_7, 3); - lean_ctor_release(x_7, 4); - x_166 = x_7; -} else { - lean_dec_ref(x_7); - x_166 = lean_box(0); -} -x_167 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_167, 0, x_37); -lean_ctor_set(x_167, 1, x_14); -x_168 = lean_array_push(x_163, x_167); -if (lean_is_scalar(x_166)) { - x_169 = lean_alloc_ctor(0, 5, 0); -} else { - x_169 = x_166; -} -lean_ctor_set(x_169, 0, x_161); -lean_ctor_set(x_169, 1, x_162); -lean_ctor_set(x_169, 2, x_168); -lean_ctor_set(x_169, 3, x_164); -lean_ctor_set(x_169, 4, x_165); -x_170 = l_Lean_Meta_isDefEqBindingDomain___main___at___private_Lean_Meta_ExprDefEq_6__isDefEqBindingAux___main___spec__1(x_1, x_2, x_3, x_4, x_5, x_39, x_169, x_35); -if (lean_obj_tag(x_170) == 0) -{ -lean_object* x_171; lean_object* x_172; lean_object* x_173; -x_171 = lean_ctor_get(x_170, 0); -lean_inc(x_171); -x_172 = lean_ctor_get(x_170, 1); -lean_inc(x_172); -lean_dec(x_170); -x_173 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_173, 0, x_171); -x_126 = x_173; -x_127 = x_172; -goto block_158; -} -else -{ -lean_object* x_174; lean_object* x_175; lean_object* x_176; -x_174 = lean_ctor_get(x_170, 0); -lean_inc(x_174); -x_175 = lean_ctor_get(x_170, 1); -lean_inc(x_175); -lean_dec(x_170); -x_176 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_176, 0, x_174); -x_126 = x_176; -x_127 = x_175; -goto block_158; -} -block_158: -{ -if (lean_obj_tag(x_126) == 0) -{ -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; -x_128 = lean_ctor_get(x_127, 2); -lean_inc(x_128); -x_129 = lean_ctor_get(x_126, 0); -lean_inc(x_129); -lean_dec(x_126); -x_130 = lean_ctor_get(x_127, 0); +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_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; +x_126 = lean_ctor_get(x_41, 0); +x_127 = lean_ctor_get(x_41, 1); +x_128 = lean_ctor_get(x_41, 2); +x_129 = lean_ctor_get(x_41, 3); +x_130 = lean_ctor_get(x_41, 4); lean_inc(x_130); -x_131 = lean_ctor_get(x_127, 1); -lean_inc(x_131); -x_132 = lean_ctor_get(x_127, 3); -lean_inc(x_132); -x_133 = lean_ctor_get(x_127, 4); -lean_inc(x_133); -x_134 = lean_ctor_get(x_127, 5); -lean_inc(x_134); -if (lean_is_exclusive(x_127)) { - lean_ctor_release(x_127, 0); - lean_ctor_release(x_127, 1); - lean_ctor_release(x_127, 2); - lean_ctor_release(x_127, 3); - lean_ctor_release(x_127, 4); - lean_ctor_release(x_127, 5); - x_135 = x_127; -} else { - lean_dec_ref(x_127); - x_135 = lean_box(0); -} -x_136 = lean_ctor_get(x_128, 0); -lean_inc(x_136); -x_137 = lean_ctor_get(x_128, 1); -lean_inc(x_137); -x_138 = lean_ctor_get(x_128, 3); -lean_inc(x_138); -if (lean_is_exclusive(x_128)) { - lean_ctor_release(x_128, 0); - lean_ctor_release(x_128, 1); - lean_ctor_release(x_128, 2); - lean_ctor_release(x_128, 3); - x_139 = x_128; -} else { - lean_dec_ref(x_128); - x_139 = lean_box(0); -} -if (lean_is_scalar(x_139)) { - x_140 = lean_alloc_ctor(0, 4, 0); -} else { - x_140 = x_139; -} -lean_ctor_set(x_140, 0, x_136); -lean_ctor_set(x_140, 1, x_137); -lean_ctor_set(x_140, 2, x_124); -lean_ctor_set(x_140, 3, x_138); -if (lean_is_scalar(x_135)) { - x_141 = lean_alloc_ctor(0, 6, 0); -} else { - x_141 = x_135; -} -lean_ctor_set(x_141, 0, x_130); -lean_ctor_set(x_141, 1, x_131); -lean_ctor_set(x_141, 2, x_140); -lean_ctor_set(x_141, 3, x_132); -lean_ctor_set(x_141, 4, x_133); -lean_ctor_set(x_141, 5, x_134); -if (lean_is_scalar(x_36)) { - x_142 = lean_alloc_ctor(1, 2, 0); -} else { - x_142 = x_36; - lean_ctor_set_tag(x_142, 1); -} -lean_ctor_set(x_142, 0, x_129); -lean_ctor_set(x_142, 1, x_141); -return x_142; -} -else -{ -lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; 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; -x_143 = lean_ctor_get(x_127, 2); -lean_inc(x_143); -x_144 = lean_ctor_get(x_126, 0); -lean_inc(x_144); -lean_dec(x_126); -x_145 = lean_ctor_get(x_127, 0); -lean_inc(x_145); -x_146 = lean_ctor_get(x_127, 1); -lean_inc(x_146); -x_147 = lean_ctor_get(x_127, 3); -lean_inc(x_147); -x_148 = lean_ctor_get(x_127, 4); -lean_inc(x_148); -x_149 = lean_ctor_get(x_127, 5); -lean_inc(x_149); -if (lean_is_exclusive(x_127)) { - lean_ctor_release(x_127, 0); - lean_ctor_release(x_127, 1); - lean_ctor_release(x_127, 2); - lean_ctor_release(x_127, 3); - lean_ctor_release(x_127, 4); - lean_ctor_release(x_127, 5); - x_150 = x_127; -} else { - lean_dec_ref(x_127); - x_150 = lean_box(0); -} -x_151 = lean_ctor_get(x_143, 0); -lean_inc(x_151); -x_152 = lean_ctor_get(x_143, 1); -lean_inc(x_152); -x_153 = lean_ctor_get(x_143, 3); -lean_inc(x_153); -if (lean_is_exclusive(x_143)) { - lean_ctor_release(x_143, 0); - lean_ctor_release(x_143, 1); - lean_ctor_release(x_143, 2); - lean_ctor_release(x_143, 3); - x_154 = x_143; -} else { - lean_dec_ref(x_143); - x_154 = lean_box(0); -} -if (lean_is_scalar(x_154)) { - x_155 = lean_alloc_ctor(0, 4, 0); -} else { - x_155 = x_154; -} -lean_ctor_set(x_155, 0, x_151); -lean_ctor_set(x_155, 1, x_152); -lean_ctor_set(x_155, 2, x_124); -lean_ctor_set(x_155, 3, x_153); -if (lean_is_scalar(x_150)) { - x_156 = lean_alloc_ctor(0, 6, 0); -} else { - x_156 = x_150; -} -lean_ctor_set(x_156, 0, x_145); -lean_ctor_set(x_156, 1, x_146); -lean_ctor_set(x_156, 2, x_155); -lean_ctor_set(x_156, 3, x_147); -lean_ctor_set(x_156, 4, x_148); -lean_ctor_set(x_156, 5, x_149); -if (lean_is_scalar(x_36)) { - x_157 = lean_alloc_ctor(0, 2, 0); -} else { - x_157 = x_36; -} -lean_ctor_set(x_157, 0, x_144); -lean_ctor_set(x_157, 1, x_156); -return x_157; -} -} -} -} -else -{ -lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; 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_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; lean_object* x_231; lean_object* x_232; lean_object* x_233; -x_177 = lean_ctor_get(x_35, 2); -x_178 = lean_ctor_get(x_35, 0); -x_179 = lean_ctor_get(x_35, 1); -x_180 = lean_ctor_get(x_35, 3); -x_181 = lean_ctor_get(x_35, 4); -x_182 = lean_ctor_get(x_35, 5); -lean_inc(x_182); -lean_inc(x_181); -lean_inc(x_180); -lean_inc(x_177); -lean_inc(x_179); -lean_inc(x_178); -lean_dec(x_35); -x_183 = lean_ctor_get(x_177, 0); -lean_inc(x_183); -x_184 = lean_ctor_get(x_177, 1); -lean_inc(x_184); -x_185 = lean_ctor_get(x_177, 2); -lean_inc(x_185); -x_186 = lean_ctor_get(x_177, 3); -lean_inc(x_186); -if (lean_is_exclusive(x_177)) { - lean_ctor_release(x_177, 0); - lean_ctor_release(x_177, 1); - lean_ctor_release(x_177, 2); - lean_ctor_release(x_177, 3); - x_187 = x_177; -} else { - lean_dec_ref(x_177); - x_187 = lean_box(0); -} -x_221 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_187)) { - x_222 = lean_alloc_ctor(0, 4, 0); -} else { - x_222 = x_187; -} -lean_ctor_set(x_222, 0, x_183); -lean_ctor_set(x_222, 1, x_184); -lean_ctor_set(x_222, 2, x_221); -lean_ctor_set(x_222, 3, x_186); -x_223 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_223, 0, x_178); -lean_ctor_set(x_223, 1, x_179); -lean_ctor_set(x_223, 2, x_222); -lean_ctor_set(x_223, 3, x_180); -lean_ctor_set(x_223, 4, x_181); -lean_ctor_set(x_223, 5, x_182); -x_224 = lean_ctor_get(x_7, 0); -lean_inc(x_224); -x_225 = lean_ctor_get(x_7, 1); -lean_inc(x_225); -x_226 = lean_ctor_get(x_7, 2); -lean_inc(x_226); -x_227 = lean_ctor_get(x_7, 3); -lean_inc(x_227); -x_228 = lean_ctor_get(x_7, 4); -lean_inc(x_228); +lean_inc(x_129); +lean_inc(x_128); +lean_inc(x_127); +lean_inc(x_126); +lean_dec(x_41); +x_166 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_167 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_167, 0, x_126); +lean_ctor_set(x_167, 1, x_127); +lean_ctor_set(x_167, 2, x_166); +lean_ctor_set(x_167, 3, x_129); +lean_ctor_set(x_167, 4, x_130); +lean_ctor_set(x_35, 2, x_167); +x_168 = lean_ctor_get(x_7, 0); +lean_inc(x_168); +x_169 = lean_ctor_get(x_7, 1); +lean_inc(x_169); +x_170 = lean_ctor_get(x_7, 2); +lean_inc(x_170); +x_171 = lean_ctor_get(x_7, 3); +lean_inc(x_171); +x_172 = lean_ctor_get(x_7, 4); +lean_inc(x_172); if (lean_is_exclusive(x_7)) { lean_ctor_release(x_7, 0); lean_ctor_release(x_7, 1); lean_ctor_release(x_7, 2); lean_ctor_release(x_7, 3); lean_ctor_release(x_7, 4); - x_229 = x_7; + x_173 = x_7; } else { lean_dec_ref(x_7); - x_229 = lean_box(0); + x_173 = lean_box(0); } -x_230 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_230, 0, x_37); -lean_ctor_set(x_230, 1, x_14); -x_231 = lean_array_push(x_226, x_230); -if (lean_is_scalar(x_229)) { +x_174 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_174, 0, x_37); +lean_ctor_set(x_174, 1, x_14); +x_175 = lean_array_push(x_170, x_174); +if (lean_is_scalar(x_173)) { + x_176 = lean_alloc_ctor(0, 5, 0); +} else { + x_176 = x_173; +} +lean_ctor_set(x_176, 0, x_168); +lean_ctor_set(x_176, 1, x_169); +lean_ctor_set(x_176, 2, x_175); +lean_ctor_set(x_176, 3, x_171); +lean_ctor_set(x_176, 4, x_172); +x_177 = l_Lean_Meta_isDefEqBindingDomain___main___at___private_Lean_Meta_ExprDefEq_6__isDefEqBindingAux___main___spec__1(x_1, x_2, x_3, x_4, x_5, x_39, x_176, x_35); +if (lean_obj_tag(x_177) == 0) +{ +lean_object* x_178; lean_object* x_179; lean_object* x_180; +x_178 = lean_ctor_get(x_177, 0); +lean_inc(x_178); +x_179 = lean_ctor_get(x_177, 1); +lean_inc(x_179); +lean_dec(x_177); +x_180 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_180, 0, x_178); +x_131 = x_180; +x_132 = x_179; +goto block_165; +} +else +{ +lean_object* x_181; lean_object* x_182; lean_object* x_183; +x_181 = lean_ctor_get(x_177, 0); +lean_inc(x_181); +x_182 = lean_ctor_get(x_177, 1); +lean_inc(x_182); +lean_dec(x_177); +x_183 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_183, 0, x_181); +x_131 = x_183; +x_132 = x_182; +goto block_165; +} +block_165: +{ +if (lean_obj_tag(x_131) == 0) +{ +lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; +x_133 = lean_ctor_get(x_132, 2); +lean_inc(x_133); +x_134 = lean_ctor_get(x_131, 0); +lean_inc(x_134); +lean_dec(x_131); +x_135 = lean_ctor_get(x_132, 0); +lean_inc(x_135); +x_136 = lean_ctor_get(x_132, 1); +lean_inc(x_136); +x_137 = lean_ctor_get(x_132, 3); +lean_inc(x_137); +x_138 = lean_ctor_get(x_132, 4); +lean_inc(x_138); +x_139 = lean_ctor_get(x_132, 5); +lean_inc(x_139); +if (lean_is_exclusive(x_132)) { + lean_ctor_release(x_132, 0); + lean_ctor_release(x_132, 1); + lean_ctor_release(x_132, 2); + lean_ctor_release(x_132, 3); + lean_ctor_release(x_132, 4); + lean_ctor_release(x_132, 5); + x_140 = x_132; +} else { + lean_dec_ref(x_132); + x_140 = lean_box(0); +} +x_141 = lean_ctor_get(x_133, 0); +lean_inc(x_141); +x_142 = lean_ctor_get(x_133, 1); +lean_inc(x_142); +x_143 = lean_ctor_get(x_133, 3); +lean_inc(x_143); +x_144 = lean_ctor_get(x_133, 4); +lean_inc(x_144); +if (lean_is_exclusive(x_133)) { + lean_ctor_release(x_133, 0); + lean_ctor_release(x_133, 1); + lean_ctor_release(x_133, 2); + lean_ctor_release(x_133, 3); + lean_ctor_release(x_133, 4); + x_145 = x_133; +} else { + lean_dec_ref(x_133); + x_145 = lean_box(0); +} +if (lean_is_scalar(x_145)) { + x_146 = lean_alloc_ctor(0, 5, 0); +} else { + x_146 = x_145; +} +lean_ctor_set(x_146, 0, x_141); +lean_ctor_set(x_146, 1, x_142); +lean_ctor_set(x_146, 2, x_128); +lean_ctor_set(x_146, 3, x_143); +lean_ctor_set(x_146, 4, x_144); +if (lean_is_scalar(x_140)) { + x_147 = lean_alloc_ctor(0, 6, 0); +} else { + x_147 = x_140; +} +lean_ctor_set(x_147, 0, x_135); +lean_ctor_set(x_147, 1, x_136); +lean_ctor_set(x_147, 2, x_146); +lean_ctor_set(x_147, 3, x_137); +lean_ctor_set(x_147, 4, x_138); +lean_ctor_set(x_147, 5, x_139); +if (lean_is_scalar(x_36)) { + x_148 = lean_alloc_ctor(1, 2, 0); +} else { + x_148 = x_36; + lean_ctor_set_tag(x_148, 1); +} +lean_ctor_set(x_148, 0, x_134); +lean_ctor_set(x_148, 1, x_147); +return x_148; +} +else +{ +lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; +x_149 = lean_ctor_get(x_132, 2); +lean_inc(x_149); +x_150 = lean_ctor_get(x_131, 0); +lean_inc(x_150); +lean_dec(x_131); +x_151 = lean_ctor_get(x_132, 0); +lean_inc(x_151); +x_152 = lean_ctor_get(x_132, 1); +lean_inc(x_152); +x_153 = lean_ctor_get(x_132, 3); +lean_inc(x_153); +x_154 = lean_ctor_get(x_132, 4); +lean_inc(x_154); +x_155 = lean_ctor_get(x_132, 5); +lean_inc(x_155); +if (lean_is_exclusive(x_132)) { + lean_ctor_release(x_132, 0); + lean_ctor_release(x_132, 1); + lean_ctor_release(x_132, 2); + lean_ctor_release(x_132, 3); + lean_ctor_release(x_132, 4); + lean_ctor_release(x_132, 5); + x_156 = x_132; +} else { + lean_dec_ref(x_132); + x_156 = lean_box(0); +} +x_157 = lean_ctor_get(x_149, 0); +lean_inc(x_157); +x_158 = lean_ctor_get(x_149, 1); +lean_inc(x_158); +x_159 = lean_ctor_get(x_149, 3); +lean_inc(x_159); +x_160 = lean_ctor_get(x_149, 4); +lean_inc(x_160); +if (lean_is_exclusive(x_149)) { + lean_ctor_release(x_149, 0); + lean_ctor_release(x_149, 1); + lean_ctor_release(x_149, 2); + lean_ctor_release(x_149, 3); + lean_ctor_release(x_149, 4); + x_161 = x_149; +} else { + lean_dec_ref(x_149); + x_161 = lean_box(0); +} +if (lean_is_scalar(x_161)) { + x_162 = lean_alloc_ctor(0, 5, 0); +} else { + x_162 = x_161; +} +lean_ctor_set(x_162, 0, x_157); +lean_ctor_set(x_162, 1, x_158); +lean_ctor_set(x_162, 2, x_128); +lean_ctor_set(x_162, 3, x_159); +lean_ctor_set(x_162, 4, x_160); +if (lean_is_scalar(x_156)) { + x_163 = lean_alloc_ctor(0, 6, 0); +} else { + x_163 = x_156; +} +lean_ctor_set(x_163, 0, x_151); +lean_ctor_set(x_163, 1, x_152); +lean_ctor_set(x_163, 2, x_162); +lean_ctor_set(x_163, 3, x_153); +lean_ctor_set(x_163, 4, x_154); +lean_ctor_set(x_163, 5, x_155); +if (lean_is_scalar(x_36)) { + x_164 = lean_alloc_ctor(0, 2, 0); +} else { + x_164 = x_36; +} +lean_ctor_set(x_164, 0, x_150); +lean_ctor_set(x_164, 1, x_163); +return x_164; +} +} +} +} +else +{ +lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_231; lean_object* x_232; lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_object* x_236; lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; lean_object* x_242; lean_object* x_243; +x_184 = lean_ctor_get(x_35, 2); +x_185 = lean_ctor_get(x_35, 0); +x_186 = lean_ctor_get(x_35, 1); +x_187 = lean_ctor_get(x_35, 3); +x_188 = lean_ctor_get(x_35, 4); +x_189 = lean_ctor_get(x_35, 5); +lean_inc(x_189); +lean_inc(x_188); +lean_inc(x_187); +lean_inc(x_184); +lean_inc(x_186); +lean_inc(x_185); +lean_dec(x_35); +x_190 = lean_ctor_get(x_184, 0); +lean_inc(x_190); +x_191 = lean_ctor_get(x_184, 1); +lean_inc(x_191); +x_192 = lean_ctor_get(x_184, 2); +lean_inc(x_192); +x_193 = lean_ctor_get(x_184, 3); +lean_inc(x_193); +x_194 = lean_ctor_get(x_184, 4); +lean_inc(x_194); +if (lean_is_exclusive(x_184)) { + lean_ctor_release(x_184, 0); + lean_ctor_release(x_184, 1); + lean_ctor_release(x_184, 2); + lean_ctor_release(x_184, 3); + lean_ctor_release(x_184, 4); + x_195 = x_184; +} else { + lean_dec_ref(x_184); + x_195 = lean_box(0); +} +x_231 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_195)) { x_232 = lean_alloc_ctor(0, 5, 0); } else { - x_232 = x_229; + x_232 = x_195; } -lean_ctor_set(x_232, 0, x_224); -lean_ctor_set(x_232, 1, x_225); +lean_ctor_set(x_232, 0, x_190); +lean_ctor_set(x_232, 1, x_191); lean_ctor_set(x_232, 2, x_231); -lean_ctor_set(x_232, 3, x_227); -lean_ctor_set(x_232, 4, x_228); -x_233 = l_Lean_Meta_isDefEqBindingDomain___main___at___private_Lean_Meta_ExprDefEq_6__isDefEqBindingAux___main___spec__1(x_1, x_2, x_3, x_4, x_5, x_39, x_232, x_223); -if (lean_obj_tag(x_233) == 0) -{ -lean_object* x_234; lean_object* x_235; lean_object* x_236; -x_234 = lean_ctor_get(x_233, 0); +lean_ctor_set(x_232, 3, x_193); +lean_ctor_set(x_232, 4, x_194); +x_233 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_233, 0, x_185); +lean_ctor_set(x_233, 1, x_186); +lean_ctor_set(x_233, 2, x_232); +lean_ctor_set(x_233, 3, x_187); +lean_ctor_set(x_233, 4, x_188); +lean_ctor_set(x_233, 5, x_189); +x_234 = lean_ctor_get(x_7, 0); lean_inc(x_234); -x_235 = lean_ctor_get(x_233, 1); +x_235 = lean_ctor_get(x_7, 1); lean_inc(x_235); -lean_dec(x_233); -x_236 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_236, 0, x_234); -x_188 = x_236; -x_189 = x_235; -goto block_220; -} -else -{ -lean_object* x_237; lean_object* x_238; lean_object* x_239; -x_237 = lean_ctor_get(x_233, 0); +x_236 = lean_ctor_get(x_7, 2); +lean_inc(x_236); +x_237 = lean_ctor_get(x_7, 3); lean_inc(x_237); -x_238 = lean_ctor_get(x_233, 1); +x_238 = lean_ctor_get(x_7, 4); lean_inc(x_238); -lean_dec(x_233); -x_239 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_239, 0, x_237); -x_188 = x_239; -x_189 = x_238; -goto block_220; -} -block_220: -{ -if (lean_obj_tag(x_188) == 0) -{ -lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; -x_190 = lean_ctor_get(x_189, 2); -lean_inc(x_190); -x_191 = lean_ctor_get(x_188, 0); -lean_inc(x_191); -lean_dec(x_188); -x_192 = lean_ctor_get(x_189, 0); -lean_inc(x_192); -x_193 = lean_ctor_get(x_189, 1); -lean_inc(x_193); -x_194 = lean_ctor_get(x_189, 3); -lean_inc(x_194); -x_195 = lean_ctor_get(x_189, 4); -lean_inc(x_195); -x_196 = lean_ctor_get(x_189, 5); -lean_inc(x_196); -if (lean_is_exclusive(x_189)) { - lean_ctor_release(x_189, 0); - lean_ctor_release(x_189, 1); - lean_ctor_release(x_189, 2); - lean_ctor_release(x_189, 3); - lean_ctor_release(x_189, 4); - lean_ctor_release(x_189, 5); - x_197 = x_189; +if (lean_is_exclusive(x_7)) { + lean_ctor_release(x_7, 0); + lean_ctor_release(x_7, 1); + lean_ctor_release(x_7, 2); + lean_ctor_release(x_7, 3); + lean_ctor_release(x_7, 4); + x_239 = x_7; } else { - lean_dec_ref(x_189); - x_197 = lean_box(0); + lean_dec_ref(x_7); + x_239 = lean_box(0); } -x_198 = lean_ctor_get(x_190, 0); +x_240 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_240, 0, x_37); +lean_ctor_set(x_240, 1, x_14); +x_241 = lean_array_push(x_236, x_240); +if (lean_is_scalar(x_239)) { + x_242 = lean_alloc_ctor(0, 5, 0); +} else { + x_242 = x_239; +} +lean_ctor_set(x_242, 0, x_234); +lean_ctor_set(x_242, 1, x_235); +lean_ctor_set(x_242, 2, x_241); +lean_ctor_set(x_242, 3, x_237); +lean_ctor_set(x_242, 4, x_238); +x_243 = l_Lean_Meta_isDefEqBindingDomain___main___at___private_Lean_Meta_ExprDefEq_6__isDefEqBindingAux___main___spec__1(x_1, x_2, x_3, x_4, x_5, x_39, x_242, x_233); +if (lean_obj_tag(x_243) == 0) +{ +lean_object* x_244; lean_object* x_245; lean_object* x_246; +x_244 = lean_ctor_get(x_243, 0); +lean_inc(x_244); +x_245 = lean_ctor_get(x_243, 1); +lean_inc(x_245); +lean_dec(x_243); +x_246 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_246, 0, x_244); +x_196 = x_246; +x_197 = x_245; +goto block_230; +} +else +{ +lean_object* x_247; lean_object* x_248; lean_object* x_249; +x_247 = lean_ctor_get(x_243, 0); +lean_inc(x_247); +x_248 = lean_ctor_get(x_243, 1); +lean_inc(x_248); +lean_dec(x_243); +x_249 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_249, 0, x_247); +x_196 = x_249; +x_197 = x_248; +goto block_230; +} +block_230: +{ +if (lean_obj_tag(x_196) == 0) +{ +lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; +x_198 = lean_ctor_get(x_197, 2); lean_inc(x_198); -x_199 = lean_ctor_get(x_190, 1); +x_199 = lean_ctor_get(x_196, 0); lean_inc(x_199); -x_200 = lean_ctor_get(x_190, 3); +lean_dec(x_196); +x_200 = lean_ctor_get(x_197, 0); lean_inc(x_200); -if (lean_is_exclusive(x_190)) { - lean_ctor_release(x_190, 0); - lean_ctor_release(x_190, 1); - lean_ctor_release(x_190, 2); - lean_ctor_release(x_190, 3); - x_201 = x_190; +x_201 = lean_ctor_get(x_197, 1); +lean_inc(x_201); +x_202 = lean_ctor_get(x_197, 3); +lean_inc(x_202); +x_203 = lean_ctor_get(x_197, 4); +lean_inc(x_203); +x_204 = lean_ctor_get(x_197, 5); +lean_inc(x_204); +if (lean_is_exclusive(x_197)) { + lean_ctor_release(x_197, 0); + lean_ctor_release(x_197, 1); + lean_ctor_release(x_197, 2); + lean_ctor_release(x_197, 3); + lean_ctor_release(x_197, 4); + lean_ctor_release(x_197, 5); + x_205 = x_197; } else { - lean_dec_ref(x_190); - x_201 = lean_box(0); + lean_dec_ref(x_197); + x_205 = lean_box(0); } -if (lean_is_scalar(x_201)) { - x_202 = lean_alloc_ctor(0, 4, 0); -} else { - x_202 = x_201; -} -lean_ctor_set(x_202, 0, x_198); -lean_ctor_set(x_202, 1, x_199); -lean_ctor_set(x_202, 2, x_185); -lean_ctor_set(x_202, 3, x_200); -if (lean_is_scalar(x_197)) { - x_203 = lean_alloc_ctor(0, 6, 0); -} else { - x_203 = x_197; -} -lean_ctor_set(x_203, 0, x_192); -lean_ctor_set(x_203, 1, x_193); -lean_ctor_set(x_203, 2, x_202); -lean_ctor_set(x_203, 3, x_194); -lean_ctor_set(x_203, 4, x_195); -lean_ctor_set(x_203, 5, x_196); -if (lean_is_scalar(x_36)) { - x_204 = lean_alloc_ctor(1, 2, 0); -} else { - x_204 = x_36; - lean_ctor_set_tag(x_204, 1); -} -lean_ctor_set(x_204, 0, x_191); -lean_ctor_set(x_204, 1, x_203); -return x_204; -} -else -{ -lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; -x_205 = lean_ctor_get(x_189, 2); -lean_inc(x_205); -x_206 = lean_ctor_get(x_188, 0); +x_206 = lean_ctor_get(x_198, 0); lean_inc(x_206); -lean_dec(x_188); -x_207 = lean_ctor_get(x_189, 0); +x_207 = lean_ctor_get(x_198, 1); lean_inc(x_207); -x_208 = lean_ctor_get(x_189, 1); +x_208 = lean_ctor_get(x_198, 3); lean_inc(x_208); -x_209 = lean_ctor_get(x_189, 3); +x_209 = lean_ctor_get(x_198, 4); lean_inc(x_209); -x_210 = lean_ctor_get(x_189, 4); -lean_inc(x_210); -x_211 = lean_ctor_get(x_189, 5); -lean_inc(x_211); -if (lean_is_exclusive(x_189)) { - lean_ctor_release(x_189, 0); - lean_ctor_release(x_189, 1); - lean_ctor_release(x_189, 2); - lean_ctor_release(x_189, 3); - lean_ctor_release(x_189, 4); - lean_ctor_release(x_189, 5); - x_212 = x_189; +if (lean_is_exclusive(x_198)) { + lean_ctor_release(x_198, 0); + lean_ctor_release(x_198, 1); + lean_ctor_release(x_198, 2); + lean_ctor_release(x_198, 3); + lean_ctor_release(x_198, 4); + x_210 = x_198; } else { - lean_dec_ref(x_189); - x_212 = lean_box(0); + lean_dec_ref(x_198); + x_210 = lean_box(0); } -x_213 = lean_ctor_get(x_205, 0); -lean_inc(x_213); -x_214 = lean_ctor_get(x_205, 1); -lean_inc(x_214); -x_215 = lean_ctor_get(x_205, 3); -lean_inc(x_215); -if (lean_is_exclusive(x_205)) { - lean_ctor_release(x_205, 0); - lean_ctor_release(x_205, 1); - lean_ctor_release(x_205, 2); - lean_ctor_release(x_205, 3); - x_216 = x_205; +if (lean_is_scalar(x_210)) { + x_211 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_205); - x_216 = lean_box(0); + x_211 = x_210; } -if (lean_is_scalar(x_216)) { - x_217 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_211, 0, x_206); +lean_ctor_set(x_211, 1, x_207); +lean_ctor_set(x_211, 2, x_192); +lean_ctor_set(x_211, 3, x_208); +lean_ctor_set(x_211, 4, x_209); +if (lean_is_scalar(x_205)) { + x_212 = lean_alloc_ctor(0, 6, 0); } else { - x_217 = x_216; + x_212 = x_205; } -lean_ctor_set(x_217, 0, x_213); -lean_ctor_set(x_217, 1, x_214); -lean_ctor_set(x_217, 2, x_185); -lean_ctor_set(x_217, 3, x_215); -if (lean_is_scalar(x_212)) { - x_218 = lean_alloc_ctor(0, 6, 0); -} else { - x_218 = x_212; -} -lean_ctor_set(x_218, 0, x_207); -lean_ctor_set(x_218, 1, x_208); -lean_ctor_set(x_218, 2, x_217); -lean_ctor_set(x_218, 3, x_209); -lean_ctor_set(x_218, 4, x_210); -lean_ctor_set(x_218, 5, x_211); +lean_ctor_set(x_212, 0, x_200); +lean_ctor_set(x_212, 1, x_201); +lean_ctor_set(x_212, 2, x_211); +lean_ctor_set(x_212, 3, x_202); +lean_ctor_set(x_212, 4, x_203); +lean_ctor_set(x_212, 5, x_204); if (lean_is_scalar(x_36)) { - x_219 = lean_alloc_ctor(0, 2, 0); + x_213 = lean_alloc_ctor(1, 2, 0); } else { - x_219 = x_36; + x_213 = x_36; + lean_ctor_set_tag(x_213, 1); } -lean_ctor_set(x_219, 0, x_206); -lean_ctor_set(x_219, 1, x_218); -return x_219; +lean_ctor_set(x_213, 0, x_199); +lean_ctor_set(x_213, 1, x_212); +return x_213; +} +else +{ +lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; 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; +x_214 = lean_ctor_get(x_197, 2); +lean_inc(x_214); +x_215 = lean_ctor_get(x_196, 0); +lean_inc(x_215); +lean_dec(x_196); +x_216 = lean_ctor_get(x_197, 0); +lean_inc(x_216); +x_217 = lean_ctor_get(x_197, 1); +lean_inc(x_217); +x_218 = lean_ctor_get(x_197, 3); +lean_inc(x_218); +x_219 = lean_ctor_get(x_197, 4); +lean_inc(x_219); +x_220 = lean_ctor_get(x_197, 5); +lean_inc(x_220); +if (lean_is_exclusive(x_197)) { + lean_ctor_release(x_197, 0); + lean_ctor_release(x_197, 1); + lean_ctor_release(x_197, 2); + lean_ctor_release(x_197, 3); + lean_ctor_release(x_197, 4); + lean_ctor_release(x_197, 5); + x_221 = x_197; +} else { + lean_dec_ref(x_197); + x_221 = lean_box(0); +} +x_222 = lean_ctor_get(x_214, 0); +lean_inc(x_222); +x_223 = lean_ctor_get(x_214, 1); +lean_inc(x_223); +x_224 = lean_ctor_get(x_214, 3); +lean_inc(x_224); +x_225 = lean_ctor_get(x_214, 4); +lean_inc(x_225); +if (lean_is_exclusive(x_214)) { + lean_ctor_release(x_214, 0); + lean_ctor_release(x_214, 1); + lean_ctor_release(x_214, 2); + lean_ctor_release(x_214, 3); + lean_ctor_release(x_214, 4); + x_226 = x_214; +} else { + lean_dec_ref(x_214); + x_226 = lean_box(0); +} +if (lean_is_scalar(x_226)) { + x_227 = lean_alloc_ctor(0, 5, 0); +} else { + x_227 = x_226; +} +lean_ctor_set(x_227, 0, x_222); +lean_ctor_set(x_227, 1, x_223); +lean_ctor_set(x_227, 2, x_192); +lean_ctor_set(x_227, 3, x_224); +lean_ctor_set(x_227, 4, x_225); +if (lean_is_scalar(x_221)) { + x_228 = lean_alloc_ctor(0, 6, 0); +} else { + x_228 = x_221; +} +lean_ctor_set(x_228, 0, x_216); +lean_ctor_set(x_228, 1, x_217); +lean_ctor_set(x_228, 2, x_227); +lean_ctor_set(x_228, 3, x_218); +lean_ctor_set(x_228, 4, x_219); +lean_ctor_set(x_228, 5, x_220); +if (lean_is_scalar(x_36)) { + x_229 = lean_alloc_ctor(0, 2, 0); +} else { + x_229 = x_36; +} +lean_ctor_set(x_229, 0, x_215); +lean_ctor_set(x_229, 1, x_228); +return x_229; } } } @@ -5587,81 +5661,81 @@ return x_219; } else { -uint8_t x_240; +uint8_t x_250; lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); -x_240 = !lean_is_exclusive(x_29); -if (x_240 == 0) +x_250 = !lean_is_exclusive(x_29); +if (x_250 == 0) { return x_29; } else { -lean_object* x_241; lean_object* x_242; lean_object* x_243; -x_241 = lean_ctor_get(x_29, 0); -x_242 = lean_ctor_get(x_29, 1); -lean_inc(x_242); -lean_inc(x_241); +lean_object* x_251; lean_object* x_252; lean_object* x_253; +x_251 = lean_ctor_get(x_29, 0); +x_252 = lean_ctor_get(x_29, 1); +lean_inc(x_252); +lean_inc(x_251); lean_dec(x_29); -x_243 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_243, 0, x_241); -lean_ctor_set(x_243, 1, x_242); -return x_243; +x_253 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_253, 0, x_251); +lean_ctor_set(x_253, 1, x_252); +return x_253; } } } } else { -uint8_t x_244; +uint8_t x_254; lean_dec(x_18); lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); -x_244 = !lean_is_exclusive(x_21); -if (x_244 == 0) +x_254 = !lean_is_exclusive(x_21); +if (x_254 == 0) { return x_21; } else { -lean_object* x_245; lean_object* x_246; lean_object* x_247; -x_245 = lean_ctor_get(x_21, 0); -x_246 = lean_ctor_get(x_21, 1); -lean_inc(x_246); -lean_inc(x_245); +lean_object* x_255; lean_object* x_256; lean_object* x_257; +x_255 = lean_ctor_get(x_21, 0); +x_256 = lean_ctor_get(x_21, 1); +lean_inc(x_256); +lean_inc(x_255); lean_dec(x_21); -x_247 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_247, 0, x_245); -lean_ctor_set(x_247, 1, x_246); -return x_247; +x_257 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_257, 0, x_255); +lean_ctor_set(x_257, 1, x_256); +return x_257; } } } else { -uint8_t x_248; +uint8_t x_258; lean_dec(x_14); lean_dec(x_7); lean_dec(x_6); -x_248 = !lean_is_exclusive(x_15); -if (x_248 == 0) +x_258 = !lean_is_exclusive(x_15); +if (x_258 == 0) { return x_15; } else { -lean_object* x_249; lean_object* x_250; lean_object* x_251; -x_249 = lean_ctor_get(x_15, 0); -x_250 = lean_ctor_get(x_15, 1); -lean_inc(x_250); -lean_inc(x_249); +lean_object* x_259; lean_object* x_260; lean_object* x_261; +x_259 = lean_ctor_get(x_15, 0); +x_260 = lean_ctor_get(x_15, 1); +lean_inc(x_260); +lean_inc(x_259); lean_dec(x_15); -x_251 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_251, 0, x_249); -lean_ctor_set(x_251, 1, x_250); -return x_251; +x_261 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_261, 0, x_259); +lean_ctor_set(x_261, 1, x_260); +return x_261; } } } @@ -10013,105 +10087,105 @@ x_41 = lean_ctor_get(x_35, 2); x_42 = !lean_is_exclusive(x_41); if (x_42 == 0) { -lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_95; uint8_t x_96; +lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_99; uint8_t x_100; x_43 = lean_ctor_get(x_41, 2); -x_95 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_41, 2, x_95); -x_96 = !lean_is_exclusive(x_8); -if (x_96 == 0) +x_99 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_41, 2, x_99); +x_100 = !lean_is_exclusive(x_8); +if (x_100 == 0) { -lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; -x_97 = lean_ctor_get(x_8, 2); -x_98 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_98, 0, x_37); -lean_ctor_set(x_98, 1, x_24); -x_99 = lean_array_push(x_97, x_98); -lean_ctor_set(x_8, 2, x_99); -x_100 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_39, x_8, x_35); -if (lean_obj_tag(x_100) == 0) +lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; +x_101 = lean_ctor_get(x_8, 2); +x_102 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_102, 0, x_37); +lean_ctor_set(x_102, 1, x_24); +x_103 = lean_array_push(x_101, x_102); +lean_ctor_set(x_8, 2, x_103); +x_104 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_39, x_8, x_35); +if (lean_obj_tag(x_104) == 0) { -lean_object* x_101; lean_object* x_102; lean_object* x_103; -x_101 = lean_ctor_get(x_100, 0); -lean_inc(x_101); -x_102 = lean_ctor_get(x_100, 1); -lean_inc(x_102); -lean_dec(x_100); -x_103 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_103, 0, x_101); -x_44 = x_103; -x_45 = x_102; -goto block_94; -} -else -{ -lean_object* x_104; lean_object* x_105; lean_object* x_106; -x_104 = lean_ctor_get(x_100, 0); -lean_inc(x_104); -x_105 = lean_ctor_get(x_100, 1); +lean_object* x_105; lean_object* x_106; lean_object* x_107; +x_105 = lean_ctor_get(x_104, 0); lean_inc(x_105); -lean_dec(x_100); -x_106 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_106, 0, x_104); -x_44 = x_106; -x_45 = x_105; -goto block_94; -} +x_106 = lean_ctor_get(x_104, 1); +lean_inc(x_106); +lean_dec(x_104); +x_107 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_107, 0, x_105); +x_44 = x_107; +x_45 = x_106; +goto block_98; } else { -lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; -x_107 = lean_ctor_get(x_8, 0); -x_108 = lean_ctor_get(x_8, 1); -x_109 = lean_ctor_get(x_8, 2); -x_110 = lean_ctor_get(x_8, 3); -x_111 = lean_ctor_get(x_8, 4); -lean_inc(x_111); -lean_inc(x_110); -lean_inc(x_109); +lean_object* x_108; lean_object* x_109; lean_object* x_110; +x_108 = lean_ctor_get(x_104, 0); lean_inc(x_108); -lean_inc(x_107); -lean_dec(x_8); -x_112 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_112, 0, x_37); -lean_ctor_set(x_112, 1, x_24); -x_113 = lean_array_push(x_109, x_112); -x_114 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_114, 0, x_107); -lean_ctor_set(x_114, 1, x_108); -lean_ctor_set(x_114, 2, x_113); -lean_ctor_set(x_114, 3, x_110); -lean_ctor_set(x_114, 4, x_111); -x_115 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_39, x_114, x_35); -if (lean_obj_tag(x_115) == 0) -{ -lean_object* x_116; lean_object* x_117; lean_object* x_118; -x_116 = lean_ctor_get(x_115, 0); -lean_inc(x_116); -x_117 = lean_ctor_get(x_115, 1); -lean_inc(x_117); -lean_dec(x_115); -x_118 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_118, 0, x_116); -x_44 = x_118; -x_45 = x_117; -goto block_94; +x_109 = lean_ctor_get(x_104, 1); +lean_inc(x_109); +lean_dec(x_104); +x_110 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_110, 0, x_108); +x_44 = x_110; +x_45 = x_109; +goto block_98; +} } else { -lean_object* x_119; lean_object* x_120; lean_object* x_121; -x_119 = lean_ctor_get(x_115, 0); -lean_inc(x_119); -x_120 = lean_ctor_get(x_115, 1); +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; +x_111 = lean_ctor_get(x_8, 0); +x_112 = lean_ctor_get(x_8, 1); +x_113 = lean_ctor_get(x_8, 2); +x_114 = lean_ctor_get(x_8, 3); +x_115 = lean_ctor_get(x_8, 4); +lean_inc(x_115); +lean_inc(x_114); +lean_inc(x_113); +lean_inc(x_112); +lean_inc(x_111); +lean_dec(x_8); +x_116 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_116, 0, x_37); +lean_ctor_set(x_116, 1, x_24); +x_117 = lean_array_push(x_113, x_116); +x_118 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_118, 0, x_111); +lean_ctor_set(x_118, 1, x_112); +lean_ctor_set(x_118, 2, x_117); +lean_ctor_set(x_118, 3, x_114); +lean_ctor_set(x_118, 4, x_115); +x_119 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_39, x_118, x_35); +if (lean_obj_tag(x_119) == 0) +{ +lean_object* x_120; lean_object* x_121; lean_object* x_122; +x_120 = lean_ctor_get(x_119, 0); lean_inc(x_120); -lean_dec(x_115); -x_121 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_121, 0, x_119); -x_44 = x_121; -x_45 = x_120; -goto block_94; +x_121 = lean_ctor_get(x_119, 1); +lean_inc(x_121); +lean_dec(x_119); +x_122 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_122, 0, x_120); +x_44 = x_122; +x_45 = x_121; +goto block_98; +} +else +{ +lean_object* x_123; lean_object* x_124; lean_object* x_125; +x_123 = lean_ctor_get(x_119, 0); +lean_inc(x_123); +x_124 = lean_ctor_get(x_119, 1); +lean_inc(x_124); +lean_dec(x_119); +x_125 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_125, 0, x_123); +x_44 = x_125; +x_45 = x_124; +goto block_98; } } -block_94: +block_98: { if (lean_obj_tag(x_44) == 0) { @@ -10146,1284 +10220,1262 @@ 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_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; x_53 = lean_ctor_get(x_46, 0); x_54 = lean_ctor_get(x_46, 1); x_55 = lean_ctor_get(x_46, 3); +x_56 = lean_ctor_get(x_46, 4); +lean_inc(x_56); lean_inc(x_55); lean_inc(x_54); lean_inc(x_53); lean_dec(x_46); -x_56 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_56, 0, x_53); -lean_ctor_set(x_56, 1, x_54); -lean_ctor_set(x_56, 2, x_43); -lean_ctor_set(x_56, 3, x_55); -lean_ctor_set(x_45, 2, x_56); +x_57 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_57, 0, x_53); +lean_ctor_set(x_57, 1, x_54); +lean_ctor_set(x_57, 2, x_43); +lean_ctor_set(x_57, 3, x_55); +lean_ctor_set(x_57, 4, x_56); +lean_ctor_set(x_45, 2, x_57); if (lean_is_scalar(x_36)) { - x_57 = lean_alloc_ctor(1, 2, 0); + x_58 = lean_alloc_ctor(1, 2, 0); } else { - x_57 = x_36; - lean_ctor_set_tag(x_57, 1); + x_58 = x_36; + lean_ctor_set_tag(x_58, 1); } -lean_ctor_set(x_57, 0, x_47); -lean_ctor_set(x_57, 1, x_45); -return x_57; +lean_ctor_set(x_58, 0, x_47); +lean_ctor_set(x_58, 1, x_45); +return x_58; } } else { -lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; -x_58 = lean_ctor_get(x_45, 0); -x_59 = lean_ctor_get(x_45, 1); -x_60 = lean_ctor_get(x_45, 3); -x_61 = lean_ctor_get(x_45, 4); -x_62 = lean_ctor_get(x_45, 5); +lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; +x_59 = lean_ctor_get(x_45, 0); +x_60 = lean_ctor_get(x_45, 1); +x_61 = lean_ctor_get(x_45, 3); +x_62 = lean_ctor_get(x_45, 4); +x_63 = lean_ctor_get(x_45, 5); +lean_inc(x_63); lean_inc(x_62); lean_inc(x_61); lean_inc(x_60); lean_inc(x_59); -lean_inc(x_58); lean_dec(x_45); -x_63 = lean_ctor_get(x_46, 0); -lean_inc(x_63); -x_64 = lean_ctor_get(x_46, 1); +x_64 = lean_ctor_get(x_46, 0); lean_inc(x_64); -x_65 = lean_ctor_get(x_46, 3); +x_65 = lean_ctor_get(x_46, 1); lean_inc(x_65); +x_66 = lean_ctor_get(x_46, 3); +lean_inc(x_66); +x_67 = lean_ctor_get(x_46, 4); +lean_inc(x_67); if (lean_is_exclusive(x_46)) { lean_ctor_release(x_46, 0); lean_ctor_release(x_46, 1); lean_ctor_release(x_46, 2); lean_ctor_release(x_46, 3); - x_66 = x_46; + lean_ctor_release(x_46, 4); + x_68 = x_46; } else { lean_dec_ref(x_46); - x_66 = lean_box(0); + x_68 = lean_box(0); } -if (lean_is_scalar(x_66)) { - x_67 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_68)) { + x_69 = lean_alloc_ctor(0, 5, 0); } else { - x_67 = x_66; + x_69 = x_68; } -lean_ctor_set(x_67, 0, x_63); -lean_ctor_set(x_67, 1, x_64); -lean_ctor_set(x_67, 2, x_43); -lean_ctor_set(x_67, 3, x_65); -x_68 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_68, 0, x_58); -lean_ctor_set(x_68, 1, x_59); -lean_ctor_set(x_68, 2, x_67); -lean_ctor_set(x_68, 3, x_60); -lean_ctor_set(x_68, 4, x_61); -lean_ctor_set(x_68, 5, x_62); +lean_ctor_set(x_69, 0, x_64); +lean_ctor_set(x_69, 1, x_65); +lean_ctor_set(x_69, 2, x_43); +lean_ctor_set(x_69, 3, x_66); +lean_ctor_set(x_69, 4, x_67); +x_70 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_70, 0, x_59); +lean_ctor_set(x_70, 1, x_60); +lean_ctor_set(x_70, 2, x_69); +lean_ctor_set(x_70, 3, x_61); +lean_ctor_set(x_70, 4, x_62); +lean_ctor_set(x_70, 5, x_63); if (lean_is_scalar(x_36)) { - x_69 = lean_alloc_ctor(1, 2, 0); + x_71 = lean_alloc_ctor(1, 2, 0); } else { - x_69 = x_36; - lean_ctor_set_tag(x_69, 1); + x_71 = x_36; + lean_ctor_set_tag(x_71, 1); } -lean_ctor_set(x_69, 0, x_47); -lean_ctor_set(x_69, 1, x_68); -return x_69; +lean_ctor_set(x_71, 0, x_47); +lean_ctor_set(x_71, 1, x_70); +return x_71; } } else { -lean_object* x_70; lean_object* x_71; uint8_t x_72; -x_70 = lean_ctor_get(x_45, 2); -lean_inc(x_70); -x_71 = lean_ctor_get(x_44, 0); -lean_inc(x_71); +lean_object* x_72; lean_object* x_73; uint8_t x_74; +x_72 = lean_ctor_get(x_45, 2); +lean_inc(x_72); +x_73 = lean_ctor_get(x_44, 0); +lean_inc(x_73); lean_dec(x_44); -x_72 = !lean_is_exclusive(x_45); -if (x_72 == 0) -{ -lean_object* x_73; uint8_t x_74; -x_73 = lean_ctor_get(x_45, 2); -lean_dec(x_73); -x_74 = !lean_is_exclusive(x_70); +x_74 = !lean_is_exclusive(x_45); if (x_74 == 0) { -lean_object* x_75; lean_object* x_76; -x_75 = lean_ctor_get(x_70, 2); +lean_object* x_75; uint8_t x_76; +x_75 = lean_ctor_get(x_45, 2); lean_dec(x_75); -lean_ctor_set(x_70, 2, x_43); +x_76 = !lean_is_exclusive(x_72); +if (x_76 == 0) +{ +lean_object* x_77; lean_object* x_78; +x_77 = lean_ctor_get(x_72, 2); +lean_dec(x_77); +lean_ctor_set(x_72, 2, x_43); if (lean_is_scalar(x_36)) { - x_76 = lean_alloc_ctor(0, 2, 0); + x_78 = lean_alloc_ctor(0, 2, 0); } else { - x_76 = x_36; + x_78 = x_36; } -lean_ctor_set(x_76, 0, x_71); -lean_ctor_set(x_76, 1, x_45); -return x_76; +lean_ctor_set(x_78, 0, x_73); +lean_ctor_set(x_78, 1, x_45); +return x_78; } else { -lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; -x_77 = lean_ctor_get(x_70, 0); -x_78 = lean_ctor_get(x_70, 1); -x_79 = lean_ctor_get(x_70, 3); +lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; +x_79 = lean_ctor_get(x_72, 0); +x_80 = lean_ctor_get(x_72, 1); +x_81 = lean_ctor_get(x_72, 3); +x_82 = lean_ctor_get(x_72, 4); +lean_inc(x_82); +lean_inc(x_81); +lean_inc(x_80); lean_inc(x_79); -lean_inc(x_78); -lean_inc(x_77); -lean_dec(x_70); -x_80 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_80, 0, x_77); -lean_ctor_set(x_80, 1, x_78); -lean_ctor_set(x_80, 2, x_43); -lean_ctor_set(x_80, 3, x_79); -lean_ctor_set(x_45, 2, x_80); +lean_dec(x_72); +x_83 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_83, 0, x_79); +lean_ctor_set(x_83, 1, x_80); +lean_ctor_set(x_83, 2, x_43); +lean_ctor_set(x_83, 3, x_81); +lean_ctor_set(x_83, 4, x_82); +lean_ctor_set(x_45, 2, x_83); if (lean_is_scalar(x_36)) { - x_81 = lean_alloc_ctor(0, 2, 0); + x_84 = lean_alloc_ctor(0, 2, 0); } else { - x_81 = x_36; + x_84 = x_36; } -lean_ctor_set(x_81, 0, x_71); -lean_ctor_set(x_81, 1, x_45); -return x_81; +lean_ctor_set(x_84, 0, x_73); +lean_ctor_set(x_84, 1, x_45); +return x_84; } } else { -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; -x_82 = lean_ctor_get(x_45, 0); -x_83 = lean_ctor_get(x_45, 1); -x_84 = lean_ctor_get(x_45, 3); -x_85 = lean_ctor_get(x_45, 4); -x_86 = lean_ctor_get(x_45, 5); +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; +x_85 = lean_ctor_get(x_45, 0); +x_86 = lean_ctor_get(x_45, 1); +x_87 = lean_ctor_get(x_45, 3); +x_88 = lean_ctor_get(x_45, 4); +x_89 = lean_ctor_get(x_45, 5); +lean_inc(x_89); +lean_inc(x_88); +lean_inc(x_87); lean_inc(x_86); lean_inc(x_85); -lean_inc(x_84); -lean_inc(x_83); -lean_inc(x_82); lean_dec(x_45); -x_87 = lean_ctor_get(x_70, 0); -lean_inc(x_87); -x_88 = lean_ctor_get(x_70, 1); -lean_inc(x_88); -x_89 = lean_ctor_get(x_70, 3); -lean_inc(x_89); -if (lean_is_exclusive(x_70)) { - lean_ctor_release(x_70, 0); - lean_ctor_release(x_70, 1); - lean_ctor_release(x_70, 2); - lean_ctor_release(x_70, 3); - x_90 = x_70; +x_90 = lean_ctor_get(x_72, 0); +lean_inc(x_90); +x_91 = lean_ctor_get(x_72, 1); +lean_inc(x_91); +x_92 = lean_ctor_get(x_72, 3); +lean_inc(x_92); +x_93 = lean_ctor_get(x_72, 4); +lean_inc(x_93); +if (lean_is_exclusive(x_72)) { + lean_ctor_release(x_72, 0); + lean_ctor_release(x_72, 1); + lean_ctor_release(x_72, 2); + lean_ctor_release(x_72, 3); + lean_ctor_release(x_72, 4); + x_94 = x_72; } else { - lean_dec_ref(x_70); - x_90 = lean_box(0); + lean_dec_ref(x_72); + x_94 = lean_box(0); } -if (lean_is_scalar(x_90)) { - x_91 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_94)) { + x_95 = lean_alloc_ctor(0, 5, 0); } else { - x_91 = x_90; + x_95 = x_94; } -lean_ctor_set(x_91, 0, x_87); -lean_ctor_set(x_91, 1, x_88); -lean_ctor_set(x_91, 2, x_43); -lean_ctor_set(x_91, 3, x_89); -x_92 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_92, 0, x_82); -lean_ctor_set(x_92, 1, x_83); -lean_ctor_set(x_92, 2, x_91); -lean_ctor_set(x_92, 3, x_84); -lean_ctor_set(x_92, 4, x_85); -lean_ctor_set(x_92, 5, x_86); +lean_ctor_set(x_95, 0, x_90); +lean_ctor_set(x_95, 1, x_91); +lean_ctor_set(x_95, 2, x_43); +lean_ctor_set(x_95, 3, x_92); +lean_ctor_set(x_95, 4, x_93); +x_96 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_96, 0, x_85); +lean_ctor_set(x_96, 1, x_86); +lean_ctor_set(x_96, 2, x_95); +lean_ctor_set(x_96, 3, x_87); +lean_ctor_set(x_96, 4, x_88); +lean_ctor_set(x_96, 5, x_89); if (lean_is_scalar(x_36)) { - x_93 = lean_alloc_ctor(0, 2, 0); + x_97 = lean_alloc_ctor(0, 2, 0); } else { - x_93 = x_36; + x_97 = x_36; } -lean_ctor_set(x_93, 0, x_71); -lean_ctor_set(x_93, 1, x_92); -return x_93; +lean_ctor_set(x_97, 0, x_73); +lean_ctor_set(x_97, 1, x_96); +return x_97; } } } } else { -lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; -x_122 = lean_ctor_get(x_41, 0); -x_123 = lean_ctor_get(x_41, 1); -x_124 = lean_ctor_get(x_41, 2); -x_125 = lean_ctor_get(x_41, 3); -lean_inc(x_125); -lean_inc(x_124); -lean_inc(x_123); -lean_inc(x_122); -lean_dec(x_41); -x_159 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_160 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_160, 0, x_122); -lean_ctor_set(x_160, 1, x_123); -lean_ctor_set(x_160, 2, x_159); -lean_ctor_set(x_160, 3, x_125); -lean_ctor_set(x_35, 2, x_160); -x_161 = lean_ctor_get(x_8, 0); -lean_inc(x_161); -x_162 = lean_ctor_get(x_8, 1); -lean_inc(x_162); -x_163 = lean_ctor_get(x_8, 2); -lean_inc(x_163); -x_164 = lean_ctor_get(x_8, 3); -lean_inc(x_164); -x_165 = lean_ctor_get(x_8, 4); -lean_inc(x_165); -if (lean_is_exclusive(x_8)) { - lean_ctor_release(x_8, 0); - lean_ctor_release(x_8, 1); - lean_ctor_release(x_8, 2); - lean_ctor_release(x_8, 3); - lean_ctor_release(x_8, 4); - x_166 = x_8; -} else { - lean_dec_ref(x_8); - x_166 = lean_box(0); -} -x_167 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_167, 0, x_37); -lean_ctor_set(x_167, 1, x_24); -x_168 = lean_array_push(x_163, x_167); -if (lean_is_scalar(x_166)) { - x_169 = lean_alloc_ctor(0, 5, 0); -} else { - x_169 = x_166; -} -lean_ctor_set(x_169, 0, x_161); -lean_ctor_set(x_169, 1, x_162); -lean_ctor_set(x_169, 2, x_168); -lean_ctor_set(x_169, 3, x_164); -lean_ctor_set(x_169, 4, x_165); -x_170 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_39, x_169, x_35); -if (lean_obj_tag(x_170) == 0) -{ -lean_object* x_171; lean_object* x_172; lean_object* x_173; -x_171 = lean_ctor_get(x_170, 0); -lean_inc(x_171); -x_172 = lean_ctor_get(x_170, 1); -lean_inc(x_172); -lean_dec(x_170); -x_173 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_173, 0, x_171); -x_126 = x_173; -x_127 = x_172; -goto block_158; -} -else -{ -lean_object* x_174; lean_object* x_175; lean_object* x_176; -x_174 = lean_ctor_get(x_170, 0); -lean_inc(x_174); -x_175 = lean_ctor_get(x_170, 1); -lean_inc(x_175); -lean_dec(x_170); -x_176 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_176, 0, x_174); -x_126 = x_176; -x_127 = x_175; -goto block_158; -} -block_158: -{ -if (lean_obj_tag(x_126) == 0) -{ -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; -x_128 = lean_ctor_get(x_127, 2); -lean_inc(x_128); -x_129 = lean_ctor_get(x_126, 0); -lean_inc(x_129); -lean_dec(x_126); -x_130 = lean_ctor_get(x_127, 0); +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_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; +x_126 = lean_ctor_get(x_41, 0); +x_127 = lean_ctor_get(x_41, 1); +x_128 = lean_ctor_get(x_41, 2); +x_129 = lean_ctor_get(x_41, 3); +x_130 = lean_ctor_get(x_41, 4); lean_inc(x_130); -x_131 = lean_ctor_get(x_127, 1); -lean_inc(x_131); -x_132 = lean_ctor_get(x_127, 3); -lean_inc(x_132); -x_133 = lean_ctor_get(x_127, 4); -lean_inc(x_133); -x_134 = lean_ctor_get(x_127, 5); -lean_inc(x_134); -if (lean_is_exclusive(x_127)) { - lean_ctor_release(x_127, 0); - lean_ctor_release(x_127, 1); - lean_ctor_release(x_127, 2); - lean_ctor_release(x_127, 3); - lean_ctor_release(x_127, 4); - lean_ctor_release(x_127, 5); - x_135 = x_127; -} else { - lean_dec_ref(x_127); - x_135 = lean_box(0); -} -x_136 = lean_ctor_get(x_128, 0); -lean_inc(x_136); -x_137 = lean_ctor_get(x_128, 1); -lean_inc(x_137); -x_138 = lean_ctor_get(x_128, 3); -lean_inc(x_138); -if (lean_is_exclusive(x_128)) { - lean_ctor_release(x_128, 0); - lean_ctor_release(x_128, 1); - lean_ctor_release(x_128, 2); - lean_ctor_release(x_128, 3); - x_139 = x_128; -} else { - lean_dec_ref(x_128); - x_139 = lean_box(0); -} -if (lean_is_scalar(x_139)) { - x_140 = lean_alloc_ctor(0, 4, 0); -} else { - x_140 = x_139; -} -lean_ctor_set(x_140, 0, x_136); -lean_ctor_set(x_140, 1, x_137); -lean_ctor_set(x_140, 2, x_124); -lean_ctor_set(x_140, 3, x_138); -if (lean_is_scalar(x_135)) { - x_141 = lean_alloc_ctor(0, 6, 0); -} else { - x_141 = x_135; -} -lean_ctor_set(x_141, 0, x_130); -lean_ctor_set(x_141, 1, x_131); -lean_ctor_set(x_141, 2, x_140); -lean_ctor_set(x_141, 3, x_132); -lean_ctor_set(x_141, 4, x_133); -lean_ctor_set(x_141, 5, x_134); -if (lean_is_scalar(x_36)) { - x_142 = lean_alloc_ctor(1, 2, 0); -} else { - x_142 = x_36; - lean_ctor_set_tag(x_142, 1); -} -lean_ctor_set(x_142, 0, x_129); -lean_ctor_set(x_142, 1, x_141); -return x_142; -} -else -{ -lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; 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; -x_143 = lean_ctor_get(x_127, 2); -lean_inc(x_143); -x_144 = lean_ctor_get(x_126, 0); -lean_inc(x_144); -lean_dec(x_126); -x_145 = lean_ctor_get(x_127, 0); -lean_inc(x_145); -x_146 = lean_ctor_get(x_127, 1); -lean_inc(x_146); -x_147 = lean_ctor_get(x_127, 3); -lean_inc(x_147); -x_148 = lean_ctor_get(x_127, 4); -lean_inc(x_148); -x_149 = lean_ctor_get(x_127, 5); -lean_inc(x_149); -if (lean_is_exclusive(x_127)) { - lean_ctor_release(x_127, 0); - lean_ctor_release(x_127, 1); - lean_ctor_release(x_127, 2); - lean_ctor_release(x_127, 3); - lean_ctor_release(x_127, 4); - lean_ctor_release(x_127, 5); - x_150 = x_127; -} else { - lean_dec_ref(x_127); - x_150 = lean_box(0); -} -x_151 = lean_ctor_get(x_143, 0); -lean_inc(x_151); -x_152 = lean_ctor_get(x_143, 1); -lean_inc(x_152); -x_153 = lean_ctor_get(x_143, 3); -lean_inc(x_153); -if (lean_is_exclusive(x_143)) { - lean_ctor_release(x_143, 0); - lean_ctor_release(x_143, 1); - lean_ctor_release(x_143, 2); - lean_ctor_release(x_143, 3); - x_154 = x_143; -} else { - lean_dec_ref(x_143); - x_154 = lean_box(0); -} -if (lean_is_scalar(x_154)) { - x_155 = lean_alloc_ctor(0, 4, 0); -} else { - x_155 = x_154; -} -lean_ctor_set(x_155, 0, x_151); -lean_ctor_set(x_155, 1, x_152); -lean_ctor_set(x_155, 2, x_124); -lean_ctor_set(x_155, 3, x_153); -if (lean_is_scalar(x_150)) { - x_156 = lean_alloc_ctor(0, 6, 0); -} else { - x_156 = x_150; -} -lean_ctor_set(x_156, 0, x_145); -lean_ctor_set(x_156, 1, x_146); -lean_ctor_set(x_156, 2, x_155); -lean_ctor_set(x_156, 3, x_147); -lean_ctor_set(x_156, 4, x_148); -lean_ctor_set(x_156, 5, x_149); -if (lean_is_scalar(x_36)) { - x_157 = lean_alloc_ctor(0, 2, 0); -} else { - x_157 = x_36; -} -lean_ctor_set(x_157, 0, x_144); -lean_ctor_set(x_157, 1, x_156); -return x_157; -} -} -} -} -else -{ -lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; 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_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; lean_object* x_231; lean_object* x_232; lean_object* x_233; -x_177 = lean_ctor_get(x_35, 2); -x_178 = lean_ctor_get(x_35, 0); -x_179 = lean_ctor_get(x_35, 1); -x_180 = lean_ctor_get(x_35, 3); -x_181 = lean_ctor_get(x_35, 4); -x_182 = lean_ctor_get(x_35, 5); -lean_inc(x_182); -lean_inc(x_181); -lean_inc(x_180); -lean_inc(x_177); -lean_inc(x_179); -lean_inc(x_178); -lean_dec(x_35); -x_183 = lean_ctor_get(x_177, 0); -lean_inc(x_183); -x_184 = lean_ctor_get(x_177, 1); -lean_inc(x_184); -x_185 = lean_ctor_get(x_177, 2); -lean_inc(x_185); -x_186 = lean_ctor_get(x_177, 3); -lean_inc(x_186); -if (lean_is_exclusive(x_177)) { - lean_ctor_release(x_177, 0); - lean_ctor_release(x_177, 1); - lean_ctor_release(x_177, 2); - lean_ctor_release(x_177, 3); - x_187 = x_177; -} else { - lean_dec_ref(x_177); - x_187 = lean_box(0); -} -x_221 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_187)) { - x_222 = lean_alloc_ctor(0, 4, 0); -} else { - x_222 = x_187; -} -lean_ctor_set(x_222, 0, x_183); -lean_ctor_set(x_222, 1, x_184); -lean_ctor_set(x_222, 2, x_221); -lean_ctor_set(x_222, 3, x_186); -x_223 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_223, 0, x_178); -lean_ctor_set(x_223, 1, x_179); -lean_ctor_set(x_223, 2, x_222); -lean_ctor_set(x_223, 3, x_180); -lean_ctor_set(x_223, 4, x_181); -lean_ctor_set(x_223, 5, x_182); -x_224 = lean_ctor_get(x_8, 0); -lean_inc(x_224); -x_225 = lean_ctor_get(x_8, 1); -lean_inc(x_225); -x_226 = lean_ctor_get(x_8, 2); -lean_inc(x_226); -x_227 = lean_ctor_get(x_8, 3); -lean_inc(x_227); -x_228 = lean_ctor_get(x_8, 4); -lean_inc(x_228); +lean_inc(x_129); +lean_inc(x_128); +lean_inc(x_127); +lean_inc(x_126); +lean_dec(x_41); +x_166 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_167 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_167, 0, x_126); +lean_ctor_set(x_167, 1, x_127); +lean_ctor_set(x_167, 2, x_166); +lean_ctor_set(x_167, 3, x_129); +lean_ctor_set(x_167, 4, x_130); +lean_ctor_set(x_35, 2, x_167); +x_168 = lean_ctor_get(x_8, 0); +lean_inc(x_168); +x_169 = lean_ctor_get(x_8, 1); +lean_inc(x_169); +x_170 = lean_ctor_get(x_8, 2); +lean_inc(x_170); +x_171 = lean_ctor_get(x_8, 3); +lean_inc(x_171); +x_172 = lean_ctor_get(x_8, 4); +lean_inc(x_172); if (lean_is_exclusive(x_8)) { lean_ctor_release(x_8, 0); lean_ctor_release(x_8, 1); lean_ctor_release(x_8, 2); lean_ctor_release(x_8, 3); lean_ctor_release(x_8, 4); - x_229 = x_8; + x_173 = x_8; } else { lean_dec_ref(x_8); - x_229 = lean_box(0); + x_173 = lean_box(0); } -x_230 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_230, 0, x_37); -lean_ctor_set(x_230, 1, x_24); -x_231 = lean_array_push(x_226, x_230); -if (lean_is_scalar(x_229)) { +x_174 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_174, 0, x_37); +lean_ctor_set(x_174, 1, x_24); +x_175 = lean_array_push(x_170, x_174); +if (lean_is_scalar(x_173)) { + x_176 = lean_alloc_ctor(0, 5, 0); +} else { + x_176 = x_173; +} +lean_ctor_set(x_176, 0, x_168); +lean_ctor_set(x_176, 1, x_169); +lean_ctor_set(x_176, 2, x_175); +lean_ctor_set(x_176, 3, x_171); +lean_ctor_set(x_176, 4, x_172); +x_177 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_39, x_176, x_35); +if (lean_obj_tag(x_177) == 0) +{ +lean_object* x_178; lean_object* x_179; lean_object* x_180; +x_178 = lean_ctor_get(x_177, 0); +lean_inc(x_178); +x_179 = lean_ctor_get(x_177, 1); +lean_inc(x_179); +lean_dec(x_177); +x_180 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_180, 0, x_178); +x_131 = x_180; +x_132 = x_179; +goto block_165; +} +else +{ +lean_object* x_181; lean_object* x_182; lean_object* x_183; +x_181 = lean_ctor_get(x_177, 0); +lean_inc(x_181); +x_182 = lean_ctor_get(x_177, 1); +lean_inc(x_182); +lean_dec(x_177); +x_183 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_183, 0, x_181); +x_131 = x_183; +x_132 = x_182; +goto block_165; +} +block_165: +{ +if (lean_obj_tag(x_131) == 0) +{ +lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; +x_133 = lean_ctor_get(x_132, 2); +lean_inc(x_133); +x_134 = lean_ctor_get(x_131, 0); +lean_inc(x_134); +lean_dec(x_131); +x_135 = lean_ctor_get(x_132, 0); +lean_inc(x_135); +x_136 = lean_ctor_get(x_132, 1); +lean_inc(x_136); +x_137 = lean_ctor_get(x_132, 3); +lean_inc(x_137); +x_138 = lean_ctor_get(x_132, 4); +lean_inc(x_138); +x_139 = lean_ctor_get(x_132, 5); +lean_inc(x_139); +if (lean_is_exclusive(x_132)) { + lean_ctor_release(x_132, 0); + lean_ctor_release(x_132, 1); + lean_ctor_release(x_132, 2); + lean_ctor_release(x_132, 3); + lean_ctor_release(x_132, 4); + lean_ctor_release(x_132, 5); + x_140 = x_132; +} else { + lean_dec_ref(x_132); + x_140 = lean_box(0); +} +x_141 = lean_ctor_get(x_133, 0); +lean_inc(x_141); +x_142 = lean_ctor_get(x_133, 1); +lean_inc(x_142); +x_143 = lean_ctor_get(x_133, 3); +lean_inc(x_143); +x_144 = lean_ctor_get(x_133, 4); +lean_inc(x_144); +if (lean_is_exclusive(x_133)) { + lean_ctor_release(x_133, 0); + lean_ctor_release(x_133, 1); + lean_ctor_release(x_133, 2); + lean_ctor_release(x_133, 3); + lean_ctor_release(x_133, 4); + x_145 = x_133; +} else { + lean_dec_ref(x_133); + x_145 = lean_box(0); +} +if (lean_is_scalar(x_145)) { + x_146 = lean_alloc_ctor(0, 5, 0); +} else { + x_146 = x_145; +} +lean_ctor_set(x_146, 0, x_141); +lean_ctor_set(x_146, 1, x_142); +lean_ctor_set(x_146, 2, x_128); +lean_ctor_set(x_146, 3, x_143); +lean_ctor_set(x_146, 4, x_144); +if (lean_is_scalar(x_140)) { + x_147 = lean_alloc_ctor(0, 6, 0); +} else { + x_147 = x_140; +} +lean_ctor_set(x_147, 0, x_135); +lean_ctor_set(x_147, 1, x_136); +lean_ctor_set(x_147, 2, x_146); +lean_ctor_set(x_147, 3, x_137); +lean_ctor_set(x_147, 4, x_138); +lean_ctor_set(x_147, 5, x_139); +if (lean_is_scalar(x_36)) { + x_148 = lean_alloc_ctor(1, 2, 0); +} else { + x_148 = x_36; + lean_ctor_set_tag(x_148, 1); +} +lean_ctor_set(x_148, 0, x_134); +lean_ctor_set(x_148, 1, x_147); +return x_148; +} +else +{ +lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; +x_149 = lean_ctor_get(x_132, 2); +lean_inc(x_149); +x_150 = lean_ctor_get(x_131, 0); +lean_inc(x_150); +lean_dec(x_131); +x_151 = lean_ctor_get(x_132, 0); +lean_inc(x_151); +x_152 = lean_ctor_get(x_132, 1); +lean_inc(x_152); +x_153 = lean_ctor_get(x_132, 3); +lean_inc(x_153); +x_154 = lean_ctor_get(x_132, 4); +lean_inc(x_154); +x_155 = lean_ctor_get(x_132, 5); +lean_inc(x_155); +if (lean_is_exclusive(x_132)) { + lean_ctor_release(x_132, 0); + lean_ctor_release(x_132, 1); + lean_ctor_release(x_132, 2); + lean_ctor_release(x_132, 3); + lean_ctor_release(x_132, 4); + lean_ctor_release(x_132, 5); + x_156 = x_132; +} else { + lean_dec_ref(x_132); + x_156 = lean_box(0); +} +x_157 = lean_ctor_get(x_149, 0); +lean_inc(x_157); +x_158 = lean_ctor_get(x_149, 1); +lean_inc(x_158); +x_159 = lean_ctor_get(x_149, 3); +lean_inc(x_159); +x_160 = lean_ctor_get(x_149, 4); +lean_inc(x_160); +if (lean_is_exclusive(x_149)) { + lean_ctor_release(x_149, 0); + lean_ctor_release(x_149, 1); + lean_ctor_release(x_149, 2); + lean_ctor_release(x_149, 3); + lean_ctor_release(x_149, 4); + x_161 = x_149; +} else { + lean_dec_ref(x_149); + x_161 = lean_box(0); +} +if (lean_is_scalar(x_161)) { + x_162 = lean_alloc_ctor(0, 5, 0); +} else { + x_162 = x_161; +} +lean_ctor_set(x_162, 0, x_157); +lean_ctor_set(x_162, 1, x_158); +lean_ctor_set(x_162, 2, x_128); +lean_ctor_set(x_162, 3, x_159); +lean_ctor_set(x_162, 4, x_160); +if (lean_is_scalar(x_156)) { + x_163 = lean_alloc_ctor(0, 6, 0); +} else { + x_163 = x_156; +} +lean_ctor_set(x_163, 0, x_151); +lean_ctor_set(x_163, 1, x_152); +lean_ctor_set(x_163, 2, x_162); +lean_ctor_set(x_163, 3, x_153); +lean_ctor_set(x_163, 4, x_154); +lean_ctor_set(x_163, 5, x_155); +if (lean_is_scalar(x_36)) { + x_164 = lean_alloc_ctor(0, 2, 0); +} else { + x_164 = x_36; +} +lean_ctor_set(x_164, 0, x_150); +lean_ctor_set(x_164, 1, x_163); +return x_164; +} +} +} +} +else +{ +lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_231; lean_object* x_232; lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_object* x_236; lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; lean_object* x_242; lean_object* x_243; +x_184 = lean_ctor_get(x_35, 2); +x_185 = lean_ctor_get(x_35, 0); +x_186 = lean_ctor_get(x_35, 1); +x_187 = lean_ctor_get(x_35, 3); +x_188 = lean_ctor_get(x_35, 4); +x_189 = lean_ctor_get(x_35, 5); +lean_inc(x_189); +lean_inc(x_188); +lean_inc(x_187); +lean_inc(x_184); +lean_inc(x_186); +lean_inc(x_185); +lean_dec(x_35); +x_190 = lean_ctor_get(x_184, 0); +lean_inc(x_190); +x_191 = lean_ctor_get(x_184, 1); +lean_inc(x_191); +x_192 = lean_ctor_get(x_184, 2); +lean_inc(x_192); +x_193 = lean_ctor_get(x_184, 3); +lean_inc(x_193); +x_194 = lean_ctor_get(x_184, 4); +lean_inc(x_194); +if (lean_is_exclusive(x_184)) { + lean_ctor_release(x_184, 0); + lean_ctor_release(x_184, 1); + lean_ctor_release(x_184, 2); + lean_ctor_release(x_184, 3); + lean_ctor_release(x_184, 4); + x_195 = x_184; +} else { + lean_dec_ref(x_184); + x_195 = lean_box(0); +} +x_231 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_195)) { x_232 = lean_alloc_ctor(0, 5, 0); } else { - x_232 = x_229; + x_232 = x_195; } -lean_ctor_set(x_232, 0, x_224); -lean_ctor_set(x_232, 1, x_225); +lean_ctor_set(x_232, 0, x_190); +lean_ctor_set(x_232, 1, x_191); lean_ctor_set(x_232, 2, x_231); -lean_ctor_set(x_232, 3, x_227); -lean_ctor_set(x_232, 4, x_228); -x_233 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_39, x_232, x_223); -if (lean_obj_tag(x_233) == 0) -{ -lean_object* x_234; lean_object* x_235; lean_object* x_236; -x_234 = lean_ctor_get(x_233, 0); +lean_ctor_set(x_232, 3, x_193); +lean_ctor_set(x_232, 4, x_194); +x_233 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_233, 0, x_185); +lean_ctor_set(x_233, 1, x_186); +lean_ctor_set(x_233, 2, x_232); +lean_ctor_set(x_233, 3, x_187); +lean_ctor_set(x_233, 4, x_188); +lean_ctor_set(x_233, 5, x_189); +x_234 = lean_ctor_get(x_8, 0); lean_inc(x_234); -x_235 = lean_ctor_get(x_233, 1); +x_235 = lean_ctor_get(x_8, 1); lean_inc(x_235); -lean_dec(x_233); -x_236 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_236, 0, x_234); -x_188 = x_236; -x_189 = x_235; -goto block_220; -} -else -{ -lean_object* x_237; lean_object* x_238; lean_object* x_239; -x_237 = lean_ctor_get(x_233, 0); +x_236 = lean_ctor_get(x_8, 2); +lean_inc(x_236); +x_237 = lean_ctor_get(x_8, 3); lean_inc(x_237); -x_238 = lean_ctor_get(x_233, 1); +x_238 = lean_ctor_get(x_8, 4); lean_inc(x_238); -lean_dec(x_233); -x_239 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_239, 0, x_237); -x_188 = x_239; -x_189 = x_238; -goto block_220; +if (lean_is_exclusive(x_8)) { + lean_ctor_release(x_8, 0); + lean_ctor_release(x_8, 1); + lean_ctor_release(x_8, 2); + lean_ctor_release(x_8, 3); + lean_ctor_release(x_8, 4); + x_239 = x_8; +} else { + lean_dec_ref(x_8); + x_239 = lean_box(0); } -block_220: +x_240 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_240, 0, x_37); +lean_ctor_set(x_240, 1, x_24); +x_241 = lean_array_push(x_236, x_240); +if (lean_is_scalar(x_239)) { + x_242 = lean_alloc_ctor(0, 5, 0); +} else { + x_242 = x_239; +} +lean_ctor_set(x_242, 0, x_234); +lean_ctor_set(x_242, 1, x_235); +lean_ctor_set(x_242, 2, x_241); +lean_ctor_set(x_242, 3, x_237); +lean_ctor_set(x_242, 4, x_238); +x_243 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_39, x_242, x_233); +if (lean_obj_tag(x_243) == 0) { -if (lean_obj_tag(x_188) == 0) -{ -lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; -x_190 = lean_ctor_get(x_189, 2); -lean_inc(x_190); -x_191 = lean_ctor_get(x_188, 0); -lean_inc(x_191); -lean_dec(x_188); -x_192 = lean_ctor_get(x_189, 0); -lean_inc(x_192); -x_193 = lean_ctor_get(x_189, 1); -lean_inc(x_193); -x_194 = lean_ctor_get(x_189, 3); -lean_inc(x_194); -x_195 = lean_ctor_get(x_189, 4); -lean_inc(x_195); -x_196 = lean_ctor_get(x_189, 5); -lean_inc(x_196); -if (lean_is_exclusive(x_189)) { - lean_ctor_release(x_189, 0); - lean_ctor_release(x_189, 1); - lean_ctor_release(x_189, 2); - lean_ctor_release(x_189, 3); - lean_ctor_release(x_189, 4); - lean_ctor_release(x_189, 5); - x_197 = x_189; -} else { - lean_dec_ref(x_189); - x_197 = lean_box(0); -} -x_198 = lean_ctor_get(x_190, 0); -lean_inc(x_198); -x_199 = lean_ctor_get(x_190, 1); -lean_inc(x_199); -x_200 = lean_ctor_get(x_190, 3); -lean_inc(x_200); -if (lean_is_exclusive(x_190)) { - lean_ctor_release(x_190, 0); - lean_ctor_release(x_190, 1); - lean_ctor_release(x_190, 2); - lean_ctor_release(x_190, 3); - x_201 = x_190; -} else { - lean_dec_ref(x_190); - x_201 = lean_box(0); -} -if (lean_is_scalar(x_201)) { - x_202 = lean_alloc_ctor(0, 4, 0); -} else { - x_202 = x_201; -} -lean_ctor_set(x_202, 0, x_198); -lean_ctor_set(x_202, 1, x_199); -lean_ctor_set(x_202, 2, x_185); -lean_ctor_set(x_202, 3, x_200); -if (lean_is_scalar(x_197)) { - x_203 = lean_alloc_ctor(0, 6, 0); -} else { - x_203 = x_197; -} -lean_ctor_set(x_203, 0, x_192); -lean_ctor_set(x_203, 1, x_193); -lean_ctor_set(x_203, 2, x_202); -lean_ctor_set(x_203, 3, x_194); -lean_ctor_set(x_203, 4, x_195); -lean_ctor_set(x_203, 5, x_196); -if (lean_is_scalar(x_36)) { - x_204 = lean_alloc_ctor(1, 2, 0); -} else { - x_204 = x_36; - lean_ctor_set_tag(x_204, 1); -} -lean_ctor_set(x_204, 0, x_191); -lean_ctor_set(x_204, 1, x_203); -return x_204; +lean_object* x_244; lean_object* x_245; lean_object* x_246; +x_244 = lean_ctor_get(x_243, 0); +lean_inc(x_244); +x_245 = lean_ctor_get(x_243, 1); +lean_inc(x_245); +lean_dec(x_243); +x_246 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_246, 0, x_244); +x_196 = x_246; +x_197 = x_245; +goto block_230; } else { -lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; -x_205 = lean_ctor_get(x_189, 2); -lean_inc(x_205); -x_206 = lean_ctor_get(x_188, 0); +lean_object* x_247; lean_object* x_248; lean_object* x_249; +x_247 = lean_ctor_get(x_243, 0); +lean_inc(x_247); +x_248 = lean_ctor_get(x_243, 1); +lean_inc(x_248); +lean_dec(x_243); +x_249 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_249, 0, x_247); +x_196 = x_249; +x_197 = x_248; +goto block_230; +} +block_230: +{ +if (lean_obj_tag(x_196) == 0) +{ +lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; +x_198 = lean_ctor_get(x_197, 2); +lean_inc(x_198); +x_199 = lean_ctor_get(x_196, 0); +lean_inc(x_199); +lean_dec(x_196); +x_200 = lean_ctor_get(x_197, 0); +lean_inc(x_200); +x_201 = lean_ctor_get(x_197, 1); +lean_inc(x_201); +x_202 = lean_ctor_get(x_197, 3); +lean_inc(x_202); +x_203 = lean_ctor_get(x_197, 4); +lean_inc(x_203); +x_204 = lean_ctor_get(x_197, 5); +lean_inc(x_204); +if (lean_is_exclusive(x_197)) { + lean_ctor_release(x_197, 0); + lean_ctor_release(x_197, 1); + lean_ctor_release(x_197, 2); + lean_ctor_release(x_197, 3); + lean_ctor_release(x_197, 4); + lean_ctor_release(x_197, 5); + x_205 = x_197; +} else { + lean_dec_ref(x_197); + x_205 = lean_box(0); +} +x_206 = lean_ctor_get(x_198, 0); lean_inc(x_206); -lean_dec(x_188); -x_207 = lean_ctor_get(x_189, 0); +x_207 = lean_ctor_get(x_198, 1); lean_inc(x_207); -x_208 = lean_ctor_get(x_189, 1); +x_208 = lean_ctor_get(x_198, 3); lean_inc(x_208); -x_209 = lean_ctor_get(x_189, 3); +x_209 = lean_ctor_get(x_198, 4); lean_inc(x_209); -x_210 = lean_ctor_get(x_189, 4); -lean_inc(x_210); -x_211 = lean_ctor_get(x_189, 5); -lean_inc(x_211); -if (lean_is_exclusive(x_189)) { - lean_ctor_release(x_189, 0); - lean_ctor_release(x_189, 1); - lean_ctor_release(x_189, 2); - lean_ctor_release(x_189, 3); - lean_ctor_release(x_189, 4); - lean_ctor_release(x_189, 5); - x_212 = x_189; +if (lean_is_exclusive(x_198)) { + lean_ctor_release(x_198, 0); + lean_ctor_release(x_198, 1); + lean_ctor_release(x_198, 2); + lean_ctor_release(x_198, 3); + lean_ctor_release(x_198, 4); + x_210 = x_198; } else { - lean_dec_ref(x_189); - x_212 = lean_box(0); + lean_dec_ref(x_198); + x_210 = lean_box(0); } -x_213 = lean_ctor_get(x_205, 0); -lean_inc(x_213); -x_214 = lean_ctor_get(x_205, 1); -lean_inc(x_214); -x_215 = lean_ctor_get(x_205, 3); -lean_inc(x_215); -if (lean_is_exclusive(x_205)) { - lean_ctor_release(x_205, 0); - lean_ctor_release(x_205, 1); - lean_ctor_release(x_205, 2); - lean_ctor_release(x_205, 3); - x_216 = x_205; +if (lean_is_scalar(x_210)) { + x_211 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_205); - x_216 = lean_box(0); + x_211 = x_210; } -if (lean_is_scalar(x_216)) { - x_217 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_211, 0, x_206); +lean_ctor_set(x_211, 1, x_207); +lean_ctor_set(x_211, 2, x_192); +lean_ctor_set(x_211, 3, x_208); +lean_ctor_set(x_211, 4, x_209); +if (lean_is_scalar(x_205)) { + x_212 = lean_alloc_ctor(0, 6, 0); } else { - x_217 = x_216; + x_212 = x_205; } -lean_ctor_set(x_217, 0, x_213); -lean_ctor_set(x_217, 1, x_214); -lean_ctor_set(x_217, 2, x_185); -lean_ctor_set(x_217, 3, x_215); -if (lean_is_scalar(x_212)) { - x_218 = lean_alloc_ctor(0, 6, 0); -} else { - x_218 = x_212; -} -lean_ctor_set(x_218, 0, x_207); -lean_ctor_set(x_218, 1, x_208); -lean_ctor_set(x_218, 2, x_217); -lean_ctor_set(x_218, 3, x_209); -lean_ctor_set(x_218, 4, x_210); -lean_ctor_set(x_218, 5, x_211); +lean_ctor_set(x_212, 0, x_200); +lean_ctor_set(x_212, 1, x_201); +lean_ctor_set(x_212, 2, x_211); +lean_ctor_set(x_212, 3, x_202); +lean_ctor_set(x_212, 4, x_203); +lean_ctor_set(x_212, 5, x_204); if (lean_is_scalar(x_36)) { - x_219 = lean_alloc_ctor(0, 2, 0); + x_213 = lean_alloc_ctor(1, 2, 0); } else { - x_219 = x_36; + x_213 = x_36; + lean_ctor_set_tag(x_213, 1); } -lean_ctor_set(x_219, 0, x_206); -lean_ctor_set(x_219, 1, x_218); -return x_219; +lean_ctor_set(x_213, 0, x_199); +lean_ctor_set(x_213, 1, x_212); +return x_213; +} +else +{ +lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; 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; +x_214 = lean_ctor_get(x_197, 2); +lean_inc(x_214); +x_215 = lean_ctor_get(x_196, 0); +lean_inc(x_215); +lean_dec(x_196); +x_216 = lean_ctor_get(x_197, 0); +lean_inc(x_216); +x_217 = lean_ctor_get(x_197, 1); +lean_inc(x_217); +x_218 = lean_ctor_get(x_197, 3); +lean_inc(x_218); +x_219 = lean_ctor_get(x_197, 4); +lean_inc(x_219); +x_220 = lean_ctor_get(x_197, 5); +lean_inc(x_220); +if (lean_is_exclusive(x_197)) { + lean_ctor_release(x_197, 0); + lean_ctor_release(x_197, 1); + lean_ctor_release(x_197, 2); + lean_ctor_release(x_197, 3); + lean_ctor_release(x_197, 4); + lean_ctor_release(x_197, 5); + x_221 = x_197; +} else { + lean_dec_ref(x_197); + x_221 = lean_box(0); +} +x_222 = lean_ctor_get(x_214, 0); +lean_inc(x_222); +x_223 = lean_ctor_get(x_214, 1); +lean_inc(x_223); +x_224 = lean_ctor_get(x_214, 3); +lean_inc(x_224); +x_225 = lean_ctor_get(x_214, 4); +lean_inc(x_225); +if (lean_is_exclusive(x_214)) { + lean_ctor_release(x_214, 0); + lean_ctor_release(x_214, 1); + lean_ctor_release(x_214, 2); + lean_ctor_release(x_214, 3); + lean_ctor_release(x_214, 4); + x_226 = x_214; +} else { + lean_dec_ref(x_214); + x_226 = lean_box(0); +} +if (lean_is_scalar(x_226)) { + x_227 = lean_alloc_ctor(0, 5, 0); +} else { + x_227 = x_226; +} +lean_ctor_set(x_227, 0, x_222); +lean_ctor_set(x_227, 1, x_223); +lean_ctor_set(x_227, 2, x_192); +lean_ctor_set(x_227, 3, x_224); +lean_ctor_set(x_227, 4, x_225); +if (lean_is_scalar(x_221)) { + x_228 = lean_alloc_ctor(0, 6, 0); +} else { + x_228 = x_221; +} +lean_ctor_set(x_228, 0, x_216); +lean_ctor_set(x_228, 1, x_217); +lean_ctor_set(x_228, 2, x_227); +lean_ctor_set(x_228, 3, x_218); +lean_ctor_set(x_228, 4, x_219); +lean_ctor_set(x_228, 5, x_220); +if (lean_is_scalar(x_36)) { + x_229 = lean_alloc_ctor(0, 2, 0); +} else { + x_229 = x_36; +} +lean_ctor_set(x_229, 0, x_215); +lean_ctor_set(x_229, 1, x_228); +return x_229; } } } } default: { -lean_object* x_240; lean_object* x_241; -x_240 = lean_ctor_get(x_29, 1); -lean_inc(x_240); +lean_object* x_250; lean_object* x_251; +x_250 = lean_ctor_get(x_29, 1); +lean_inc(x_250); lean_dec(x_29); lean_inc(x_8); -x_241 = l_Lean_Meta_isClassExpensive___main(x_28, x_8, x_240); -if (lean_obj_tag(x_241) == 0) +x_251 = l_Lean_Meta_isClassExpensive___main(x_28, x_8, x_250); +if (lean_obj_tag(x_251) == 0) { -lean_object* x_242; -x_242 = lean_ctor_get(x_241, 0); -lean_inc(x_242); -if (lean_obj_tag(x_242) == 0) +lean_object* x_252; +x_252 = lean_ctor_get(x_251, 0); +lean_inc(x_252); +if (lean_obj_tag(x_252) == 0) { -lean_object* x_243; lean_object* x_244; lean_object* x_245; +lean_object* x_253; lean_object* x_254; lean_object* x_255; lean_dec(x_24); -x_243 = lean_ctor_get(x_241, 1); -lean_inc(x_243); -lean_dec(x_241); -x_244 = lean_unsigned_to_nat(1u); -x_245 = lean_nat_add(x_7, x_244); +x_253 = lean_ctor_get(x_251, 1); +lean_inc(x_253); +lean_dec(x_251); +x_254 = lean_unsigned_to_nat(1u); +x_255 = lean_nat_add(x_7, x_254); lean_dec(x_7); -x_7 = x_245; -x_9 = x_243; +x_7 = x_255; +x_9 = x_253; goto _start; } else { -lean_object* x_247; lean_object* x_248; lean_object* x_249; lean_object* x_250; lean_object* x_251; uint8_t x_252; -x_247 = lean_ctor_get(x_241, 1); -lean_inc(x_247); -if (lean_is_exclusive(x_241)) { - lean_ctor_release(x_241, 0); - lean_ctor_release(x_241, 1); - x_248 = x_241; +lean_object* x_257; lean_object* x_258; lean_object* x_259; lean_object* x_260; lean_object* x_261; uint8_t x_262; +x_257 = lean_ctor_get(x_251, 1); +lean_inc(x_257); +if (lean_is_exclusive(x_251)) { + lean_ctor_release(x_251, 0); + lean_ctor_release(x_251, 1); + x_258 = x_251; } else { - lean_dec_ref(x_241); - x_248 = lean_box(0); + lean_dec_ref(x_251); + x_258 = lean_box(0); } -x_249 = lean_ctor_get(x_242, 0); -lean_inc(x_249); -lean_dec(x_242); -x_250 = lean_unsigned_to_nat(1u); -x_251 = lean_nat_add(x_7, x_250); -lean_dec(x_7); -x_252 = !lean_is_exclusive(x_247); -if (x_252 == 0) -{ -lean_object* x_253; uint8_t x_254; -x_253 = lean_ctor_get(x_247, 2); -x_254 = !lean_is_exclusive(x_253); -if (x_254 == 0) -{ -lean_object* x_255; lean_object* x_256; lean_object* x_257; lean_object* x_307; uint8_t x_308; -x_255 = lean_ctor_get(x_253, 2); -x_307 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_253, 2, x_307); -x_308 = !lean_is_exclusive(x_8); -if (x_308 == 0) -{ -lean_object* x_309; lean_object* x_310; lean_object* x_311; lean_object* x_312; -x_309 = lean_ctor_get(x_8, 2); -x_310 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_310, 0, x_249); -lean_ctor_set(x_310, 1, x_24); -x_311 = lean_array_push(x_309, x_310); -lean_ctor_set(x_8, 2, x_311); -x_312 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_251, x_8, x_247); -if (lean_obj_tag(x_312) == 0) -{ -lean_object* x_313; lean_object* x_314; lean_object* x_315; -x_313 = lean_ctor_get(x_312, 0); -lean_inc(x_313); -x_314 = lean_ctor_get(x_312, 1); -lean_inc(x_314); -lean_dec(x_312); -x_315 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_315, 0, x_313); -x_256 = x_315; -x_257 = x_314; -goto block_306; -} -else -{ -lean_object* x_316; lean_object* x_317; lean_object* x_318; -x_316 = lean_ctor_get(x_312, 0); -lean_inc(x_316); -x_317 = lean_ctor_get(x_312, 1); -lean_inc(x_317); -lean_dec(x_312); -x_318 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_318, 0, x_316); -x_256 = x_318; -x_257 = x_317; -goto block_306; -} -} -else -{ -lean_object* x_319; lean_object* x_320; lean_object* x_321; lean_object* x_322; lean_object* x_323; lean_object* x_324; lean_object* x_325; lean_object* x_326; lean_object* x_327; -x_319 = lean_ctor_get(x_8, 0); -x_320 = lean_ctor_get(x_8, 1); -x_321 = lean_ctor_get(x_8, 2); -x_322 = lean_ctor_get(x_8, 3); -x_323 = lean_ctor_get(x_8, 4); -lean_inc(x_323); -lean_inc(x_322); -lean_inc(x_321); -lean_inc(x_320); -lean_inc(x_319); -lean_dec(x_8); -x_324 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_324, 0, x_249); -lean_ctor_set(x_324, 1, x_24); -x_325 = lean_array_push(x_321, x_324); -x_326 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_326, 0, x_319); -lean_ctor_set(x_326, 1, x_320); -lean_ctor_set(x_326, 2, x_325); -lean_ctor_set(x_326, 3, x_322); -lean_ctor_set(x_326, 4, x_323); -x_327 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_251, x_326, x_247); -if (lean_obj_tag(x_327) == 0) -{ -lean_object* x_328; lean_object* x_329; lean_object* x_330; -x_328 = lean_ctor_get(x_327, 0); -lean_inc(x_328); -x_329 = lean_ctor_get(x_327, 1); -lean_inc(x_329); -lean_dec(x_327); -x_330 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_330, 0, x_328); -x_256 = x_330; -x_257 = x_329; -goto block_306; -} -else -{ -lean_object* x_331; lean_object* x_332; lean_object* x_333; -x_331 = lean_ctor_get(x_327, 0); -lean_inc(x_331); -x_332 = lean_ctor_get(x_327, 1); -lean_inc(x_332); -lean_dec(x_327); -x_333 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_333, 0, x_331); -x_256 = x_333; -x_257 = x_332; -goto block_306; -} -} -block_306: -{ -if (lean_obj_tag(x_256) == 0) -{ -lean_object* x_258; lean_object* x_259; uint8_t x_260; -x_258 = lean_ctor_get(x_257, 2); -lean_inc(x_258); -x_259 = lean_ctor_get(x_256, 0); +x_259 = lean_ctor_get(x_252, 0); lean_inc(x_259); -lean_dec(x_256); -x_260 = !lean_is_exclusive(x_257); -if (x_260 == 0) -{ -lean_object* x_261; uint8_t x_262; -x_261 = lean_ctor_get(x_257, 2); -lean_dec(x_261); -x_262 = !lean_is_exclusive(x_258); +lean_dec(x_252); +x_260 = lean_unsigned_to_nat(1u); +x_261 = lean_nat_add(x_7, x_260); +lean_dec(x_7); +x_262 = !lean_is_exclusive(x_257); if (x_262 == 0) { -lean_object* x_263; lean_object* x_264; -x_263 = lean_ctor_get(x_258, 2); -lean_dec(x_263); -lean_ctor_set(x_258, 2, x_255); -if (lean_is_scalar(x_248)) { - x_264 = lean_alloc_ctor(1, 2, 0); -} else { - x_264 = x_248; - lean_ctor_set_tag(x_264, 1); -} -lean_ctor_set(x_264, 0, x_259); -lean_ctor_set(x_264, 1, x_257); -return x_264; +lean_object* x_263; uint8_t x_264; +x_263 = lean_ctor_get(x_257, 2); +x_264 = !lean_is_exclusive(x_263); +if (x_264 == 0) +{ +lean_object* x_265; lean_object* x_266; lean_object* x_267; lean_object* x_321; uint8_t x_322; +x_265 = lean_ctor_get(x_263, 2); +x_321 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_263, 2, x_321); +x_322 = !lean_is_exclusive(x_8); +if (x_322 == 0) +{ +lean_object* x_323; lean_object* x_324; lean_object* x_325; lean_object* x_326; +x_323 = lean_ctor_get(x_8, 2); +x_324 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_324, 0, x_259); +lean_ctor_set(x_324, 1, x_24); +x_325 = lean_array_push(x_323, x_324); +lean_ctor_set(x_8, 2, x_325); +x_326 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_261, x_8, x_257); +if (lean_obj_tag(x_326) == 0) +{ +lean_object* x_327; lean_object* x_328; lean_object* x_329; +x_327 = lean_ctor_get(x_326, 0); +lean_inc(x_327); +x_328 = lean_ctor_get(x_326, 1); +lean_inc(x_328); +lean_dec(x_326); +x_329 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_329, 0, x_327); +x_266 = x_329; +x_267 = x_328; +goto block_320; } else { -lean_object* x_265; lean_object* x_266; lean_object* x_267; lean_object* x_268; lean_object* x_269; -x_265 = lean_ctor_get(x_258, 0); -x_266 = lean_ctor_get(x_258, 1); -x_267 = lean_ctor_get(x_258, 3); -lean_inc(x_267); -lean_inc(x_266); -lean_inc(x_265); -lean_dec(x_258); -x_268 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_268, 0, x_265); -lean_ctor_set(x_268, 1, x_266); -lean_ctor_set(x_268, 2, x_255); -lean_ctor_set(x_268, 3, x_267); -lean_ctor_set(x_257, 2, x_268); -if (lean_is_scalar(x_248)) { - x_269 = lean_alloc_ctor(1, 2, 0); -} else { - x_269 = x_248; - lean_ctor_set_tag(x_269, 1); -} -lean_ctor_set(x_269, 0, x_259); -lean_ctor_set(x_269, 1, x_257); -return x_269; +lean_object* x_330; lean_object* x_331; lean_object* x_332; +x_330 = lean_ctor_get(x_326, 0); +lean_inc(x_330); +x_331 = lean_ctor_get(x_326, 1); +lean_inc(x_331); +lean_dec(x_326); +x_332 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_332, 0, x_330); +x_266 = x_332; +x_267 = x_331; +goto block_320; } } else { -lean_object* x_270; lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_object* x_276; lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; lean_object* x_281; -x_270 = lean_ctor_get(x_257, 0); -x_271 = lean_ctor_get(x_257, 1); -x_272 = lean_ctor_get(x_257, 3); -x_273 = lean_ctor_get(x_257, 4); -x_274 = lean_ctor_get(x_257, 5); -lean_inc(x_274); -lean_inc(x_273); -lean_inc(x_272); -lean_inc(x_271); -lean_inc(x_270); -lean_dec(x_257); -x_275 = lean_ctor_get(x_258, 0); -lean_inc(x_275); -x_276 = lean_ctor_get(x_258, 1); -lean_inc(x_276); -x_277 = lean_ctor_get(x_258, 3); +lean_object* x_333; lean_object* x_334; lean_object* x_335; lean_object* x_336; lean_object* x_337; lean_object* x_338; lean_object* x_339; lean_object* x_340; lean_object* x_341; +x_333 = lean_ctor_get(x_8, 0); +x_334 = lean_ctor_get(x_8, 1); +x_335 = lean_ctor_get(x_8, 2); +x_336 = lean_ctor_get(x_8, 3); +x_337 = lean_ctor_get(x_8, 4); +lean_inc(x_337); +lean_inc(x_336); +lean_inc(x_335); +lean_inc(x_334); +lean_inc(x_333); +lean_dec(x_8); +x_338 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_338, 0, x_259); +lean_ctor_set(x_338, 1, x_24); +x_339 = lean_array_push(x_335, x_338); +x_340 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_340, 0, x_333); +lean_ctor_set(x_340, 1, x_334); +lean_ctor_set(x_340, 2, x_339); +lean_ctor_set(x_340, 3, x_336); +lean_ctor_set(x_340, 4, x_337); +x_341 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_261, x_340, x_257); +if (lean_obj_tag(x_341) == 0) +{ +lean_object* x_342; lean_object* x_343; lean_object* x_344; +x_342 = lean_ctor_get(x_341, 0); +lean_inc(x_342); +x_343 = lean_ctor_get(x_341, 1); +lean_inc(x_343); +lean_dec(x_341); +x_344 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_344, 0, x_342); +x_266 = x_344; +x_267 = x_343; +goto block_320; +} +else +{ +lean_object* x_345; lean_object* x_346; lean_object* x_347; +x_345 = lean_ctor_get(x_341, 0); +lean_inc(x_345); +x_346 = lean_ctor_get(x_341, 1); +lean_inc(x_346); +lean_dec(x_341); +x_347 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_347, 0, x_345); +x_266 = x_347; +x_267 = x_346; +goto block_320; +} +} +block_320: +{ +if (lean_obj_tag(x_266) == 0) +{ +lean_object* x_268; lean_object* x_269; uint8_t x_270; +x_268 = lean_ctor_get(x_267, 2); +lean_inc(x_268); +x_269 = lean_ctor_get(x_266, 0); +lean_inc(x_269); +lean_dec(x_266); +x_270 = !lean_is_exclusive(x_267); +if (x_270 == 0) +{ +lean_object* x_271; uint8_t x_272; +x_271 = lean_ctor_get(x_267, 2); +lean_dec(x_271); +x_272 = !lean_is_exclusive(x_268); +if (x_272 == 0) +{ +lean_object* x_273; lean_object* x_274; +x_273 = lean_ctor_get(x_268, 2); +lean_dec(x_273); +lean_ctor_set(x_268, 2, x_265); +if (lean_is_scalar(x_258)) { + x_274 = lean_alloc_ctor(1, 2, 0); +} else { + x_274 = x_258; + lean_ctor_set_tag(x_274, 1); +} +lean_ctor_set(x_274, 0, x_269); +lean_ctor_set(x_274, 1, x_267); +return x_274; +} +else +{ +lean_object* x_275; lean_object* x_276; lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; +x_275 = lean_ctor_get(x_268, 0); +x_276 = lean_ctor_get(x_268, 1); +x_277 = lean_ctor_get(x_268, 3); +x_278 = lean_ctor_get(x_268, 4); +lean_inc(x_278); lean_inc(x_277); -if (lean_is_exclusive(x_258)) { - lean_ctor_release(x_258, 0); - lean_ctor_release(x_258, 1); - lean_ctor_release(x_258, 2); - lean_ctor_release(x_258, 3); - x_278 = x_258; -} else { - lean_dec_ref(x_258); - x_278 = lean_box(0); -} -if (lean_is_scalar(x_278)) { - x_279 = lean_alloc_ctor(0, 4, 0); -} else { - x_279 = x_278; -} +lean_inc(x_276); +lean_inc(x_275); +lean_dec(x_268); +x_279 = lean_alloc_ctor(0, 5, 0); lean_ctor_set(x_279, 0, x_275); lean_ctor_set(x_279, 1, x_276); -lean_ctor_set(x_279, 2, x_255); +lean_ctor_set(x_279, 2, x_265); lean_ctor_set(x_279, 3, x_277); -x_280 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_280, 0, x_270); -lean_ctor_set(x_280, 1, x_271); -lean_ctor_set(x_280, 2, x_279); -lean_ctor_set(x_280, 3, x_272); -lean_ctor_set(x_280, 4, x_273); -lean_ctor_set(x_280, 5, x_274); -if (lean_is_scalar(x_248)) { - x_281 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_279, 4, x_278); +lean_ctor_set(x_267, 2, x_279); +if (lean_is_scalar(x_258)) { + x_280 = lean_alloc_ctor(1, 2, 0); } else { - x_281 = x_248; - lean_ctor_set_tag(x_281, 1); + x_280 = x_258; + lean_ctor_set_tag(x_280, 1); } -lean_ctor_set(x_281, 0, x_259); -lean_ctor_set(x_281, 1, x_280); -return x_281; +lean_ctor_set(x_280, 0, x_269); +lean_ctor_set(x_280, 1, x_267); +return x_280; } } else { -lean_object* x_282; lean_object* x_283; uint8_t x_284; -x_282 = lean_ctor_get(x_257, 2); -lean_inc(x_282); -x_283 = lean_ctor_get(x_256, 0); +lean_object* x_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; lean_object* x_289; lean_object* x_290; lean_object* x_291; lean_object* x_292; lean_object* x_293; +x_281 = lean_ctor_get(x_267, 0); +x_282 = lean_ctor_get(x_267, 1); +x_283 = lean_ctor_get(x_267, 3); +x_284 = lean_ctor_get(x_267, 4); +x_285 = lean_ctor_get(x_267, 5); +lean_inc(x_285); +lean_inc(x_284); lean_inc(x_283); -lean_dec(x_256); -x_284 = !lean_is_exclusive(x_257); -if (x_284 == 0) -{ -lean_object* x_285; uint8_t x_286; -x_285 = lean_ctor_get(x_257, 2); -lean_dec(x_285); -x_286 = !lean_is_exclusive(x_282); -if (x_286 == 0) -{ -lean_object* x_287; lean_object* x_288; -x_287 = lean_ctor_get(x_282, 2); -lean_dec(x_287); -lean_ctor_set(x_282, 2, x_255); -if (lean_is_scalar(x_248)) { - x_288 = lean_alloc_ctor(0, 2, 0); -} else { - x_288 = x_248; -} -lean_ctor_set(x_288, 0, x_283); -lean_ctor_set(x_288, 1, x_257); -return x_288; -} -else -{ -lean_object* x_289; lean_object* x_290; lean_object* x_291; lean_object* x_292; lean_object* x_293; -x_289 = lean_ctor_get(x_282, 0); -x_290 = lean_ctor_get(x_282, 1); -x_291 = lean_ctor_get(x_282, 3); -lean_inc(x_291); -lean_inc(x_290); +lean_inc(x_282); +lean_inc(x_281); +lean_dec(x_267); +x_286 = lean_ctor_get(x_268, 0); +lean_inc(x_286); +x_287 = lean_ctor_get(x_268, 1); +lean_inc(x_287); +x_288 = lean_ctor_get(x_268, 3); +lean_inc(x_288); +x_289 = lean_ctor_get(x_268, 4); lean_inc(x_289); -lean_dec(x_282); -x_292 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_292, 0, x_289); -lean_ctor_set(x_292, 1, x_290); -lean_ctor_set(x_292, 2, x_255); -lean_ctor_set(x_292, 3, x_291); -lean_ctor_set(x_257, 2, x_292); -if (lean_is_scalar(x_248)) { - x_293 = lean_alloc_ctor(0, 2, 0); +if (lean_is_exclusive(x_268)) { + lean_ctor_release(x_268, 0); + lean_ctor_release(x_268, 1); + lean_ctor_release(x_268, 2); + lean_ctor_release(x_268, 3); + lean_ctor_release(x_268, 4); + x_290 = x_268; } else { - x_293 = x_248; + lean_dec_ref(x_268); + x_290 = lean_box(0); } -lean_ctor_set(x_293, 0, x_283); -lean_ctor_set(x_293, 1, x_257); +if (lean_is_scalar(x_290)) { + x_291 = lean_alloc_ctor(0, 5, 0); +} else { + x_291 = x_290; +} +lean_ctor_set(x_291, 0, x_286); +lean_ctor_set(x_291, 1, x_287); +lean_ctor_set(x_291, 2, x_265); +lean_ctor_set(x_291, 3, x_288); +lean_ctor_set(x_291, 4, x_289); +x_292 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_292, 0, x_281); +lean_ctor_set(x_292, 1, x_282); +lean_ctor_set(x_292, 2, x_291); +lean_ctor_set(x_292, 3, x_283); +lean_ctor_set(x_292, 4, x_284); +lean_ctor_set(x_292, 5, x_285); +if (lean_is_scalar(x_258)) { + x_293 = lean_alloc_ctor(1, 2, 0); +} else { + x_293 = x_258; + lean_ctor_set_tag(x_293, 1); +} +lean_ctor_set(x_293, 0, x_269); +lean_ctor_set(x_293, 1, x_292); return x_293; } } else { -lean_object* x_294; lean_object* x_295; lean_object* x_296; lean_object* x_297; lean_object* x_298; lean_object* x_299; lean_object* x_300; lean_object* x_301; lean_object* x_302; lean_object* x_303; lean_object* x_304; lean_object* x_305; -x_294 = lean_ctor_get(x_257, 0); -x_295 = lean_ctor_get(x_257, 1); -x_296 = lean_ctor_get(x_257, 3); -x_297 = lean_ctor_get(x_257, 4); -x_298 = lean_ctor_get(x_257, 5); -lean_inc(x_298); -lean_inc(x_297); -lean_inc(x_296); -lean_inc(x_295); +lean_object* x_294; lean_object* x_295; uint8_t x_296; +x_294 = lean_ctor_get(x_267, 2); lean_inc(x_294); -lean_dec(x_257); -x_299 = lean_ctor_get(x_282, 0); -lean_inc(x_299); -x_300 = lean_ctor_get(x_282, 1); -lean_inc(x_300); -x_301 = lean_ctor_get(x_282, 3); +x_295 = lean_ctor_get(x_266, 0); +lean_inc(x_295); +lean_dec(x_266); +x_296 = !lean_is_exclusive(x_267); +if (x_296 == 0) +{ +lean_object* x_297; uint8_t x_298; +x_297 = lean_ctor_get(x_267, 2); +lean_dec(x_297); +x_298 = !lean_is_exclusive(x_294); +if (x_298 == 0) +{ +lean_object* x_299; lean_object* x_300; +x_299 = lean_ctor_get(x_294, 2); +lean_dec(x_299); +lean_ctor_set(x_294, 2, x_265); +if (lean_is_scalar(x_258)) { + x_300 = lean_alloc_ctor(0, 2, 0); +} else { + x_300 = x_258; +} +lean_ctor_set(x_300, 0, x_295); +lean_ctor_set(x_300, 1, x_267); +return x_300; +} +else +{ +lean_object* x_301; lean_object* x_302; lean_object* x_303; lean_object* x_304; lean_object* x_305; lean_object* x_306; +x_301 = lean_ctor_get(x_294, 0); +x_302 = lean_ctor_get(x_294, 1); +x_303 = lean_ctor_get(x_294, 3); +x_304 = lean_ctor_get(x_294, 4); +lean_inc(x_304); +lean_inc(x_303); +lean_inc(x_302); lean_inc(x_301); -if (lean_is_exclusive(x_282)) { - lean_ctor_release(x_282, 0); - lean_ctor_release(x_282, 1); - lean_ctor_release(x_282, 2); - lean_ctor_release(x_282, 3); - x_302 = x_282; +lean_dec(x_294); +x_305 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_305, 0, x_301); +lean_ctor_set(x_305, 1, x_302); +lean_ctor_set(x_305, 2, x_265); +lean_ctor_set(x_305, 3, x_303); +lean_ctor_set(x_305, 4, x_304); +lean_ctor_set(x_267, 2, x_305); +if (lean_is_scalar(x_258)) { + x_306 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_282); - x_302 = lean_box(0); + x_306 = x_258; } -if (lean_is_scalar(x_302)) { - x_303 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_306, 0, x_295); +lean_ctor_set(x_306, 1, x_267); +return x_306; +} +} +else +{ +lean_object* x_307; lean_object* x_308; lean_object* x_309; lean_object* x_310; lean_object* x_311; lean_object* x_312; lean_object* x_313; lean_object* x_314; lean_object* x_315; lean_object* x_316; lean_object* x_317; lean_object* x_318; lean_object* x_319; +x_307 = lean_ctor_get(x_267, 0); +x_308 = lean_ctor_get(x_267, 1); +x_309 = lean_ctor_get(x_267, 3); +x_310 = lean_ctor_get(x_267, 4); +x_311 = lean_ctor_get(x_267, 5); +lean_inc(x_311); +lean_inc(x_310); +lean_inc(x_309); +lean_inc(x_308); +lean_inc(x_307); +lean_dec(x_267); +x_312 = lean_ctor_get(x_294, 0); +lean_inc(x_312); +x_313 = lean_ctor_get(x_294, 1); +lean_inc(x_313); +x_314 = lean_ctor_get(x_294, 3); +lean_inc(x_314); +x_315 = lean_ctor_get(x_294, 4); +lean_inc(x_315); +if (lean_is_exclusive(x_294)) { + lean_ctor_release(x_294, 0); + lean_ctor_release(x_294, 1); + lean_ctor_release(x_294, 2); + lean_ctor_release(x_294, 3); + lean_ctor_release(x_294, 4); + x_316 = x_294; } else { - x_303 = x_302; + lean_dec_ref(x_294); + x_316 = lean_box(0); } -lean_ctor_set(x_303, 0, x_299); -lean_ctor_set(x_303, 1, x_300); -lean_ctor_set(x_303, 2, x_255); -lean_ctor_set(x_303, 3, x_301); -x_304 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_304, 0, x_294); -lean_ctor_set(x_304, 1, x_295); -lean_ctor_set(x_304, 2, x_303); -lean_ctor_set(x_304, 3, x_296); -lean_ctor_set(x_304, 4, x_297); -lean_ctor_set(x_304, 5, x_298); -if (lean_is_scalar(x_248)) { - x_305 = lean_alloc_ctor(0, 2, 0); +if (lean_is_scalar(x_316)) { + x_317 = lean_alloc_ctor(0, 5, 0); } else { - x_305 = x_248; + x_317 = x_316; } -lean_ctor_set(x_305, 0, x_283); -lean_ctor_set(x_305, 1, x_304); -return x_305; +lean_ctor_set(x_317, 0, x_312); +lean_ctor_set(x_317, 1, x_313); +lean_ctor_set(x_317, 2, x_265); +lean_ctor_set(x_317, 3, x_314); +lean_ctor_set(x_317, 4, x_315); +x_318 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_318, 0, x_307); +lean_ctor_set(x_318, 1, x_308); +lean_ctor_set(x_318, 2, x_317); +lean_ctor_set(x_318, 3, x_309); +lean_ctor_set(x_318, 4, x_310); +lean_ctor_set(x_318, 5, x_311); +if (lean_is_scalar(x_258)) { + x_319 = lean_alloc_ctor(0, 2, 0); +} else { + x_319 = x_258; +} +lean_ctor_set(x_319, 0, x_295); +lean_ctor_set(x_319, 1, x_318); +return x_319; } } } } else { -lean_object* x_334; lean_object* x_335; lean_object* x_336; lean_object* x_337; lean_object* x_338; lean_object* x_339; lean_object* x_371; lean_object* x_372; lean_object* x_373; lean_object* x_374; lean_object* x_375; 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; -x_334 = lean_ctor_get(x_253, 0); -x_335 = lean_ctor_get(x_253, 1); -x_336 = lean_ctor_get(x_253, 2); -x_337 = lean_ctor_get(x_253, 3); -lean_inc(x_337); -lean_inc(x_336); -lean_inc(x_335); -lean_inc(x_334); -lean_dec(x_253); -x_371 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_372 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_372, 0, x_334); -lean_ctor_set(x_372, 1, x_335); -lean_ctor_set(x_372, 2, x_371); -lean_ctor_set(x_372, 3, x_337); -lean_ctor_set(x_247, 2, x_372); -x_373 = lean_ctor_get(x_8, 0); -lean_inc(x_373); -x_374 = lean_ctor_get(x_8, 1); -lean_inc(x_374); -x_375 = lean_ctor_get(x_8, 2); -lean_inc(x_375); -x_376 = lean_ctor_get(x_8, 3); -lean_inc(x_376); -x_377 = lean_ctor_get(x_8, 4); -lean_inc(x_377); +lean_object* x_348; lean_object* x_349; lean_object* x_350; lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_388; lean_object* x_389; lean_object* x_390; lean_object* x_391; lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; +x_348 = lean_ctor_get(x_263, 0); +x_349 = lean_ctor_get(x_263, 1); +x_350 = lean_ctor_get(x_263, 2); +x_351 = lean_ctor_get(x_263, 3); +x_352 = lean_ctor_get(x_263, 4); +lean_inc(x_352); +lean_inc(x_351); +lean_inc(x_350); +lean_inc(x_349); +lean_inc(x_348); +lean_dec(x_263); +x_388 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_389 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_389, 0, x_348); +lean_ctor_set(x_389, 1, x_349); +lean_ctor_set(x_389, 2, x_388); +lean_ctor_set(x_389, 3, x_351); +lean_ctor_set(x_389, 4, x_352); +lean_ctor_set(x_257, 2, x_389); +x_390 = lean_ctor_get(x_8, 0); +lean_inc(x_390); +x_391 = lean_ctor_get(x_8, 1); +lean_inc(x_391); +x_392 = lean_ctor_get(x_8, 2); +lean_inc(x_392); +x_393 = lean_ctor_get(x_8, 3); +lean_inc(x_393); +x_394 = lean_ctor_get(x_8, 4); +lean_inc(x_394); if (lean_is_exclusive(x_8)) { lean_ctor_release(x_8, 0); lean_ctor_release(x_8, 1); lean_ctor_release(x_8, 2); lean_ctor_release(x_8, 3); lean_ctor_release(x_8, 4); - x_378 = x_8; + x_395 = x_8; } else { lean_dec_ref(x_8); - x_378 = lean_box(0); + x_395 = lean_box(0); } -x_379 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_379, 0, x_249); -lean_ctor_set(x_379, 1, x_24); -x_380 = lean_array_push(x_375, x_379); -if (lean_is_scalar(x_378)) { - x_381 = lean_alloc_ctor(0, 5, 0); +x_396 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_396, 0, x_259); +lean_ctor_set(x_396, 1, x_24); +x_397 = lean_array_push(x_392, x_396); +if (lean_is_scalar(x_395)) { + x_398 = lean_alloc_ctor(0, 5, 0); } else { - x_381 = x_378; + x_398 = x_395; } -lean_ctor_set(x_381, 0, x_373); -lean_ctor_set(x_381, 1, x_374); -lean_ctor_set(x_381, 2, x_380); -lean_ctor_set(x_381, 3, x_376); -lean_ctor_set(x_381, 4, x_377); -x_382 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_251, x_381, x_247); -if (lean_obj_tag(x_382) == 0) +lean_ctor_set(x_398, 0, x_390); +lean_ctor_set(x_398, 1, x_391); +lean_ctor_set(x_398, 2, x_397); +lean_ctor_set(x_398, 3, x_393); +lean_ctor_set(x_398, 4, x_394); +x_399 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_261, x_398, x_257); +if (lean_obj_tag(x_399) == 0) { -lean_object* x_383; lean_object* x_384; lean_object* x_385; -x_383 = lean_ctor_get(x_382, 0); -lean_inc(x_383); -x_384 = lean_ctor_get(x_382, 1); -lean_inc(x_384); -lean_dec(x_382); -x_385 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_385, 0, x_383); -x_338 = x_385; -x_339 = x_384; -goto block_370; +lean_object* x_400; lean_object* x_401; lean_object* x_402; +x_400 = lean_ctor_get(x_399, 0); +lean_inc(x_400); +x_401 = lean_ctor_get(x_399, 1); +lean_inc(x_401); +lean_dec(x_399); +x_402 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_402, 0, x_400); +x_353 = x_402; +x_354 = x_401; +goto block_387; } else { -lean_object* x_386; lean_object* x_387; lean_object* x_388; -x_386 = lean_ctor_get(x_382, 0); -lean_inc(x_386); -x_387 = lean_ctor_get(x_382, 1); -lean_inc(x_387); -lean_dec(x_382); -x_388 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_388, 0, x_386); -x_338 = x_388; -x_339 = x_387; -goto block_370; +lean_object* x_403; lean_object* x_404; lean_object* x_405; +x_403 = lean_ctor_get(x_399, 0); +lean_inc(x_403); +x_404 = lean_ctor_get(x_399, 1); +lean_inc(x_404); +lean_dec(x_399); +x_405 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_405, 0, x_403); +x_353 = x_405; +x_354 = x_404; +goto block_387; } -block_370: +block_387: { -if (lean_obj_tag(x_338) == 0) +if (lean_obj_tag(x_353) == 0) { -lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; lean_object* x_350; lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; -x_340 = lean_ctor_get(x_339, 2); -lean_inc(x_340); -x_341 = lean_ctor_get(x_338, 0); -lean_inc(x_341); -lean_dec(x_338); -x_342 = lean_ctor_get(x_339, 0); -lean_inc(x_342); -x_343 = lean_ctor_get(x_339, 1); -lean_inc(x_343); -x_344 = lean_ctor_get(x_339, 3); -lean_inc(x_344); -x_345 = lean_ctor_get(x_339, 4); -lean_inc(x_345); -x_346 = lean_ctor_get(x_339, 5); -lean_inc(x_346); -if (lean_is_exclusive(x_339)) { - lean_ctor_release(x_339, 0); - lean_ctor_release(x_339, 1); - lean_ctor_release(x_339, 2); - lean_ctor_release(x_339, 3); - lean_ctor_release(x_339, 4); - lean_ctor_release(x_339, 5); - x_347 = x_339; -} else { - lean_dec_ref(x_339); - x_347 = lean_box(0); -} -x_348 = lean_ctor_get(x_340, 0); -lean_inc(x_348); -x_349 = lean_ctor_get(x_340, 1); -lean_inc(x_349); -x_350 = lean_ctor_get(x_340, 3); -lean_inc(x_350); -if (lean_is_exclusive(x_340)) { - lean_ctor_release(x_340, 0); - lean_ctor_release(x_340, 1); - lean_ctor_release(x_340, 2); - lean_ctor_release(x_340, 3); - x_351 = x_340; -} else { - lean_dec_ref(x_340); - x_351 = lean_box(0); -} -if (lean_is_scalar(x_351)) { - x_352 = lean_alloc_ctor(0, 4, 0); -} else { - x_352 = x_351; -} -lean_ctor_set(x_352, 0, x_348); -lean_ctor_set(x_352, 1, x_349); -lean_ctor_set(x_352, 2, x_336); -lean_ctor_set(x_352, 3, x_350); -if (lean_is_scalar(x_347)) { - x_353 = lean_alloc_ctor(0, 6, 0); -} else { - x_353 = x_347; -} -lean_ctor_set(x_353, 0, x_342); -lean_ctor_set(x_353, 1, x_343); -lean_ctor_set(x_353, 2, x_352); -lean_ctor_set(x_353, 3, x_344); -lean_ctor_set(x_353, 4, x_345); -lean_ctor_set(x_353, 5, x_346); -if (lean_is_scalar(x_248)) { - x_354 = lean_alloc_ctor(1, 2, 0); -} else { - x_354 = x_248; - lean_ctor_set_tag(x_354, 1); -} -lean_ctor_set(x_354, 0, x_341); -lean_ctor_set(x_354, 1, x_353); -return x_354; -} -else -{ -lean_object* x_355; lean_object* x_356; lean_object* x_357; 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; -x_355 = lean_ctor_get(x_339, 2); +lean_object* x_355; lean_object* x_356; lean_object* x_357; 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; +x_355 = lean_ctor_get(x_354, 2); lean_inc(x_355); -x_356 = lean_ctor_get(x_338, 0); +x_356 = lean_ctor_get(x_353, 0); lean_inc(x_356); -lean_dec(x_338); -x_357 = lean_ctor_get(x_339, 0); +lean_dec(x_353); +x_357 = lean_ctor_get(x_354, 0); lean_inc(x_357); -x_358 = lean_ctor_get(x_339, 1); +x_358 = lean_ctor_get(x_354, 1); lean_inc(x_358); -x_359 = lean_ctor_get(x_339, 3); +x_359 = lean_ctor_get(x_354, 3); lean_inc(x_359); -x_360 = lean_ctor_get(x_339, 4); +x_360 = lean_ctor_get(x_354, 4); lean_inc(x_360); -x_361 = lean_ctor_get(x_339, 5); +x_361 = lean_ctor_get(x_354, 5); lean_inc(x_361); -if (lean_is_exclusive(x_339)) { - lean_ctor_release(x_339, 0); - lean_ctor_release(x_339, 1); - lean_ctor_release(x_339, 2); - lean_ctor_release(x_339, 3); - lean_ctor_release(x_339, 4); - lean_ctor_release(x_339, 5); - x_362 = x_339; +if (lean_is_exclusive(x_354)) { + lean_ctor_release(x_354, 0); + lean_ctor_release(x_354, 1); + lean_ctor_release(x_354, 2); + lean_ctor_release(x_354, 3); + lean_ctor_release(x_354, 4); + lean_ctor_release(x_354, 5); + x_362 = x_354; } else { - lean_dec_ref(x_339); + lean_dec_ref(x_354); x_362 = lean_box(0); } x_363 = lean_ctor_get(x_355, 0); @@ -11432,315 +11484,411 @@ x_364 = lean_ctor_get(x_355, 1); lean_inc(x_364); x_365 = lean_ctor_get(x_355, 3); lean_inc(x_365); +x_366 = lean_ctor_get(x_355, 4); +lean_inc(x_366); if (lean_is_exclusive(x_355)) { lean_ctor_release(x_355, 0); lean_ctor_release(x_355, 1); lean_ctor_release(x_355, 2); lean_ctor_release(x_355, 3); - x_366 = x_355; + lean_ctor_release(x_355, 4); + x_367 = x_355; } else { lean_dec_ref(x_355); - x_366 = lean_box(0); + x_367 = lean_box(0); } -if (lean_is_scalar(x_366)) { - x_367 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_367)) { + x_368 = lean_alloc_ctor(0, 5, 0); } else { - x_367 = x_366; + x_368 = x_367; } -lean_ctor_set(x_367, 0, x_363); -lean_ctor_set(x_367, 1, x_364); -lean_ctor_set(x_367, 2, x_336); -lean_ctor_set(x_367, 3, x_365); +lean_ctor_set(x_368, 0, x_363); +lean_ctor_set(x_368, 1, x_364); +lean_ctor_set(x_368, 2, x_350); +lean_ctor_set(x_368, 3, x_365); +lean_ctor_set(x_368, 4, x_366); if (lean_is_scalar(x_362)) { - x_368 = lean_alloc_ctor(0, 6, 0); + x_369 = lean_alloc_ctor(0, 6, 0); } else { - x_368 = x_362; + x_369 = x_362; } -lean_ctor_set(x_368, 0, x_357); -lean_ctor_set(x_368, 1, x_358); -lean_ctor_set(x_368, 2, x_367); -lean_ctor_set(x_368, 3, x_359); -lean_ctor_set(x_368, 4, x_360); -lean_ctor_set(x_368, 5, x_361); -if (lean_is_scalar(x_248)) { - x_369 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_369, 0, x_357); +lean_ctor_set(x_369, 1, x_358); +lean_ctor_set(x_369, 2, x_368); +lean_ctor_set(x_369, 3, x_359); +lean_ctor_set(x_369, 4, x_360); +lean_ctor_set(x_369, 5, x_361); +if (lean_is_scalar(x_258)) { + x_370 = lean_alloc_ctor(1, 2, 0); } else { - x_369 = x_248; + x_370 = x_258; + lean_ctor_set_tag(x_370, 1); } -lean_ctor_set(x_369, 0, x_356); -lean_ctor_set(x_369, 1, x_368); -return x_369; +lean_ctor_set(x_370, 0, x_356); +lean_ctor_set(x_370, 1, x_369); +return x_370; +} +else +{ +lean_object* x_371; lean_object* x_372; lean_object* x_373; lean_object* x_374; lean_object* x_375; 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; +x_371 = lean_ctor_get(x_354, 2); +lean_inc(x_371); +x_372 = lean_ctor_get(x_353, 0); +lean_inc(x_372); +lean_dec(x_353); +x_373 = lean_ctor_get(x_354, 0); +lean_inc(x_373); +x_374 = lean_ctor_get(x_354, 1); +lean_inc(x_374); +x_375 = lean_ctor_get(x_354, 3); +lean_inc(x_375); +x_376 = lean_ctor_get(x_354, 4); +lean_inc(x_376); +x_377 = lean_ctor_get(x_354, 5); +lean_inc(x_377); +if (lean_is_exclusive(x_354)) { + lean_ctor_release(x_354, 0); + lean_ctor_release(x_354, 1); + lean_ctor_release(x_354, 2); + lean_ctor_release(x_354, 3); + lean_ctor_release(x_354, 4); + lean_ctor_release(x_354, 5); + x_378 = x_354; +} else { + lean_dec_ref(x_354); + x_378 = lean_box(0); +} +x_379 = lean_ctor_get(x_371, 0); +lean_inc(x_379); +x_380 = lean_ctor_get(x_371, 1); +lean_inc(x_380); +x_381 = lean_ctor_get(x_371, 3); +lean_inc(x_381); +x_382 = lean_ctor_get(x_371, 4); +lean_inc(x_382); +if (lean_is_exclusive(x_371)) { + lean_ctor_release(x_371, 0); + lean_ctor_release(x_371, 1); + lean_ctor_release(x_371, 2); + lean_ctor_release(x_371, 3); + lean_ctor_release(x_371, 4); + x_383 = x_371; +} else { + lean_dec_ref(x_371); + x_383 = lean_box(0); +} +if (lean_is_scalar(x_383)) { + x_384 = lean_alloc_ctor(0, 5, 0); +} else { + x_384 = x_383; +} +lean_ctor_set(x_384, 0, x_379); +lean_ctor_set(x_384, 1, x_380); +lean_ctor_set(x_384, 2, x_350); +lean_ctor_set(x_384, 3, x_381); +lean_ctor_set(x_384, 4, x_382); +if (lean_is_scalar(x_378)) { + x_385 = lean_alloc_ctor(0, 6, 0); +} else { + x_385 = x_378; +} +lean_ctor_set(x_385, 0, x_373); +lean_ctor_set(x_385, 1, x_374); +lean_ctor_set(x_385, 2, x_384); +lean_ctor_set(x_385, 3, x_375); +lean_ctor_set(x_385, 4, x_376); +lean_ctor_set(x_385, 5, x_377); +if (lean_is_scalar(x_258)) { + x_386 = lean_alloc_ctor(0, 2, 0); +} else { + x_386 = x_258; +} +lean_ctor_set(x_386, 0, x_372); +lean_ctor_set(x_386, 1, x_385); +return x_386; } } } } else { -lean_object* x_389; lean_object* x_390; lean_object* x_391; lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; lean_object* x_400; lean_object* x_401; 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; lean_object* x_445; -x_389 = lean_ctor_get(x_247, 2); -x_390 = lean_ctor_get(x_247, 0); -x_391 = lean_ctor_get(x_247, 1); -x_392 = lean_ctor_get(x_247, 3); -x_393 = lean_ctor_get(x_247, 4); -x_394 = lean_ctor_get(x_247, 5); -lean_inc(x_394); -lean_inc(x_393); -lean_inc(x_392); -lean_inc(x_389); -lean_inc(x_391); -lean_inc(x_390); -lean_dec(x_247); -x_395 = lean_ctor_get(x_389, 0); -lean_inc(x_395); -x_396 = lean_ctor_get(x_389, 1); -lean_inc(x_396); -x_397 = lean_ctor_get(x_389, 2); -lean_inc(x_397); -x_398 = lean_ctor_get(x_389, 3); -lean_inc(x_398); -if (lean_is_exclusive(x_389)) { - lean_ctor_release(x_389, 0); - lean_ctor_release(x_389, 1); - lean_ctor_release(x_389, 2); - lean_ctor_release(x_389, 3); - x_399 = x_389; +lean_object* x_406; lean_object* x_407; lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_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_453; lean_object* x_454; lean_object* x_455; lean_object* x_456; lean_object* x_457; lean_object* x_458; lean_object* x_459; lean_object* x_460; lean_object* x_461; lean_object* x_462; lean_object* x_463; lean_object* x_464; lean_object* x_465; +x_406 = lean_ctor_get(x_257, 2); +x_407 = lean_ctor_get(x_257, 0); +x_408 = lean_ctor_get(x_257, 1); +x_409 = lean_ctor_get(x_257, 3); +x_410 = lean_ctor_get(x_257, 4); +x_411 = lean_ctor_get(x_257, 5); +lean_inc(x_411); +lean_inc(x_410); +lean_inc(x_409); +lean_inc(x_406); +lean_inc(x_408); +lean_inc(x_407); +lean_dec(x_257); +x_412 = lean_ctor_get(x_406, 0); +lean_inc(x_412); +x_413 = lean_ctor_get(x_406, 1); +lean_inc(x_413); +x_414 = lean_ctor_get(x_406, 2); +lean_inc(x_414); +x_415 = lean_ctor_get(x_406, 3); +lean_inc(x_415); +x_416 = lean_ctor_get(x_406, 4); +lean_inc(x_416); +if (lean_is_exclusive(x_406)) { + lean_ctor_release(x_406, 0); + lean_ctor_release(x_406, 1); + lean_ctor_release(x_406, 2); + lean_ctor_release(x_406, 3); + lean_ctor_release(x_406, 4); + x_417 = x_406; } else { - lean_dec_ref(x_389); - x_399 = lean_box(0); + lean_dec_ref(x_406); + x_417 = lean_box(0); } -x_433 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_399)) { - x_434 = lean_alloc_ctor(0, 4, 0); +x_453 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_417)) { + x_454 = lean_alloc_ctor(0, 5, 0); } else { - x_434 = x_399; + x_454 = x_417; } -lean_ctor_set(x_434, 0, x_395); -lean_ctor_set(x_434, 1, x_396); -lean_ctor_set(x_434, 2, x_433); -lean_ctor_set(x_434, 3, x_398); -x_435 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_435, 0, x_390); -lean_ctor_set(x_435, 1, x_391); -lean_ctor_set(x_435, 2, x_434); -lean_ctor_set(x_435, 3, x_392); -lean_ctor_set(x_435, 4, x_393); -lean_ctor_set(x_435, 5, x_394); -x_436 = lean_ctor_get(x_8, 0); -lean_inc(x_436); -x_437 = lean_ctor_get(x_8, 1); -lean_inc(x_437); -x_438 = lean_ctor_get(x_8, 2); -lean_inc(x_438); -x_439 = lean_ctor_get(x_8, 3); -lean_inc(x_439); -x_440 = lean_ctor_get(x_8, 4); -lean_inc(x_440); +lean_ctor_set(x_454, 0, x_412); +lean_ctor_set(x_454, 1, x_413); +lean_ctor_set(x_454, 2, x_453); +lean_ctor_set(x_454, 3, x_415); +lean_ctor_set(x_454, 4, x_416); +x_455 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_455, 0, x_407); +lean_ctor_set(x_455, 1, x_408); +lean_ctor_set(x_455, 2, x_454); +lean_ctor_set(x_455, 3, x_409); +lean_ctor_set(x_455, 4, x_410); +lean_ctor_set(x_455, 5, x_411); +x_456 = lean_ctor_get(x_8, 0); +lean_inc(x_456); +x_457 = lean_ctor_get(x_8, 1); +lean_inc(x_457); +x_458 = lean_ctor_get(x_8, 2); +lean_inc(x_458); +x_459 = lean_ctor_get(x_8, 3); +lean_inc(x_459); +x_460 = lean_ctor_get(x_8, 4); +lean_inc(x_460); if (lean_is_exclusive(x_8)) { lean_ctor_release(x_8, 0); lean_ctor_release(x_8, 1); lean_ctor_release(x_8, 2); lean_ctor_release(x_8, 3); lean_ctor_release(x_8, 4); - x_441 = x_8; + x_461 = x_8; } else { lean_dec_ref(x_8); - x_441 = lean_box(0); + x_461 = lean_box(0); } -x_442 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_442, 0, x_249); -lean_ctor_set(x_442, 1, x_24); -x_443 = lean_array_push(x_438, x_442); -if (lean_is_scalar(x_441)) { - x_444 = lean_alloc_ctor(0, 5, 0); +x_462 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_462, 0, x_259); +lean_ctor_set(x_462, 1, x_24); +x_463 = lean_array_push(x_458, x_462); +if (lean_is_scalar(x_461)) { + x_464 = lean_alloc_ctor(0, 5, 0); } else { - x_444 = x_441; + x_464 = x_461; } -lean_ctor_set(x_444, 0, x_436); -lean_ctor_set(x_444, 1, x_437); -lean_ctor_set(x_444, 2, x_443); -lean_ctor_set(x_444, 3, x_439); -lean_ctor_set(x_444, 4, x_440); -x_445 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_251, x_444, x_435); -if (lean_obj_tag(x_445) == 0) +lean_ctor_set(x_464, 0, x_456); +lean_ctor_set(x_464, 1, x_457); +lean_ctor_set(x_464, 2, x_463); +lean_ctor_set(x_464, 3, x_459); +lean_ctor_set(x_464, 4, x_460); +x_465 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_261, x_464, x_455); +if (lean_obj_tag(x_465) == 0) { -lean_object* x_446; lean_object* x_447; lean_object* x_448; -x_446 = lean_ctor_get(x_445, 0); -lean_inc(x_446); -x_447 = lean_ctor_get(x_445, 1); -lean_inc(x_447); -lean_dec(x_445); -x_448 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_448, 0, x_446); -x_400 = x_448; -x_401 = x_447; -goto block_432; +lean_object* x_466; lean_object* x_467; lean_object* x_468; +x_466 = lean_ctor_get(x_465, 0); +lean_inc(x_466); +x_467 = lean_ctor_get(x_465, 1); +lean_inc(x_467); +lean_dec(x_465); +x_468 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_468, 0, x_466); +x_418 = x_468; +x_419 = x_467; +goto block_452; } else { -lean_object* x_449; lean_object* x_450; lean_object* x_451; -x_449 = lean_ctor_get(x_445, 0); -lean_inc(x_449); -x_450 = lean_ctor_get(x_445, 1); -lean_inc(x_450); -lean_dec(x_445); -x_451 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_451, 0, x_449); -x_400 = x_451; -x_401 = x_450; -goto block_432; +lean_object* x_469; lean_object* x_470; lean_object* x_471; +x_469 = lean_ctor_get(x_465, 0); +lean_inc(x_469); +x_470 = lean_ctor_get(x_465, 1); +lean_inc(x_470); +lean_dec(x_465); +x_471 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_471, 0, x_469); +x_418 = x_471; +x_419 = x_470; +goto block_452; } -block_432: +block_452: { -if (lean_obj_tag(x_400) == 0) +if (lean_obj_tag(x_418) == 0) { -lean_object* x_402; lean_object* x_403; lean_object* x_404; lean_object* x_405; lean_object* x_406; lean_object* x_407; lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_object* x_412; lean_object* x_413; lean_object* x_414; lean_object* x_415; lean_object* x_416; -x_402 = lean_ctor_get(x_401, 2); -lean_inc(x_402); -x_403 = lean_ctor_get(x_400, 0); -lean_inc(x_403); -lean_dec(x_400); -x_404 = lean_ctor_get(x_401, 0); -lean_inc(x_404); -x_405 = lean_ctor_get(x_401, 1); -lean_inc(x_405); -x_406 = lean_ctor_get(x_401, 3); -lean_inc(x_406); -x_407 = lean_ctor_get(x_401, 4); -lean_inc(x_407); -x_408 = lean_ctor_get(x_401, 5); -lean_inc(x_408); -if (lean_is_exclusive(x_401)) { - lean_ctor_release(x_401, 0); - lean_ctor_release(x_401, 1); - lean_ctor_release(x_401, 2); - lean_ctor_release(x_401, 3); - lean_ctor_release(x_401, 4); - lean_ctor_release(x_401, 5); - x_409 = x_401; -} else { - lean_dec_ref(x_401); - x_409 = lean_box(0); -} -x_410 = lean_ctor_get(x_402, 0); -lean_inc(x_410); -x_411 = lean_ctor_get(x_402, 1); -lean_inc(x_411); -x_412 = lean_ctor_get(x_402, 3); -lean_inc(x_412); -if (lean_is_exclusive(x_402)) { - lean_ctor_release(x_402, 0); - lean_ctor_release(x_402, 1); - lean_ctor_release(x_402, 2); - lean_ctor_release(x_402, 3); - x_413 = x_402; -} else { - lean_dec_ref(x_402); - x_413 = lean_box(0); -} -if (lean_is_scalar(x_413)) { - x_414 = lean_alloc_ctor(0, 4, 0); -} else { - x_414 = x_413; -} -lean_ctor_set(x_414, 0, x_410); -lean_ctor_set(x_414, 1, x_411); -lean_ctor_set(x_414, 2, x_397); -lean_ctor_set(x_414, 3, x_412); -if (lean_is_scalar(x_409)) { - x_415 = lean_alloc_ctor(0, 6, 0); -} else { - x_415 = x_409; -} -lean_ctor_set(x_415, 0, x_404); -lean_ctor_set(x_415, 1, x_405); -lean_ctor_set(x_415, 2, x_414); -lean_ctor_set(x_415, 3, x_406); -lean_ctor_set(x_415, 4, x_407); -lean_ctor_set(x_415, 5, x_408); -if (lean_is_scalar(x_248)) { - x_416 = lean_alloc_ctor(1, 2, 0); -} else { - x_416 = x_248; - lean_ctor_set_tag(x_416, 1); -} -lean_ctor_set(x_416, 0, x_403); -lean_ctor_set(x_416, 1, x_415); -return x_416; -} -else -{ -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; lean_object* x_426; lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; -x_417 = lean_ctor_get(x_401, 2); -lean_inc(x_417); -x_418 = lean_ctor_get(x_400, 0); -lean_inc(x_418); -lean_dec(x_400); -x_419 = lean_ctor_get(x_401, 0); -lean_inc(x_419); -x_420 = lean_ctor_get(x_401, 1); +lean_object* x_420; lean_object* x_421; lean_object* x_422; lean_object* x_423; lean_object* x_424; lean_object* x_425; lean_object* x_426; lean_object* x_427; 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; +x_420 = lean_ctor_get(x_419, 2); lean_inc(x_420); -x_421 = lean_ctor_get(x_401, 3); +x_421 = lean_ctor_get(x_418, 0); lean_inc(x_421); -x_422 = lean_ctor_get(x_401, 4); +lean_dec(x_418); +x_422 = lean_ctor_get(x_419, 0); lean_inc(x_422); -x_423 = lean_ctor_get(x_401, 5); +x_423 = lean_ctor_get(x_419, 1); lean_inc(x_423); -if (lean_is_exclusive(x_401)) { - lean_ctor_release(x_401, 0); - lean_ctor_release(x_401, 1); - lean_ctor_release(x_401, 2); - lean_ctor_release(x_401, 3); - lean_ctor_release(x_401, 4); - lean_ctor_release(x_401, 5); - x_424 = x_401; -} else { - lean_dec_ref(x_401); - x_424 = lean_box(0); -} -x_425 = lean_ctor_get(x_417, 0); +x_424 = lean_ctor_get(x_419, 3); +lean_inc(x_424); +x_425 = lean_ctor_get(x_419, 4); lean_inc(x_425); -x_426 = lean_ctor_get(x_417, 1); +x_426 = lean_ctor_get(x_419, 5); lean_inc(x_426); -x_427 = lean_ctor_get(x_417, 3); -lean_inc(x_427); -if (lean_is_exclusive(x_417)) { - lean_ctor_release(x_417, 0); - lean_ctor_release(x_417, 1); - lean_ctor_release(x_417, 2); - lean_ctor_release(x_417, 3); - x_428 = x_417; +if (lean_is_exclusive(x_419)) { + lean_ctor_release(x_419, 0); + lean_ctor_release(x_419, 1); + lean_ctor_release(x_419, 2); + lean_ctor_release(x_419, 3); + lean_ctor_release(x_419, 4); + lean_ctor_release(x_419, 5); + x_427 = x_419; } else { - lean_dec_ref(x_417); - x_428 = lean_box(0); + lean_dec_ref(x_419); + x_427 = lean_box(0); } -if (lean_is_scalar(x_428)) { - x_429 = lean_alloc_ctor(0, 4, 0); +x_428 = lean_ctor_get(x_420, 0); +lean_inc(x_428); +x_429 = lean_ctor_get(x_420, 1); +lean_inc(x_429); +x_430 = lean_ctor_get(x_420, 3); +lean_inc(x_430); +x_431 = lean_ctor_get(x_420, 4); +lean_inc(x_431); +if (lean_is_exclusive(x_420)) { + lean_ctor_release(x_420, 0); + lean_ctor_release(x_420, 1); + lean_ctor_release(x_420, 2); + lean_ctor_release(x_420, 3); + lean_ctor_release(x_420, 4); + x_432 = x_420; } else { - x_429 = x_428; + lean_dec_ref(x_420); + x_432 = lean_box(0); } -lean_ctor_set(x_429, 0, x_425); -lean_ctor_set(x_429, 1, x_426); -lean_ctor_set(x_429, 2, x_397); -lean_ctor_set(x_429, 3, x_427); -if (lean_is_scalar(x_424)) { - x_430 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_432)) { + x_433 = lean_alloc_ctor(0, 5, 0); } else { - x_430 = x_424; + x_433 = x_432; } -lean_ctor_set(x_430, 0, x_419); -lean_ctor_set(x_430, 1, x_420); -lean_ctor_set(x_430, 2, x_429); -lean_ctor_set(x_430, 3, x_421); -lean_ctor_set(x_430, 4, x_422); -lean_ctor_set(x_430, 5, x_423); -if (lean_is_scalar(x_248)) { - x_431 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_433, 0, x_428); +lean_ctor_set(x_433, 1, x_429); +lean_ctor_set(x_433, 2, x_414); +lean_ctor_set(x_433, 3, x_430); +lean_ctor_set(x_433, 4, x_431); +if (lean_is_scalar(x_427)) { + x_434 = lean_alloc_ctor(0, 6, 0); } else { - x_431 = x_248; + x_434 = x_427; } -lean_ctor_set(x_431, 0, x_418); -lean_ctor_set(x_431, 1, x_430); -return x_431; +lean_ctor_set(x_434, 0, x_422); +lean_ctor_set(x_434, 1, x_423); +lean_ctor_set(x_434, 2, x_433); +lean_ctor_set(x_434, 3, x_424); +lean_ctor_set(x_434, 4, x_425); +lean_ctor_set(x_434, 5, x_426); +if (lean_is_scalar(x_258)) { + x_435 = lean_alloc_ctor(1, 2, 0); +} else { + x_435 = x_258; + lean_ctor_set_tag(x_435, 1); +} +lean_ctor_set(x_435, 0, x_421); +lean_ctor_set(x_435, 1, x_434); +return x_435; +} +else +{ +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; lean_object* x_445; lean_object* x_446; lean_object* x_447; lean_object* x_448; lean_object* x_449; lean_object* x_450; lean_object* x_451; +x_436 = lean_ctor_get(x_419, 2); +lean_inc(x_436); +x_437 = lean_ctor_get(x_418, 0); +lean_inc(x_437); +lean_dec(x_418); +x_438 = lean_ctor_get(x_419, 0); +lean_inc(x_438); +x_439 = lean_ctor_get(x_419, 1); +lean_inc(x_439); +x_440 = lean_ctor_get(x_419, 3); +lean_inc(x_440); +x_441 = lean_ctor_get(x_419, 4); +lean_inc(x_441); +x_442 = lean_ctor_get(x_419, 5); +lean_inc(x_442); +if (lean_is_exclusive(x_419)) { + lean_ctor_release(x_419, 0); + lean_ctor_release(x_419, 1); + lean_ctor_release(x_419, 2); + lean_ctor_release(x_419, 3); + lean_ctor_release(x_419, 4); + lean_ctor_release(x_419, 5); + x_443 = x_419; +} else { + lean_dec_ref(x_419); + x_443 = lean_box(0); +} +x_444 = lean_ctor_get(x_436, 0); +lean_inc(x_444); +x_445 = lean_ctor_get(x_436, 1); +lean_inc(x_445); +x_446 = lean_ctor_get(x_436, 3); +lean_inc(x_446); +x_447 = lean_ctor_get(x_436, 4); +lean_inc(x_447); +if (lean_is_exclusive(x_436)) { + lean_ctor_release(x_436, 0); + lean_ctor_release(x_436, 1); + lean_ctor_release(x_436, 2); + lean_ctor_release(x_436, 3); + lean_ctor_release(x_436, 4); + x_448 = x_436; +} else { + lean_dec_ref(x_436); + x_448 = lean_box(0); +} +if (lean_is_scalar(x_448)) { + x_449 = lean_alloc_ctor(0, 5, 0); +} else { + x_449 = x_448; +} +lean_ctor_set(x_449, 0, x_444); +lean_ctor_set(x_449, 1, x_445); +lean_ctor_set(x_449, 2, x_414); +lean_ctor_set(x_449, 3, x_446); +lean_ctor_set(x_449, 4, x_447); +if (lean_is_scalar(x_443)) { + x_450 = lean_alloc_ctor(0, 6, 0); +} else { + x_450 = x_443; +} +lean_ctor_set(x_450, 0, x_438); +lean_ctor_set(x_450, 1, x_439); +lean_ctor_set(x_450, 2, x_449); +lean_ctor_set(x_450, 3, x_440); +lean_ctor_set(x_450, 4, x_441); +lean_ctor_set(x_450, 5, x_442); +if (lean_is_scalar(x_258)) { + x_451 = lean_alloc_ctor(0, 2, 0); +} else { + x_451 = x_258; +} +lean_ctor_set(x_451, 0, x_437); +lean_ctor_set(x_451, 1, x_450); +return x_451; } } } @@ -11748,30 +11896,30 @@ return x_431; } else { -uint8_t x_452; +uint8_t x_472; lean_dec(x_24); lean_dec(x_8); lean_dec(x_7); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_452 = !lean_is_exclusive(x_241); -if (x_452 == 0) +x_472 = !lean_is_exclusive(x_251); +if (x_472 == 0) { -return x_241; +return x_251; } else { -lean_object* x_453; lean_object* x_454; lean_object* x_455; -x_453 = lean_ctor_get(x_241, 0); -x_454 = lean_ctor_get(x_241, 1); -lean_inc(x_454); -lean_inc(x_453); -lean_dec(x_241); -x_455 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_455, 0, x_453); -lean_ctor_set(x_455, 1, x_454); -return x_455; +lean_object* x_473; lean_object* x_474; lean_object* x_475; +x_473 = lean_ctor_get(x_251, 0); +x_474 = lean_ctor_get(x_251, 1); +lean_inc(x_474); +lean_inc(x_473); +lean_dec(x_251); +x_475 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_475, 0, x_473); +lean_ctor_set(x_475, 1, x_474); +return x_475; } } } @@ -11779,7 +11927,7 @@ return x_455; } else { -uint8_t x_456; +uint8_t x_476; lean_dec(x_28); lean_dec(x_24); lean_dec(x_8); @@ -11787,52 +11935,52 @@ lean_dec(x_7); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_456 = !lean_is_exclusive(x_29); -if (x_456 == 0) +x_476 = !lean_is_exclusive(x_29); +if (x_476 == 0) { return x_29; } else { -lean_object* x_457; lean_object* x_458; lean_object* x_459; -x_457 = lean_ctor_get(x_29, 0); -x_458 = lean_ctor_get(x_29, 1); -lean_inc(x_458); -lean_inc(x_457); +lean_object* x_477; lean_object* x_478; lean_object* x_479; +x_477 = lean_ctor_get(x_29, 0); +x_478 = lean_ctor_get(x_29, 1); +lean_inc(x_478); +lean_inc(x_477); lean_dec(x_29); -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_479 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_479, 0, x_477); +lean_ctor_set(x_479, 1, x_478); +return x_479; } } } else { -uint8_t x_460; +uint8_t x_480; lean_dec(x_24); lean_dec(x_8); lean_dec(x_7); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_460 = !lean_is_exclusive(x_25); -if (x_460 == 0) +x_480 = !lean_is_exclusive(x_25); +if (x_480 == 0) { return x_25; } else { -lean_object* x_461; lean_object* x_462; lean_object* x_463; -x_461 = lean_ctor_get(x_25, 0); -x_462 = lean_ctor_get(x_25, 1); -lean_inc(x_462); -lean_inc(x_461); +lean_object* x_481; lean_object* x_482; lean_object* x_483; +x_481 = lean_ctor_get(x_25, 0); +x_482 = lean_ctor_get(x_25, 1); +lean_inc(x_482); +lean_inc(x_481); lean_dec(x_25); -x_463 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_463, 0, x_461); -lean_ctor_set(x_463, 1, x_462); -return x_463; +x_483 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_483, 0, x_481); +lean_ctor_set(x_483, 1, x_482); +return x_483; } } } @@ -12027,105 +12175,105 @@ x_39 = lean_ctor_get(x_33, 2); x_40 = !lean_is_exclusive(x_39); if (x_40 == 0) { -lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_93; uint8_t x_94; +lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_97; uint8_t x_98; x_41 = lean_ctor_get(x_39, 2); -x_93 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_39, 2, x_93); -x_94 = !lean_is_exclusive(x_13); -if (x_94 == 0) +x_97 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_39, 2, x_97); +x_98 = !lean_is_exclusive(x_13); +if (x_98 == 0) { -lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; -x_95 = lean_ctor_get(x_13, 2); -x_96 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_96, 0, x_35); -lean_ctor_set(x_96, 1, x_22); -x_97 = lean_array_push(x_95, x_96); -lean_ctor_set(x_13, 2, x_97); -x_98 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_37, x_13, x_33); -if (lean_obj_tag(x_98) == 0) +lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; +x_99 = lean_ctor_get(x_13, 2); +x_100 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_100, 0, x_35); +lean_ctor_set(x_100, 1, x_22); +x_101 = lean_array_push(x_99, x_100); +lean_ctor_set(x_13, 2, x_101); +x_102 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_37, x_13, x_33); +if (lean_obj_tag(x_102) == 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); -x_101 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_101, 0, x_99); -x_42 = x_101; -x_43 = x_100; -goto block_92; -} -else -{ -lean_object* x_102; lean_object* x_103; lean_object* x_104; -x_102 = lean_ctor_get(x_98, 0); -lean_inc(x_102); -x_103 = lean_ctor_get(x_98, 1); +lean_object* x_103; lean_object* x_104; lean_object* x_105; +x_103 = lean_ctor_get(x_102, 0); lean_inc(x_103); -lean_dec(x_98); -x_104 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_104, 0, x_102); -x_42 = x_104; -x_43 = x_103; -goto block_92; -} +x_104 = lean_ctor_get(x_102, 1); +lean_inc(x_104); +lean_dec(x_102); +x_105 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_105, 0, x_103); +x_42 = x_105; +x_43 = x_104; +goto block_96; } else { -lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; -x_105 = lean_ctor_get(x_13, 0); -x_106 = lean_ctor_get(x_13, 1); -x_107 = lean_ctor_get(x_13, 2); -x_108 = lean_ctor_get(x_13, 3); -x_109 = lean_ctor_get(x_13, 4); -lean_inc(x_109); -lean_inc(x_108); -lean_inc(x_107); +lean_object* x_106; lean_object* x_107; lean_object* x_108; +x_106 = lean_ctor_get(x_102, 0); lean_inc(x_106); -lean_inc(x_105); -lean_dec(x_13); -x_110 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_110, 0, x_35); -lean_ctor_set(x_110, 1, x_22); -x_111 = lean_array_push(x_107, x_110); -x_112 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_112, 0, x_105); -lean_ctor_set(x_112, 1, x_106); -lean_ctor_set(x_112, 2, x_111); -lean_ctor_set(x_112, 3, x_108); -lean_ctor_set(x_112, 4, x_109); -x_113 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_37, x_112, x_33); -if (lean_obj_tag(x_113) == 0) -{ -lean_object* x_114; lean_object* x_115; lean_object* x_116; -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_114); -x_42 = x_116; -x_43 = x_115; -goto block_92; +x_107 = lean_ctor_get(x_102, 1); +lean_inc(x_107); +lean_dec(x_102); +x_108 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_108, 0, x_106); +x_42 = x_108; +x_43 = x_107; +goto block_96; +} } else { -lean_object* x_117; lean_object* x_118; lean_object* x_119; -x_117 = lean_ctor_get(x_113, 0); -lean_inc(x_117); -x_118 = lean_ctor_get(x_113, 1); +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; +x_109 = lean_ctor_get(x_13, 0); +x_110 = lean_ctor_get(x_13, 1); +x_111 = lean_ctor_get(x_13, 2); +x_112 = lean_ctor_get(x_13, 3); +x_113 = lean_ctor_get(x_13, 4); +lean_inc(x_113); +lean_inc(x_112); +lean_inc(x_111); +lean_inc(x_110); +lean_inc(x_109); +lean_dec(x_13); +x_114 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_114, 0, x_35); +lean_ctor_set(x_114, 1, x_22); +x_115 = lean_array_push(x_111, x_114); +x_116 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_116, 0, x_109); +lean_ctor_set(x_116, 1, x_110); +lean_ctor_set(x_116, 2, x_115); +lean_ctor_set(x_116, 3, x_112); +lean_ctor_set(x_116, 4, x_113); +x_117 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_37, x_116, x_33); +if (lean_obj_tag(x_117) == 0) +{ +lean_object* x_118; lean_object* x_119; lean_object* x_120; +x_118 = lean_ctor_get(x_117, 0); lean_inc(x_118); -lean_dec(x_113); -x_119 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_119, 0, x_117); -x_42 = x_119; -x_43 = x_118; -goto block_92; +x_119 = lean_ctor_get(x_117, 1); +lean_inc(x_119); +lean_dec(x_117); +x_120 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_120, 0, x_118); +x_42 = x_120; +x_43 = x_119; +goto block_96; +} +else +{ +lean_object* x_121; lean_object* x_122; lean_object* x_123; +x_121 = lean_ctor_get(x_117, 0); +lean_inc(x_121); +x_122 = lean_ctor_get(x_117, 1); +lean_inc(x_122); +lean_dec(x_117); +x_123 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_123, 0, x_121); +x_42 = x_123; +x_43 = x_122; +goto block_96; } } -block_92: +block_96: { if (lean_obj_tag(x_42) == 0) { @@ -12160,1284 +12308,1262 @@ return x_50; } else { -lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; +lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; x_51 = lean_ctor_get(x_44, 0); x_52 = lean_ctor_get(x_44, 1); x_53 = lean_ctor_get(x_44, 3); +x_54 = lean_ctor_get(x_44, 4); +lean_inc(x_54); lean_inc(x_53); lean_inc(x_52); lean_inc(x_51); lean_dec(x_44); -x_54 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_54, 0, x_51); -lean_ctor_set(x_54, 1, x_52); -lean_ctor_set(x_54, 2, x_41); -lean_ctor_set(x_54, 3, x_53); -lean_ctor_set(x_43, 2, x_54); +x_55 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_55, 0, x_51); +lean_ctor_set(x_55, 1, x_52); +lean_ctor_set(x_55, 2, x_41); +lean_ctor_set(x_55, 3, x_53); +lean_ctor_set(x_55, 4, x_54); +lean_ctor_set(x_43, 2, x_55); if (lean_is_scalar(x_34)) { - x_55 = lean_alloc_ctor(1, 2, 0); + x_56 = lean_alloc_ctor(1, 2, 0); } else { - x_55 = x_34; - lean_ctor_set_tag(x_55, 1); + x_56 = x_34; + lean_ctor_set_tag(x_56, 1); } -lean_ctor_set(x_55, 0, x_45); -lean_ctor_set(x_55, 1, x_43); -return x_55; +lean_ctor_set(x_56, 0, x_45); +lean_ctor_set(x_56, 1, x_43); +return x_56; } } else { -lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; -x_56 = lean_ctor_get(x_43, 0); -x_57 = lean_ctor_get(x_43, 1); -x_58 = lean_ctor_get(x_43, 3); -x_59 = lean_ctor_get(x_43, 4); -x_60 = lean_ctor_get(x_43, 5); +lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; +x_57 = lean_ctor_get(x_43, 0); +x_58 = lean_ctor_get(x_43, 1); +x_59 = lean_ctor_get(x_43, 3); +x_60 = lean_ctor_get(x_43, 4); +x_61 = lean_ctor_get(x_43, 5); +lean_inc(x_61); lean_inc(x_60); lean_inc(x_59); lean_inc(x_58); lean_inc(x_57); -lean_inc(x_56); lean_dec(x_43); -x_61 = lean_ctor_get(x_44, 0); -lean_inc(x_61); -x_62 = lean_ctor_get(x_44, 1); +x_62 = lean_ctor_get(x_44, 0); lean_inc(x_62); -x_63 = lean_ctor_get(x_44, 3); +x_63 = lean_ctor_get(x_44, 1); lean_inc(x_63); +x_64 = lean_ctor_get(x_44, 3); +lean_inc(x_64); +x_65 = lean_ctor_get(x_44, 4); +lean_inc(x_65); if (lean_is_exclusive(x_44)) { lean_ctor_release(x_44, 0); lean_ctor_release(x_44, 1); lean_ctor_release(x_44, 2); lean_ctor_release(x_44, 3); - x_64 = x_44; + lean_ctor_release(x_44, 4); + x_66 = x_44; } else { lean_dec_ref(x_44); - x_64 = lean_box(0); + x_66 = lean_box(0); } -if (lean_is_scalar(x_64)) { - x_65 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_66)) { + x_67 = lean_alloc_ctor(0, 5, 0); } else { - x_65 = x_64; + x_67 = x_66; } -lean_ctor_set(x_65, 0, x_61); -lean_ctor_set(x_65, 1, x_62); -lean_ctor_set(x_65, 2, x_41); -lean_ctor_set(x_65, 3, x_63); -x_66 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_66, 0, x_56); -lean_ctor_set(x_66, 1, x_57); -lean_ctor_set(x_66, 2, x_65); -lean_ctor_set(x_66, 3, x_58); -lean_ctor_set(x_66, 4, x_59); -lean_ctor_set(x_66, 5, x_60); +lean_ctor_set(x_67, 0, x_62); +lean_ctor_set(x_67, 1, x_63); +lean_ctor_set(x_67, 2, x_41); +lean_ctor_set(x_67, 3, x_64); +lean_ctor_set(x_67, 4, x_65); +x_68 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_68, 0, x_57); +lean_ctor_set(x_68, 1, x_58); +lean_ctor_set(x_68, 2, x_67); +lean_ctor_set(x_68, 3, x_59); +lean_ctor_set(x_68, 4, x_60); +lean_ctor_set(x_68, 5, x_61); if (lean_is_scalar(x_34)) { - x_67 = lean_alloc_ctor(1, 2, 0); + x_69 = lean_alloc_ctor(1, 2, 0); } else { - x_67 = x_34; - lean_ctor_set_tag(x_67, 1); + x_69 = x_34; + lean_ctor_set_tag(x_69, 1); } -lean_ctor_set(x_67, 0, x_45); -lean_ctor_set(x_67, 1, x_66); -return x_67; +lean_ctor_set(x_69, 0, x_45); +lean_ctor_set(x_69, 1, x_68); +return x_69; } } else { -lean_object* x_68; lean_object* x_69; uint8_t x_70; -x_68 = lean_ctor_get(x_43, 2); -lean_inc(x_68); -x_69 = lean_ctor_get(x_42, 0); -lean_inc(x_69); +lean_object* x_70; lean_object* x_71; uint8_t x_72; +x_70 = lean_ctor_get(x_43, 2); +lean_inc(x_70); +x_71 = lean_ctor_get(x_42, 0); +lean_inc(x_71); lean_dec(x_42); -x_70 = !lean_is_exclusive(x_43); -if (x_70 == 0) -{ -lean_object* x_71; uint8_t x_72; -x_71 = lean_ctor_get(x_43, 2); -lean_dec(x_71); -x_72 = !lean_is_exclusive(x_68); +x_72 = !lean_is_exclusive(x_43); if (x_72 == 0) { -lean_object* x_73; lean_object* x_74; -x_73 = lean_ctor_get(x_68, 2); +lean_object* x_73; uint8_t x_74; +x_73 = lean_ctor_get(x_43, 2); lean_dec(x_73); -lean_ctor_set(x_68, 2, x_41); +x_74 = !lean_is_exclusive(x_70); +if (x_74 == 0) +{ +lean_object* x_75; lean_object* x_76; +x_75 = lean_ctor_get(x_70, 2); +lean_dec(x_75); +lean_ctor_set(x_70, 2, x_41); if (lean_is_scalar(x_34)) { - x_74 = lean_alloc_ctor(0, 2, 0); + x_76 = lean_alloc_ctor(0, 2, 0); } else { - x_74 = x_34; + x_76 = x_34; } -lean_ctor_set(x_74, 0, x_69); -lean_ctor_set(x_74, 1, x_43); -return x_74; +lean_ctor_set(x_76, 0, x_71); +lean_ctor_set(x_76, 1, x_43); +return x_76; } else { -lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; -x_75 = lean_ctor_get(x_68, 0); -x_76 = lean_ctor_get(x_68, 1); -x_77 = lean_ctor_get(x_68, 3); +lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; +x_77 = lean_ctor_get(x_70, 0); +x_78 = lean_ctor_get(x_70, 1); +x_79 = lean_ctor_get(x_70, 3); +x_80 = lean_ctor_get(x_70, 4); +lean_inc(x_80); +lean_inc(x_79); +lean_inc(x_78); lean_inc(x_77); -lean_inc(x_76); -lean_inc(x_75); -lean_dec(x_68); -x_78 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_78, 0, x_75); -lean_ctor_set(x_78, 1, x_76); -lean_ctor_set(x_78, 2, x_41); -lean_ctor_set(x_78, 3, x_77); -lean_ctor_set(x_43, 2, x_78); +lean_dec(x_70); +x_81 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_81, 0, x_77); +lean_ctor_set(x_81, 1, x_78); +lean_ctor_set(x_81, 2, x_41); +lean_ctor_set(x_81, 3, x_79); +lean_ctor_set(x_81, 4, x_80); +lean_ctor_set(x_43, 2, x_81); if (lean_is_scalar(x_34)) { - x_79 = lean_alloc_ctor(0, 2, 0); + x_82 = lean_alloc_ctor(0, 2, 0); } else { - x_79 = x_34; + x_82 = x_34; } -lean_ctor_set(x_79, 0, x_69); -lean_ctor_set(x_79, 1, x_43); -return x_79; +lean_ctor_set(x_82, 0, x_71); +lean_ctor_set(x_82, 1, x_43); +return x_82; } } else { -lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; -x_80 = lean_ctor_get(x_43, 0); -x_81 = lean_ctor_get(x_43, 1); -x_82 = lean_ctor_get(x_43, 3); -x_83 = lean_ctor_get(x_43, 4); -x_84 = lean_ctor_get(x_43, 5); +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; +x_83 = lean_ctor_get(x_43, 0); +x_84 = lean_ctor_get(x_43, 1); +x_85 = lean_ctor_get(x_43, 3); +x_86 = lean_ctor_get(x_43, 4); +x_87 = lean_ctor_get(x_43, 5); +lean_inc(x_87); +lean_inc(x_86); +lean_inc(x_85); lean_inc(x_84); lean_inc(x_83); -lean_inc(x_82); -lean_inc(x_81); -lean_inc(x_80); lean_dec(x_43); -x_85 = lean_ctor_get(x_68, 0); -lean_inc(x_85); -x_86 = lean_ctor_get(x_68, 1); -lean_inc(x_86); -x_87 = lean_ctor_get(x_68, 3); -lean_inc(x_87); -if (lean_is_exclusive(x_68)) { - lean_ctor_release(x_68, 0); - lean_ctor_release(x_68, 1); - lean_ctor_release(x_68, 2); - lean_ctor_release(x_68, 3); - x_88 = x_68; +x_88 = lean_ctor_get(x_70, 0); +lean_inc(x_88); +x_89 = lean_ctor_get(x_70, 1); +lean_inc(x_89); +x_90 = lean_ctor_get(x_70, 3); +lean_inc(x_90); +x_91 = lean_ctor_get(x_70, 4); +lean_inc(x_91); +if (lean_is_exclusive(x_70)) { + lean_ctor_release(x_70, 0); + lean_ctor_release(x_70, 1); + lean_ctor_release(x_70, 2); + lean_ctor_release(x_70, 3); + lean_ctor_release(x_70, 4); + x_92 = x_70; } else { - lean_dec_ref(x_68); - x_88 = lean_box(0); + lean_dec_ref(x_70); + x_92 = lean_box(0); } -if (lean_is_scalar(x_88)) { - x_89 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_92)) { + x_93 = lean_alloc_ctor(0, 5, 0); } else { - x_89 = x_88; + x_93 = x_92; } -lean_ctor_set(x_89, 0, x_85); -lean_ctor_set(x_89, 1, x_86); -lean_ctor_set(x_89, 2, x_41); -lean_ctor_set(x_89, 3, x_87); -x_90 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_90, 0, x_80); -lean_ctor_set(x_90, 1, x_81); -lean_ctor_set(x_90, 2, x_89); -lean_ctor_set(x_90, 3, x_82); -lean_ctor_set(x_90, 4, x_83); -lean_ctor_set(x_90, 5, x_84); +lean_ctor_set(x_93, 0, x_88); +lean_ctor_set(x_93, 1, x_89); +lean_ctor_set(x_93, 2, x_41); +lean_ctor_set(x_93, 3, x_90); +lean_ctor_set(x_93, 4, x_91); +x_94 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_94, 0, x_83); +lean_ctor_set(x_94, 1, x_84); +lean_ctor_set(x_94, 2, x_93); +lean_ctor_set(x_94, 3, x_85); +lean_ctor_set(x_94, 4, x_86); +lean_ctor_set(x_94, 5, x_87); if (lean_is_scalar(x_34)) { - x_91 = lean_alloc_ctor(0, 2, 0); + x_95 = lean_alloc_ctor(0, 2, 0); } else { - x_91 = x_34; + x_95 = x_34; } -lean_ctor_set(x_91, 0, x_69); -lean_ctor_set(x_91, 1, x_90); -return x_91; +lean_ctor_set(x_95, 0, x_71); +lean_ctor_set(x_95, 1, x_94); +return x_95; } } } } else { -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_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_120 = lean_ctor_get(x_39, 0); -x_121 = lean_ctor_get(x_39, 1); -x_122 = lean_ctor_get(x_39, 2); -x_123 = lean_ctor_get(x_39, 3); -lean_inc(x_123); -lean_inc(x_122); -lean_inc(x_121); -lean_inc(x_120); -lean_dec(x_39); -x_157 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_158 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_158, 0, x_120); -lean_ctor_set(x_158, 1, x_121); -lean_ctor_set(x_158, 2, x_157); -lean_ctor_set(x_158, 3, x_123); -lean_ctor_set(x_33, 2, x_158); -x_159 = lean_ctor_get(x_13, 0); -lean_inc(x_159); -x_160 = lean_ctor_get(x_13, 1); -lean_inc(x_160); -x_161 = lean_ctor_get(x_13, 2); -lean_inc(x_161); -x_162 = lean_ctor_get(x_13, 3); -lean_inc(x_162); -x_163 = lean_ctor_get(x_13, 4); -lean_inc(x_163); -if (lean_is_exclusive(x_13)) { - lean_ctor_release(x_13, 0); - lean_ctor_release(x_13, 1); - lean_ctor_release(x_13, 2); - lean_ctor_release(x_13, 3); - lean_ctor_release(x_13, 4); - x_164 = x_13; -} else { - lean_dec_ref(x_13); - x_164 = lean_box(0); -} -x_165 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_165, 0, x_35); -lean_ctor_set(x_165, 1, x_22); -x_166 = lean_array_push(x_161, x_165); -if (lean_is_scalar(x_164)) { - x_167 = lean_alloc_ctor(0, 5, 0); -} else { - x_167 = x_164; -} -lean_ctor_set(x_167, 0, x_159); -lean_ctor_set(x_167, 1, x_160); -lean_ctor_set(x_167, 2, x_166); -lean_ctor_set(x_167, 3, x_162); -lean_ctor_set(x_167, 4, x_163); -x_168 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_37, x_167, x_33); -if (lean_obj_tag(x_168) == 0) -{ -lean_object* x_169; lean_object* x_170; lean_object* x_171; -x_169 = lean_ctor_get(x_168, 0); -lean_inc(x_169); -x_170 = lean_ctor_get(x_168, 1); -lean_inc(x_170); -lean_dec(x_168); -x_171 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_171, 0, x_169); -x_124 = x_171; -x_125 = x_170; -goto block_156; -} -else -{ -lean_object* x_172; lean_object* x_173; lean_object* x_174; -x_172 = lean_ctor_get(x_168, 0); -lean_inc(x_172); -x_173 = lean_ctor_get(x_168, 1); -lean_inc(x_173); -lean_dec(x_168); -x_174 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_174, 0, x_172); -x_124 = x_174; -x_125 = x_173; -goto block_156; -} -block_156: -{ -if (lean_obj_tag(x_124) == 0) -{ -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; -x_126 = lean_ctor_get(x_125, 2); -lean_inc(x_126); -x_127 = lean_ctor_get(x_124, 0); -lean_inc(x_127); -lean_dec(x_124); -x_128 = lean_ctor_get(x_125, 0); +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_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; lean_object* x_173; lean_object* x_174; lean_object* x_175; +x_124 = lean_ctor_get(x_39, 0); +x_125 = lean_ctor_get(x_39, 1); +x_126 = lean_ctor_get(x_39, 2); +x_127 = lean_ctor_get(x_39, 3); +x_128 = lean_ctor_get(x_39, 4); lean_inc(x_128); -x_129 = lean_ctor_get(x_125, 1); -lean_inc(x_129); -x_130 = lean_ctor_get(x_125, 3); -lean_inc(x_130); -x_131 = lean_ctor_get(x_125, 4); -lean_inc(x_131); -x_132 = lean_ctor_get(x_125, 5); -lean_inc(x_132); -if (lean_is_exclusive(x_125)) { - lean_ctor_release(x_125, 0); - lean_ctor_release(x_125, 1); - lean_ctor_release(x_125, 2); - lean_ctor_release(x_125, 3); - lean_ctor_release(x_125, 4); - lean_ctor_release(x_125, 5); - x_133 = x_125; -} else { - lean_dec_ref(x_125); - x_133 = lean_box(0); -} -x_134 = lean_ctor_get(x_126, 0); -lean_inc(x_134); -x_135 = lean_ctor_get(x_126, 1); -lean_inc(x_135); -x_136 = lean_ctor_get(x_126, 3); -lean_inc(x_136); -if (lean_is_exclusive(x_126)) { - lean_ctor_release(x_126, 0); - lean_ctor_release(x_126, 1); - lean_ctor_release(x_126, 2); - lean_ctor_release(x_126, 3); - x_137 = x_126; -} else { - lean_dec_ref(x_126); - x_137 = lean_box(0); -} -if (lean_is_scalar(x_137)) { - x_138 = lean_alloc_ctor(0, 4, 0); -} else { - x_138 = x_137; -} -lean_ctor_set(x_138, 0, x_134); -lean_ctor_set(x_138, 1, x_135); -lean_ctor_set(x_138, 2, x_122); -lean_ctor_set(x_138, 3, x_136); -if (lean_is_scalar(x_133)) { - x_139 = lean_alloc_ctor(0, 6, 0); -} else { - x_139 = x_133; -} -lean_ctor_set(x_139, 0, x_128); -lean_ctor_set(x_139, 1, x_129); -lean_ctor_set(x_139, 2, x_138); -lean_ctor_set(x_139, 3, x_130); -lean_ctor_set(x_139, 4, x_131); -lean_ctor_set(x_139, 5, x_132); -if (lean_is_scalar(x_34)) { - x_140 = lean_alloc_ctor(1, 2, 0); -} else { - x_140 = x_34; - lean_ctor_set_tag(x_140, 1); -} -lean_ctor_set(x_140, 0, x_127); -lean_ctor_set(x_140, 1, x_139); -return x_140; -} -else -{ -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; -x_141 = lean_ctor_get(x_125, 2); -lean_inc(x_141); -x_142 = lean_ctor_get(x_124, 0); -lean_inc(x_142); -lean_dec(x_124); -x_143 = lean_ctor_get(x_125, 0); -lean_inc(x_143); -x_144 = lean_ctor_get(x_125, 1); -lean_inc(x_144); -x_145 = lean_ctor_get(x_125, 3); -lean_inc(x_145); -x_146 = lean_ctor_get(x_125, 4); -lean_inc(x_146); -x_147 = lean_ctor_get(x_125, 5); -lean_inc(x_147); -if (lean_is_exclusive(x_125)) { - lean_ctor_release(x_125, 0); - lean_ctor_release(x_125, 1); - lean_ctor_release(x_125, 2); - lean_ctor_release(x_125, 3); - lean_ctor_release(x_125, 4); - lean_ctor_release(x_125, 5); - x_148 = x_125; -} else { - lean_dec_ref(x_125); - x_148 = lean_box(0); -} -x_149 = lean_ctor_get(x_141, 0); -lean_inc(x_149); -x_150 = lean_ctor_get(x_141, 1); -lean_inc(x_150); -x_151 = lean_ctor_get(x_141, 3); -lean_inc(x_151); -if (lean_is_exclusive(x_141)) { - lean_ctor_release(x_141, 0); - lean_ctor_release(x_141, 1); - lean_ctor_release(x_141, 2); - lean_ctor_release(x_141, 3); - x_152 = x_141; -} else { - lean_dec_ref(x_141); - x_152 = lean_box(0); -} -if (lean_is_scalar(x_152)) { - x_153 = lean_alloc_ctor(0, 4, 0); -} else { - x_153 = x_152; -} -lean_ctor_set(x_153, 0, x_149); -lean_ctor_set(x_153, 1, x_150); -lean_ctor_set(x_153, 2, x_122); -lean_ctor_set(x_153, 3, x_151); -if (lean_is_scalar(x_148)) { - x_154 = lean_alloc_ctor(0, 6, 0); -} else { - x_154 = x_148; -} -lean_ctor_set(x_154, 0, x_143); -lean_ctor_set(x_154, 1, x_144); -lean_ctor_set(x_154, 2, x_153); -lean_ctor_set(x_154, 3, x_145); -lean_ctor_set(x_154, 4, x_146); -lean_ctor_set(x_154, 5, x_147); -if (lean_is_scalar(x_34)) { - x_155 = lean_alloc_ctor(0, 2, 0); -} else { - x_155 = x_34; -} -lean_ctor_set(x_155, 0, x_142); -lean_ctor_set(x_155, 1, x_154); -return x_155; -} -} -} -} -else -{ -lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; 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; lean_object* x_231; -x_175 = lean_ctor_get(x_33, 2); -x_176 = lean_ctor_get(x_33, 0); -x_177 = lean_ctor_get(x_33, 1); -x_178 = lean_ctor_get(x_33, 3); -x_179 = lean_ctor_get(x_33, 4); -x_180 = lean_ctor_get(x_33, 5); -lean_inc(x_180); -lean_inc(x_179); -lean_inc(x_178); -lean_inc(x_175); -lean_inc(x_177); -lean_inc(x_176); -lean_dec(x_33); -x_181 = lean_ctor_get(x_175, 0); -lean_inc(x_181); -x_182 = lean_ctor_get(x_175, 1); -lean_inc(x_182); -x_183 = lean_ctor_get(x_175, 2); -lean_inc(x_183); -x_184 = lean_ctor_get(x_175, 3); -lean_inc(x_184); -if (lean_is_exclusive(x_175)) { - lean_ctor_release(x_175, 0); - lean_ctor_release(x_175, 1); - lean_ctor_release(x_175, 2); - lean_ctor_release(x_175, 3); - x_185 = x_175; -} else { - lean_dec_ref(x_175); - x_185 = lean_box(0); -} -x_219 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_185)) { - x_220 = lean_alloc_ctor(0, 4, 0); -} else { - x_220 = x_185; -} -lean_ctor_set(x_220, 0, x_181); -lean_ctor_set(x_220, 1, x_182); -lean_ctor_set(x_220, 2, x_219); -lean_ctor_set(x_220, 3, x_184); -x_221 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_221, 0, x_176); -lean_ctor_set(x_221, 1, x_177); -lean_ctor_set(x_221, 2, x_220); -lean_ctor_set(x_221, 3, x_178); -lean_ctor_set(x_221, 4, x_179); -lean_ctor_set(x_221, 5, x_180); -x_222 = lean_ctor_get(x_13, 0); -lean_inc(x_222); -x_223 = lean_ctor_get(x_13, 1); -lean_inc(x_223); -x_224 = lean_ctor_get(x_13, 2); -lean_inc(x_224); -x_225 = lean_ctor_get(x_13, 3); -lean_inc(x_225); -x_226 = lean_ctor_get(x_13, 4); -lean_inc(x_226); +lean_inc(x_127); +lean_inc(x_126); +lean_inc(x_125); +lean_inc(x_124); +lean_dec(x_39); +x_164 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_165 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_165, 0, x_124); +lean_ctor_set(x_165, 1, x_125); +lean_ctor_set(x_165, 2, x_164); +lean_ctor_set(x_165, 3, x_127); +lean_ctor_set(x_165, 4, x_128); +lean_ctor_set(x_33, 2, x_165); +x_166 = lean_ctor_get(x_13, 0); +lean_inc(x_166); +x_167 = lean_ctor_get(x_13, 1); +lean_inc(x_167); +x_168 = lean_ctor_get(x_13, 2); +lean_inc(x_168); +x_169 = lean_ctor_get(x_13, 3); +lean_inc(x_169); +x_170 = lean_ctor_get(x_13, 4); +lean_inc(x_170); if (lean_is_exclusive(x_13)) { lean_ctor_release(x_13, 0); lean_ctor_release(x_13, 1); lean_ctor_release(x_13, 2); lean_ctor_release(x_13, 3); lean_ctor_release(x_13, 4); - x_227 = x_13; + x_171 = x_13; } else { lean_dec_ref(x_13); - x_227 = lean_box(0); + x_171 = lean_box(0); } -x_228 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_228, 0, x_35); -lean_ctor_set(x_228, 1, x_22); -x_229 = lean_array_push(x_224, x_228); -if (lean_is_scalar(x_227)) { +x_172 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_172, 0, x_35); +lean_ctor_set(x_172, 1, x_22); +x_173 = lean_array_push(x_168, x_172); +if (lean_is_scalar(x_171)) { + x_174 = lean_alloc_ctor(0, 5, 0); +} else { + x_174 = x_171; +} +lean_ctor_set(x_174, 0, x_166); +lean_ctor_set(x_174, 1, x_167); +lean_ctor_set(x_174, 2, x_173); +lean_ctor_set(x_174, 3, x_169); +lean_ctor_set(x_174, 4, x_170); +x_175 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_37, x_174, x_33); +if (lean_obj_tag(x_175) == 0) +{ +lean_object* x_176; lean_object* x_177; lean_object* x_178; +x_176 = lean_ctor_get(x_175, 0); +lean_inc(x_176); +x_177 = lean_ctor_get(x_175, 1); +lean_inc(x_177); +lean_dec(x_175); +x_178 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_178, 0, x_176); +x_129 = x_178; +x_130 = x_177; +goto block_163; +} +else +{ +lean_object* x_179; lean_object* x_180; lean_object* x_181; +x_179 = lean_ctor_get(x_175, 0); +lean_inc(x_179); +x_180 = lean_ctor_get(x_175, 1); +lean_inc(x_180); +lean_dec(x_175); +x_181 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_181, 0, x_179); +x_129 = x_181; +x_130 = x_180; +goto block_163; +} +block_163: +{ +if (lean_obj_tag(x_129) == 0) +{ +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; +x_131 = lean_ctor_get(x_130, 2); +lean_inc(x_131); +x_132 = lean_ctor_get(x_129, 0); +lean_inc(x_132); +lean_dec(x_129); +x_133 = lean_ctor_get(x_130, 0); +lean_inc(x_133); +x_134 = lean_ctor_get(x_130, 1); +lean_inc(x_134); +x_135 = lean_ctor_get(x_130, 3); +lean_inc(x_135); +x_136 = lean_ctor_get(x_130, 4); +lean_inc(x_136); +x_137 = lean_ctor_get(x_130, 5); +lean_inc(x_137); +if (lean_is_exclusive(x_130)) { + lean_ctor_release(x_130, 0); + lean_ctor_release(x_130, 1); + lean_ctor_release(x_130, 2); + lean_ctor_release(x_130, 3); + lean_ctor_release(x_130, 4); + lean_ctor_release(x_130, 5); + x_138 = x_130; +} else { + lean_dec_ref(x_130); + x_138 = lean_box(0); +} +x_139 = lean_ctor_get(x_131, 0); +lean_inc(x_139); +x_140 = lean_ctor_get(x_131, 1); +lean_inc(x_140); +x_141 = lean_ctor_get(x_131, 3); +lean_inc(x_141); +x_142 = lean_ctor_get(x_131, 4); +lean_inc(x_142); +if (lean_is_exclusive(x_131)) { + lean_ctor_release(x_131, 0); + lean_ctor_release(x_131, 1); + lean_ctor_release(x_131, 2); + lean_ctor_release(x_131, 3); + lean_ctor_release(x_131, 4); + x_143 = x_131; +} else { + lean_dec_ref(x_131); + x_143 = lean_box(0); +} +if (lean_is_scalar(x_143)) { + x_144 = lean_alloc_ctor(0, 5, 0); +} else { + x_144 = x_143; +} +lean_ctor_set(x_144, 0, x_139); +lean_ctor_set(x_144, 1, x_140); +lean_ctor_set(x_144, 2, x_126); +lean_ctor_set(x_144, 3, x_141); +lean_ctor_set(x_144, 4, x_142); +if (lean_is_scalar(x_138)) { + x_145 = lean_alloc_ctor(0, 6, 0); +} else { + x_145 = x_138; +} +lean_ctor_set(x_145, 0, x_133); +lean_ctor_set(x_145, 1, x_134); +lean_ctor_set(x_145, 2, x_144); +lean_ctor_set(x_145, 3, x_135); +lean_ctor_set(x_145, 4, x_136); +lean_ctor_set(x_145, 5, x_137); +if (lean_is_scalar(x_34)) { + x_146 = lean_alloc_ctor(1, 2, 0); +} else { + x_146 = x_34; + lean_ctor_set_tag(x_146, 1); +} +lean_ctor_set(x_146, 0, x_132); +lean_ctor_set(x_146, 1, x_145); +return x_146; +} +else +{ +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; +x_147 = lean_ctor_get(x_130, 2); +lean_inc(x_147); +x_148 = lean_ctor_get(x_129, 0); +lean_inc(x_148); +lean_dec(x_129); +x_149 = lean_ctor_get(x_130, 0); +lean_inc(x_149); +x_150 = lean_ctor_get(x_130, 1); +lean_inc(x_150); +x_151 = lean_ctor_get(x_130, 3); +lean_inc(x_151); +x_152 = lean_ctor_get(x_130, 4); +lean_inc(x_152); +x_153 = lean_ctor_get(x_130, 5); +lean_inc(x_153); +if (lean_is_exclusive(x_130)) { + lean_ctor_release(x_130, 0); + lean_ctor_release(x_130, 1); + lean_ctor_release(x_130, 2); + lean_ctor_release(x_130, 3); + lean_ctor_release(x_130, 4); + lean_ctor_release(x_130, 5); + x_154 = x_130; +} else { + lean_dec_ref(x_130); + x_154 = lean_box(0); +} +x_155 = lean_ctor_get(x_147, 0); +lean_inc(x_155); +x_156 = lean_ctor_get(x_147, 1); +lean_inc(x_156); +x_157 = lean_ctor_get(x_147, 3); +lean_inc(x_157); +x_158 = lean_ctor_get(x_147, 4); +lean_inc(x_158); +if (lean_is_exclusive(x_147)) { + lean_ctor_release(x_147, 0); + lean_ctor_release(x_147, 1); + lean_ctor_release(x_147, 2); + lean_ctor_release(x_147, 3); + lean_ctor_release(x_147, 4); + x_159 = x_147; +} else { + lean_dec_ref(x_147); + x_159 = lean_box(0); +} +if (lean_is_scalar(x_159)) { + x_160 = lean_alloc_ctor(0, 5, 0); +} else { + x_160 = x_159; +} +lean_ctor_set(x_160, 0, x_155); +lean_ctor_set(x_160, 1, x_156); +lean_ctor_set(x_160, 2, x_126); +lean_ctor_set(x_160, 3, x_157); +lean_ctor_set(x_160, 4, x_158); +if (lean_is_scalar(x_154)) { + x_161 = lean_alloc_ctor(0, 6, 0); +} else { + x_161 = x_154; +} +lean_ctor_set(x_161, 0, x_149); +lean_ctor_set(x_161, 1, x_150); +lean_ctor_set(x_161, 2, x_160); +lean_ctor_set(x_161, 3, x_151); +lean_ctor_set(x_161, 4, x_152); +lean_ctor_set(x_161, 5, x_153); +if (lean_is_scalar(x_34)) { + x_162 = lean_alloc_ctor(0, 2, 0); +} else { + x_162 = x_34; +} +lean_ctor_set(x_162, 0, x_148); +lean_ctor_set(x_162, 1, x_161); +return x_162; +} +} +} +} +else +{ +lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_229; lean_object* x_230; lean_object* x_231; lean_object* x_232; lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_object* x_236; lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; +x_182 = lean_ctor_get(x_33, 2); +x_183 = lean_ctor_get(x_33, 0); +x_184 = lean_ctor_get(x_33, 1); +x_185 = lean_ctor_get(x_33, 3); +x_186 = lean_ctor_get(x_33, 4); +x_187 = lean_ctor_get(x_33, 5); +lean_inc(x_187); +lean_inc(x_186); +lean_inc(x_185); +lean_inc(x_182); +lean_inc(x_184); +lean_inc(x_183); +lean_dec(x_33); +x_188 = lean_ctor_get(x_182, 0); +lean_inc(x_188); +x_189 = lean_ctor_get(x_182, 1); +lean_inc(x_189); +x_190 = lean_ctor_get(x_182, 2); +lean_inc(x_190); +x_191 = lean_ctor_get(x_182, 3); +lean_inc(x_191); +x_192 = lean_ctor_get(x_182, 4); +lean_inc(x_192); +if (lean_is_exclusive(x_182)) { + lean_ctor_release(x_182, 0); + lean_ctor_release(x_182, 1); + lean_ctor_release(x_182, 2); + lean_ctor_release(x_182, 3); + lean_ctor_release(x_182, 4); + x_193 = x_182; +} else { + lean_dec_ref(x_182); + x_193 = lean_box(0); +} +x_229 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_193)) { x_230 = lean_alloc_ctor(0, 5, 0); } else { - x_230 = x_227; + x_230 = x_193; } -lean_ctor_set(x_230, 0, x_222); -lean_ctor_set(x_230, 1, x_223); +lean_ctor_set(x_230, 0, x_188); +lean_ctor_set(x_230, 1, x_189); lean_ctor_set(x_230, 2, x_229); -lean_ctor_set(x_230, 3, x_225); -lean_ctor_set(x_230, 4, x_226); -x_231 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_37, x_230, x_221); -if (lean_obj_tag(x_231) == 0) -{ -lean_object* x_232; lean_object* x_233; lean_object* x_234; -x_232 = lean_ctor_get(x_231, 0); +lean_ctor_set(x_230, 3, x_191); +lean_ctor_set(x_230, 4, x_192); +x_231 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_231, 0, x_183); +lean_ctor_set(x_231, 1, x_184); +lean_ctor_set(x_231, 2, x_230); +lean_ctor_set(x_231, 3, x_185); +lean_ctor_set(x_231, 4, x_186); +lean_ctor_set(x_231, 5, x_187); +x_232 = lean_ctor_get(x_13, 0); lean_inc(x_232); -x_233 = lean_ctor_get(x_231, 1); +x_233 = lean_ctor_get(x_13, 1); lean_inc(x_233); -lean_dec(x_231); -x_234 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_234, 0, x_232); -x_186 = x_234; -x_187 = x_233; -goto block_218; -} -else -{ -lean_object* x_235; lean_object* x_236; lean_object* x_237; -x_235 = lean_ctor_get(x_231, 0); +x_234 = lean_ctor_get(x_13, 2); +lean_inc(x_234); +x_235 = lean_ctor_get(x_13, 3); lean_inc(x_235); -x_236 = lean_ctor_get(x_231, 1); +x_236 = lean_ctor_get(x_13, 4); lean_inc(x_236); -lean_dec(x_231); -x_237 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_237, 0, x_235); -x_186 = x_237; -x_187 = x_236; -goto block_218; +if (lean_is_exclusive(x_13)) { + lean_ctor_release(x_13, 0); + lean_ctor_release(x_13, 1); + lean_ctor_release(x_13, 2); + lean_ctor_release(x_13, 3); + lean_ctor_release(x_13, 4); + x_237 = x_13; +} else { + lean_dec_ref(x_13); + x_237 = lean_box(0); } -block_218: +x_238 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_238, 0, x_35); +lean_ctor_set(x_238, 1, x_22); +x_239 = lean_array_push(x_234, x_238); +if (lean_is_scalar(x_237)) { + x_240 = lean_alloc_ctor(0, 5, 0); +} else { + x_240 = x_237; +} +lean_ctor_set(x_240, 0, x_232); +lean_ctor_set(x_240, 1, x_233); +lean_ctor_set(x_240, 2, x_239); +lean_ctor_set(x_240, 3, x_235); +lean_ctor_set(x_240, 4, x_236); +x_241 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_37, x_240, x_231); +if (lean_obj_tag(x_241) == 0) { -if (lean_obj_tag(x_186) == 0) -{ -lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; -x_188 = lean_ctor_get(x_187, 2); -lean_inc(x_188); -x_189 = lean_ctor_get(x_186, 0); -lean_inc(x_189); -lean_dec(x_186); -x_190 = lean_ctor_get(x_187, 0); -lean_inc(x_190); -x_191 = lean_ctor_get(x_187, 1); -lean_inc(x_191); -x_192 = lean_ctor_get(x_187, 3); -lean_inc(x_192); -x_193 = lean_ctor_get(x_187, 4); -lean_inc(x_193); -x_194 = lean_ctor_get(x_187, 5); -lean_inc(x_194); -if (lean_is_exclusive(x_187)) { - lean_ctor_release(x_187, 0); - lean_ctor_release(x_187, 1); - lean_ctor_release(x_187, 2); - lean_ctor_release(x_187, 3); - lean_ctor_release(x_187, 4); - lean_ctor_release(x_187, 5); - x_195 = x_187; -} else { - lean_dec_ref(x_187); - x_195 = lean_box(0); -} -x_196 = lean_ctor_get(x_188, 0); -lean_inc(x_196); -x_197 = lean_ctor_get(x_188, 1); -lean_inc(x_197); -x_198 = lean_ctor_get(x_188, 3); -lean_inc(x_198); -if (lean_is_exclusive(x_188)) { - lean_ctor_release(x_188, 0); - lean_ctor_release(x_188, 1); - lean_ctor_release(x_188, 2); - lean_ctor_release(x_188, 3); - x_199 = x_188; -} else { - lean_dec_ref(x_188); - x_199 = lean_box(0); -} -if (lean_is_scalar(x_199)) { - x_200 = lean_alloc_ctor(0, 4, 0); -} else { - x_200 = x_199; -} -lean_ctor_set(x_200, 0, x_196); -lean_ctor_set(x_200, 1, x_197); -lean_ctor_set(x_200, 2, x_183); -lean_ctor_set(x_200, 3, x_198); -if (lean_is_scalar(x_195)) { - x_201 = lean_alloc_ctor(0, 6, 0); -} else { - x_201 = x_195; -} -lean_ctor_set(x_201, 0, x_190); -lean_ctor_set(x_201, 1, x_191); -lean_ctor_set(x_201, 2, x_200); -lean_ctor_set(x_201, 3, x_192); -lean_ctor_set(x_201, 4, x_193); -lean_ctor_set(x_201, 5, x_194); -if (lean_is_scalar(x_34)) { - x_202 = lean_alloc_ctor(1, 2, 0); -} else { - x_202 = x_34; - lean_ctor_set_tag(x_202, 1); -} -lean_ctor_set(x_202, 0, x_189); -lean_ctor_set(x_202, 1, x_201); -return x_202; +lean_object* x_242; lean_object* x_243; lean_object* x_244; +x_242 = lean_ctor_get(x_241, 0); +lean_inc(x_242); +x_243 = lean_ctor_get(x_241, 1); +lean_inc(x_243); +lean_dec(x_241); +x_244 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_244, 0, x_242); +x_194 = x_244; +x_195 = x_243; +goto block_228; } else { -lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; -x_203 = lean_ctor_get(x_187, 2); -lean_inc(x_203); -x_204 = lean_ctor_get(x_186, 0); +lean_object* x_245; lean_object* x_246; lean_object* x_247; +x_245 = lean_ctor_get(x_241, 0); +lean_inc(x_245); +x_246 = lean_ctor_get(x_241, 1); +lean_inc(x_246); +lean_dec(x_241); +x_247 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_247, 0, x_245); +x_194 = x_247; +x_195 = x_246; +goto block_228; +} +block_228: +{ +if (lean_obj_tag(x_194) == 0) +{ +lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; +x_196 = lean_ctor_get(x_195, 2); +lean_inc(x_196); +x_197 = lean_ctor_get(x_194, 0); +lean_inc(x_197); +lean_dec(x_194); +x_198 = lean_ctor_get(x_195, 0); +lean_inc(x_198); +x_199 = lean_ctor_get(x_195, 1); +lean_inc(x_199); +x_200 = lean_ctor_get(x_195, 3); +lean_inc(x_200); +x_201 = lean_ctor_get(x_195, 4); +lean_inc(x_201); +x_202 = lean_ctor_get(x_195, 5); +lean_inc(x_202); +if (lean_is_exclusive(x_195)) { + lean_ctor_release(x_195, 0); + lean_ctor_release(x_195, 1); + lean_ctor_release(x_195, 2); + lean_ctor_release(x_195, 3); + lean_ctor_release(x_195, 4); + lean_ctor_release(x_195, 5); + x_203 = x_195; +} else { + lean_dec_ref(x_195); + x_203 = lean_box(0); +} +x_204 = lean_ctor_get(x_196, 0); lean_inc(x_204); -lean_dec(x_186); -x_205 = lean_ctor_get(x_187, 0); +x_205 = lean_ctor_get(x_196, 1); lean_inc(x_205); -x_206 = lean_ctor_get(x_187, 1); +x_206 = lean_ctor_get(x_196, 3); lean_inc(x_206); -x_207 = lean_ctor_get(x_187, 3); +x_207 = lean_ctor_get(x_196, 4); lean_inc(x_207); -x_208 = lean_ctor_get(x_187, 4); -lean_inc(x_208); -x_209 = lean_ctor_get(x_187, 5); -lean_inc(x_209); -if (lean_is_exclusive(x_187)) { - lean_ctor_release(x_187, 0); - lean_ctor_release(x_187, 1); - lean_ctor_release(x_187, 2); - lean_ctor_release(x_187, 3); - lean_ctor_release(x_187, 4); - lean_ctor_release(x_187, 5); - x_210 = x_187; +if (lean_is_exclusive(x_196)) { + lean_ctor_release(x_196, 0); + lean_ctor_release(x_196, 1); + lean_ctor_release(x_196, 2); + lean_ctor_release(x_196, 3); + lean_ctor_release(x_196, 4); + x_208 = x_196; } else { - lean_dec_ref(x_187); - x_210 = lean_box(0); + lean_dec_ref(x_196); + x_208 = lean_box(0); } -x_211 = lean_ctor_get(x_203, 0); -lean_inc(x_211); -x_212 = lean_ctor_get(x_203, 1); -lean_inc(x_212); -x_213 = lean_ctor_get(x_203, 3); -lean_inc(x_213); -if (lean_is_exclusive(x_203)) { - lean_ctor_release(x_203, 0); - lean_ctor_release(x_203, 1); - lean_ctor_release(x_203, 2); - lean_ctor_release(x_203, 3); - x_214 = x_203; +if (lean_is_scalar(x_208)) { + x_209 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_203); - x_214 = lean_box(0); + x_209 = x_208; } -if (lean_is_scalar(x_214)) { - x_215 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_209, 0, x_204); +lean_ctor_set(x_209, 1, x_205); +lean_ctor_set(x_209, 2, x_190); +lean_ctor_set(x_209, 3, x_206); +lean_ctor_set(x_209, 4, x_207); +if (lean_is_scalar(x_203)) { + x_210 = lean_alloc_ctor(0, 6, 0); } else { - x_215 = x_214; + x_210 = x_203; } -lean_ctor_set(x_215, 0, x_211); -lean_ctor_set(x_215, 1, x_212); -lean_ctor_set(x_215, 2, x_183); -lean_ctor_set(x_215, 3, x_213); -if (lean_is_scalar(x_210)) { - x_216 = lean_alloc_ctor(0, 6, 0); -} else { - x_216 = x_210; -} -lean_ctor_set(x_216, 0, x_205); -lean_ctor_set(x_216, 1, x_206); -lean_ctor_set(x_216, 2, x_215); -lean_ctor_set(x_216, 3, x_207); -lean_ctor_set(x_216, 4, x_208); -lean_ctor_set(x_216, 5, x_209); +lean_ctor_set(x_210, 0, x_198); +lean_ctor_set(x_210, 1, x_199); +lean_ctor_set(x_210, 2, x_209); +lean_ctor_set(x_210, 3, x_200); +lean_ctor_set(x_210, 4, x_201); +lean_ctor_set(x_210, 5, x_202); if (lean_is_scalar(x_34)) { - x_217 = lean_alloc_ctor(0, 2, 0); + x_211 = lean_alloc_ctor(1, 2, 0); } else { - x_217 = x_34; + x_211 = x_34; + lean_ctor_set_tag(x_211, 1); } -lean_ctor_set(x_217, 0, x_204); -lean_ctor_set(x_217, 1, x_216); -return x_217; +lean_ctor_set(x_211, 0, x_197); +lean_ctor_set(x_211, 1, x_210); +return x_211; +} +else +{ +lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; lean_object* x_224; lean_object* x_225; lean_object* x_226; lean_object* x_227; +x_212 = lean_ctor_get(x_195, 2); +lean_inc(x_212); +x_213 = lean_ctor_get(x_194, 0); +lean_inc(x_213); +lean_dec(x_194); +x_214 = lean_ctor_get(x_195, 0); +lean_inc(x_214); +x_215 = lean_ctor_get(x_195, 1); +lean_inc(x_215); +x_216 = lean_ctor_get(x_195, 3); +lean_inc(x_216); +x_217 = lean_ctor_get(x_195, 4); +lean_inc(x_217); +x_218 = lean_ctor_get(x_195, 5); +lean_inc(x_218); +if (lean_is_exclusive(x_195)) { + lean_ctor_release(x_195, 0); + lean_ctor_release(x_195, 1); + lean_ctor_release(x_195, 2); + lean_ctor_release(x_195, 3); + lean_ctor_release(x_195, 4); + lean_ctor_release(x_195, 5); + x_219 = x_195; +} else { + lean_dec_ref(x_195); + x_219 = lean_box(0); +} +x_220 = lean_ctor_get(x_212, 0); +lean_inc(x_220); +x_221 = lean_ctor_get(x_212, 1); +lean_inc(x_221); +x_222 = lean_ctor_get(x_212, 3); +lean_inc(x_222); +x_223 = lean_ctor_get(x_212, 4); +lean_inc(x_223); +if (lean_is_exclusive(x_212)) { + lean_ctor_release(x_212, 0); + lean_ctor_release(x_212, 1); + lean_ctor_release(x_212, 2); + lean_ctor_release(x_212, 3); + lean_ctor_release(x_212, 4); + x_224 = x_212; +} else { + lean_dec_ref(x_212); + x_224 = lean_box(0); +} +if (lean_is_scalar(x_224)) { + x_225 = lean_alloc_ctor(0, 5, 0); +} else { + x_225 = x_224; +} +lean_ctor_set(x_225, 0, x_220); +lean_ctor_set(x_225, 1, x_221); +lean_ctor_set(x_225, 2, x_190); +lean_ctor_set(x_225, 3, x_222); +lean_ctor_set(x_225, 4, x_223); +if (lean_is_scalar(x_219)) { + x_226 = lean_alloc_ctor(0, 6, 0); +} else { + x_226 = x_219; +} +lean_ctor_set(x_226, 0, x_214); +lean_ctor_set(x_226, 1, x_215); +lean_ctor_set(x_226, 2, x_225); +lean_ctor_set(x_226, 3, x_216); +lean_ctor_set(x_226, 4, x_217); +lean_ctor_set(x_226, 5, x_218); +if (lean_is_scalar(x_34)) { + x_227 = lean_alloc_ctor(0, 2, 0); +} else { + x_227 = x_34; +} +lean_ctor_set(x_227, 0, x_213); +lean_ctor_set(x_227, 1, x_226); +return x_227; } } } } default: { -lean_object* x_238; lean_object* x_239; -x_238 = lean_ctor_get(x_27, 1); -lean_inc(x_238); +lean_object* x_248; lean_object* x_249; +x_248 = lean_ctor_get(x_27, 1); +lean_inc(x_248); lean_dec(x_27); lean_inc(x_13); -x_239 = l_Lean_Meta_isClassExpensive___main(x_26, x_13, x_238); -if (lean_obj_tag(x_239) == 0) +x_249 = l_Lean_Meta_isClassExpensive___main(x_26, x_13, x_248); +if (lean_obj_tag(x_249) == 0) { -lean_object* x_240; -x_240 = lean_ctor_get(x_239, 0); -lean_inc(x_240); -if (lean_obj_tag(x_240) == 0) +lean_object* x_250; +x_250 = lean_ctor_get(x_249, 0); +lean_inc(x_250); +if (lean_obj_tag(x_250) == 0) { -lean_object* x_241; lean_object* x_242; lean_object* x_243; +lean_object* x_251; lean_object* x_252; lean_object* x_253; lean_dec(x_22); -x_241 = lean_ctor_get(x_239, 1); -lean_inc(x_241); -lean_dec(x_239); -x_242 = lean_unsigned_to_nat(1u); -x_243 = lean_nat_add(x_12, x_242); +x_251 = lean_ctor_get(x_249, 1); +lean_inc(x_251); +lean_dec(x_249); +x_252 = lean_unsigned_to_nat(1u); +x_253 = lean_nat_add(x_12, x_252); lean_dec(x_12); -x_12 = x_243; -x_14 = x_241; +x_12 = x_253; +x_14 = x_251; goto _start; } else { -lean_object* x_245; lean_object* x_246; lean_object* x_247; lean_object* x_248; lean_object* x_249; uint8_t x_250; -x_245 = lean_ctor_get(x_239, 1); -lean_inc(x_245); -if (lean_is_exclusive(x_239)) { - lean_ctor_release(x_239, 0); - lean_ctor_release(x_239, 1); - x_246 = x_239; +lean_object* x_255; lean_object* x_256; lean_object* x_257; lean_object* x_258; lean_object* x_259; uint8_t x_260; +x_255 = lean_ctor_get(x_249, 1); +lean_inc(x_255); +if (lean_is_exclusive(x_249)) { + lean_ctor_release(x_249, 0); + lean_ctor_release(x_249, 1); + x_256 = x_249; } else { - lean_dec_ref(x_239); - x_246 = lean_box(0); + lean_dec_ref(x_249); + x_256 = lean_box(0); } -x_247 = lean_ctor_get(x_240, 0); -lean_inc(x_247); -lean_dec(x_240); -x_248 = lean_unsigned_to_nat(1u); -x_249 = lean_nat_add(x_12, x_248); -lean_dec(x_12); -x_250 = !lean_is_exclusive(x_245); -if (x_250 == 0) -{ -lean_object* x_251; uint8_t x_252; -x_251 = lean_ctor_get(x_245, 2); -x_252 = !lean_is_exclusive(x_251); -if (x_252 == 0) -{ -lean_object* x_253; lean_object* x_254; lean_object* x_255; lean_object* x_305; uint8_t x_306; -x_253 = lean_ctor_get(x_251, 2); -x_305 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_251, 2, x_305); -x_306 = !lean_is_exclusive(x_13); -if (x_306 == 0) -{ -lean_object* x_307; lean_object* x_308; lean_object* x_309; lean_object* x_310; -x_307 = lean_ctor_get(x_13, 2); -x_308 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_308, 0, x_247); -lean_ctor_set(x_308, 1, x_22); -x_309 = lean_array_push(x_307, x_308); -lean_ctor_set(x_13, 2, x_309); -x_310 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_249, x_13, x_245); -if (lean_obj_tag(x_310) == 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); -x_313 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_313, 0, x_311); -x_254 = x_313; -x_255 = x_312; -goto block_304; -} -else -{ -lean_object* x_314; lean_object* x_315; lean_object* x_316; -x_314 = lean_ctor_get(x_310, 0); -lean_inc(x_314); -x_315 = lean_ctor_get(x_310, 1); -lean_inc(x_315); -lean_dec(x_310); -x_316 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_316, 0, x_314); -x_254 = x_316; -x_255 = x_315; -goto block_304; -} -} -else -{ -lean_object* x_317; lean_object* x_318; lean_object* x_319; lean_object* x_320; lean_object* x_321; lean_object* x_322; lean_object* x_323; lean_object* x_324; lean_object* x_325; -x_317 = lean_ctor_get(x_13, 0); -x_318 = lean_ctor_get(x_13, 1); -x_319 = lean_ctor_get(x_13, 2); -x_320 = lean_ctor_get(x_13, 3); -x_321 = lean_ctor_get(x_13, 4); -lean_inc(x_321); -lean_inc(x_320); -lean_inc(x_319); -lean_inc(x_318); -lean_inc(x_317); -lean_dec(x_13); -x_322 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_322, 0, x_247); -lean_ctor_set(x_322, 1, x_22); -x_323 = lean_array_push(x_319, x_322); -x_324 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_324, 0, x_317); -lean_ctor_set(x_324, 1, x_318); -lean_ctor_set(x_324, 2, x_323); -lean_ctor_set(x_324, 3, x_320); -lean_ctor_set(x_324, 4, x_321); -x_325 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_249, x_324, x_245); -if (lean_obj_tag(x_325) == 0) -{ -lean_object* x_326; lean_object* x_327; lean_object* x_328; -x_326 = lean_ctor_get(x_325, 0); -lean_inc(x_326); -x_327 = lean_ctor_get(x_325, 1); -lean_inc(x_327); -lean_dec(x_325); -x_328 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_328, 0, x_326); -x_254 = x_328; -x_255 = x_327; -goto block_304; -} -else -{ -lean_object* x_329; lean_object* x_330; lean_object* x_331; -x_329 = lean_ctor_get(x_325, 0); -lean_inc(x_329); -x_330 = lean_ctor_get(x_325, 1); -lean_inc(x_330); -lean_dec(x_325); -x_331 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_331, 0, x_329); -x_254 = x_331; -x_255 = x_330; -goto block_304; -} -} -block_304: -{ -if (lean_obj_tag(x_254) == 0) -{ -lean_object* x_256; lean_object* x_257; uint8_t x_258; -x_256 = lean_ctor_get(x_255, 2); -lean_inc(x_256); -x_257 = lean_ctor_get(x_254, 0); +x_257 = lean_ctor_get(x_250, 0); lean_inc(x_257); -lean_dec(x_254); -x_258 = !lean_is_exclusive(x_255); -if (x_258 == 0) -{ -lean_object* x_259; uint8_t x_260; -x_259 = lean_ctor_get(x_255, 2); -lean_dec(x_259); -x_260 = !lean_is_exclusive(x_256); +lean_dec(x_250); +x_258 = lean_unsigned_to_nat(1u); +x_259 = lean_nat_add(x_12, x_258); +lean_dec(x_12); +x_260 = !lean_is_exclusive(x_255); if (x_260 == 0) { -lean_object* x_261; lean_object* x_262; -x_261 = lean_ctor_get(x_256, 2); -lean_dec(x_261); -lean_ctor_set(x_256, 2, x_253); -if (lean_is_scalar(x_246)) { - x_262 = lean_alloc_ctor(1, 2, 0); -} else { - x_262 = x_246; - lean_ctor_set_tag(x_262, 1); -} -lean_ctor_set(x_262, 0, x_257); -lean_ctor_set(x_262, 1, x_255); -return x_262; +lean_object* x_261; uint8_t x_262; +x_261 = lean_ctor_get(x_255, 2); +x_262 = !lean_is_exclusive(x_261); +if (x_262 == 0) +{ +lean_object* x_263; lean_object* x_264; lean_object* x_265; lean_object* x_319; uint8_t x_320; +x_263 = lean_ctor_get(x_261, 2); +x_319 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_261, 2, x_319); +x_320 = !lean_is_exclusive(x_13); +if (x_320 == 0) +{ +lean_object* x_321; lean_object* x_322; lean_object* x_323; lean_object* x_324; +x_321 = lean_ctor_get(x_13, 2); +x_322 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_322, 0, x_257); +lean_ctor_set(x_322, 1, x_22); +x_323 = lean_array_push(x_321, x_322); +lean_ctor_set(x_13, 2, x_323); +x_324 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_259, x_13, x_255); +if (lean_obj_tag(x_324) == 0) +{ +lean_object* x_325; lean_object* x_326; lean_object* x_327; +x_325 = lean_ctor_get(x_324, 0); +lean_inc(x_325); +x_326 = lean_ctor_get(x_324, 1); +lean_inc(x_326); +lean_dec(x_324); +x_327 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_327, 0, x_325); +x_264 = x_327; +x_265 = x_326; +goto block_318; } 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_256, 0); -x_264 = lean_ctor_get(x_256, 1); -x_265 = lean_ctor_get(x_256, 3); -lean_inc(x_265); -lean_inc(x_264); -lean_inc(x_263); -lean_dec(x_256); -x_266 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_266, 0, x_263); -lean_ctor_set(x_266, 1, x_264); -lean_ctor_set(x_266, 2, x_253); -lean_ctor_set(x_266, 3, x_265); -lean_ctor_set(x_255, 2, x_266); -if (lean_is_scalar(x_246)) { - x_267 = lean_alloc_ctor(1, 2, 0); -} else { - x_267 = x_246; - lean_ctor_set_tag(x_267, 1); -} -lean_ctor_set(x_267, 0, x_257); -lean_ctor_set(x_267, 1, x_255); -return x_267; +lean_object* x_328; lean_object* x_329; lean_object* x_330; +x_328 = lean_ctor_get(x_324, 0); +lean_inc(x_328); +x_329 = lean_ctor_get(x_324, 1); +lean_inc(x_329); +lean_dec(x_324); +x_330 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_330, 0, x_328); +x_264 = x_330; +x_265 = x_329; +goto block_318; } } else { -lean_object* x_268; lean_object* x_269; lean_object* x_270; lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_object* x_276; lean_object* x_277; lean_object* x_278; lean_object* x_279; -x_268 = lean_ctor_get(x_255, 0); -x_269 = lean_ctor_get(x_255, 1); -x_270 = lean_ctor_get(x_255, 3); -x_271 = lean_ctor_get(x_255, 4); -x_272 = lean_ctor_get(x_255, 5); -lean_inc(x_272); -lean_inc(x_271); -lean_inc(x_270); -lean_inc(x_269); -lean_inc(x_268); -lean_dec(x_255); -x_273 = lean_ctor_get(x_256, 0); -lean_inc(x_273); -x_274 = lean_ctor_get(x_256, 1); -lean_inc(x_274); -x_275 = lean_ctor_get(x_256, 3); +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; lean_object* x_339; +x_331 = lean_ctor_get(x_13, 0); +x_332 = lean_ctor_get(x_13, 1); +x_333 = lean_ctor_get(x_13, 2); +x_334 = lean_ctor_get(x_13, 3); +x_335 = lean_ctor_get(x_13, 4); +lean_inc(x_335); +lean_inc(x_334); +lean_inc(x_333); +lean_inc(x_332); +lean_inc(x_331); +lean_dec(x_13); +x_336 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_336, 0, x_257); +lean_ctor_set(x_336, 1, x_22); +x_337 = lean_array_push(x_333, x_336); +x_338 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_338, 0, x_331); +lean_ctor_set(x_338, 1, x_332); +lean_ctor_set(x_338, 2, x_337); +lean_ctor_set(x_338, 3, x_334); +lean_ctor_set(x_338, 4, x_335); +x_339 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_259, x_338, x_255); +if (lean_obj_tag(x_339) == 0) +{ +lean_object* x_340; lean_object* x_341; lean_object* x_342; +x_340 = lean_ctor_get(x_339, 0); +lean_inc(x_340); +x_341 = lean_ctor_get(x_339, 1); +lean_inc(x_341); +lean_dec(x_339); +x_342 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_342, 0, x_340); +x_264 = x_342; +x_265 = x_341; +goto block_318; +} +else +{ +lean_object* x_343; lean_object* x_344; lean_object* x_345; +x_343 = lean_ctor_get(x_339, 0); +lean_inc(x_343); +x_344 = lean_ctor_get(x_339, 1); +lean_inc(x_344); +lean_dec(x_339); +x_345 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_345, 0, x_343); +x_264 = x_345; +x_265 = x_344; +goto block_318; +} +} +block_318: +{ +if (lean_obj_tag(x_264) == 0) +{ +lean_object* x_266; lean_object* x_267; uint8_t x_268; +x_266 = lean_ctor_get(x_265, 2); +lean_inc(x_266); +x_267 = lean_ctor_get(x_264, 0); +lean_inc(x_267); +lean_dec(x_264); +x_268 = !lean_is_exclusive(x_265); +if (x_268 == 0) +{ +lean_object* x_269; uint8_t x_270; +x_269 = lean_ctor_get(x_265, 2); +lean_dec(x_269); +x_270 = !lean_is_exclusive(x_266); +if (x_270 == 0) +{ +lean_object* x_271; lean_object* x_272; +x_271 = lean_ctor_get(x_266, 2); +lean_dec(x_271); +lean_ctor_set(x_266, 2, x_263); +if (lean_is_scalar(x_256)) { + x_272 = lean_alloc_ctor(1, 2, 0); +} else { + x_272 = x_256; + lean_ctor_set_tag(x_272, 1); +} +lean_ctor_set(x_272, 0, x_267); +lean_ctor_set(x_272, 1, x_265); +return x_272; +} +else +{ +lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_object* x_276; lean_object* x_277; lean_object* x_278; +x_273 = lean_ctor_get(x_266, 0); +x_274 = lean_ctor_get(x_266, 1); +x_275 = lean_ctor_get(x_266, 3); +x_276 = lean_ctor_get(x_266, 4); +lean_inc(x_276); lean_inc(x_275); -if (lean_is_exclusive(x_256)) { - lean_ctor_release(x_256, 0); - lean_ctor_release(x_256, 1); - lean_ctor_release(x_256, 2); - lean_ctor_release(x_256, 3); - x_276 = x_256; -} else { - lean_dec_ref(x_256); - x_276 = lean_box(0); -} -if (lean_is_scalar(x_276)) { - x_277 = lean_alloc_ctor(0, 4, 0); -} else { - x_277 = x_276; -} +lean_inc(x_274); +lean_inc(x_273); +lean_dec(x_266); +x_277 = lean_alloc_ctor(0, 5, 0); lean_ctor_set(x_277, 0, x_273); lean_ctor_set(x_277, 1, x_274); -lean_ctor_set(x_277, 2, x_253); +lean_ctor_set(x_277, 2, x_263); lean_ctor_set(x_277, 3, x_275); -x_278 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_278, 0, x_268); -lean_ctor_set(x_278, 1, x_269); -lean_ctor_set(x_278, 2, x_277); -lean_ctor_set(x_278, 3, x_270); -lean_ctor_set(x_278, 4, x_271); -lean_ctor_set(x_278, 5, x_272); -if (lean_is_scalar(x_246)) { - x_279 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_277, 4, x_276); +lean_ctor_set(x_265, 2, x_277); +if (lean_is_scalar(x_256)) { + x_278 = lean_alloc_ctor(1, 2, 0); } else { - x_279 = x_246; - lean_ctor_set_tag(x_279, 1); + x_278 = x_256; + lean_ctor_set_tag(x_278, 1); } -lean_ctor_set(x_279, 0, x_257); -lean_ctor_set(x_279, 1, x_278); -return x_279; +lean_ctor_set(x_278, 0, x_267); +lean_ctor_set(x_278, 1, x_265); +return x_278; } } else { -lean_object* x_280; lean_object* x_281; uint8_t x_282; -x_280 = lean_ctor_get(x_255, 2); -lean_inc(x_280); -x_281 = lean_ctor_get(x_254, 0); +lean_object* x_279; lean_object* x_280; lean_object* x_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; lean_object* x_289; lean_object* x_290; lean_object* x_291; +x_279 = lean_ctor_get(x_265, 0); +x_280 = lean_ctor_get(x_265, 1); +x_281 = lean_ctor_get(x_265, 3); +x_282 = lean_ctor_get(x_265, 4); +x_283 = lean_ctor_get(x_265, 5); +lean_inc(x_283); +lean_inc(x_282); lean_inc(x_281); -lean_dec(x_254); -x_282 = !lean_is_exclusive(x_255); -if (x_282 == 0) -{ -lean_object* x_283; uint8_t x_284; -x_283 = lean_ctor_get(x_255, 2); -lean_dec(x_283); -x_284 = !lean_is_exclusive(x_280); -if (x_284 == 0) -{ -lean_object* x_285; lean_object* x_286; -x_285 = lean_ctor_get(x_280, 2); -lean_dec(x_285); -lean_ctor_set(x_280, 2, x_253); -if (lean_is_scalar(x_246)) { - x_286 = lean_alloc_ctor(0, 2, 0); -} else { - x_286 = x_246; -} -lean_ctor_set(x_286, 0, x_281); -lean_ctor_set(x_286, 1, x_255); -return x_286; -} -else -{ -lean_object* x_287; lean_object* x_288; lean_object* x_289; lean_object* x_290; lean_object* x_291; -x_287 = lean_ctor_get(x_280, 0); -x_288 = lean_ctor_get(x_280, 1); -x_289 = lean_ctor_get(x_280, 3); -lean_inc(x_289); -lean_inc(x_288); +lean_inc(x_280); +lean_inc(x_279); +lean_dec(x_265); +x_284 = lean_ctor_get(x_266, 0); +lean_inc(x_284); +x_285 = lean_ctor_get(x_266, 1); +lean_inc(x_285); +x_286 = lean_ctor_get(x_266, 3); +lean_inc(x_286); +x_287 = lean_ctor_get(x_266, 4); lean_inc(x_287); -lean_dec(x_280); -x_290 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_290, 0, x_287); -lean_ctor_set(x_290, 1, x_288); -lean_ctor_set(x_290, 2, x_253); -lean_ctor_set(x_290, 3, x_289); -lean_ctor_set(x_255, 2, x_290); -if (lean_is_scalar(x_246)) { - x_291 = lean_alloc_ctor(0, 2, 0); +if (lean_is_exclusive(x_266)) { + lean_ctor_release(x_266, 0); + lean_ctor_release(x_266, 1); + lean_ctor_release(x_266, 2); + lean_ctor_release(x_266, 3); + lean_ctor_release(x_266, 4); + x_288 = x_266; } else { - x_291 = x_246; + lean_dec_ref(x_266); + x_288 = lean_box(0); } -lean_ctor_set(x_291, 0, x_281); -lean_ctor_set(x_291, 1, x_255); +if (lean_is_scalar(x_288)) { + x_289 = lean_alloc_ctor(0, 5, 0); +} else { + x_289 = x_288; +} +lean_ctor_set(x_289, 0, x_284); +lean_ctor_set(x_289, 1, x_285); +lean_ctor_set(x_289, 2, x_263); +lean_ctor_set(x_289, 3, x_286); +lean_ctor_set(x_289, 4, x_287); +x_290 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_290, 0, x_279); +lean_ctor_set(x_290, 1, x_280); +lean_ctor_set(x_290, 2, x_289); +lean_ctor_set(x_290, 3, x_281); +lean_ctor_set(x_290, 4, x_282); +lean_ctor_set(x_290, 5, x_283); +if (lean_is_scalar(x_256)) { + x_291 = lean_alloc_ctor(1, 2, 0); +} else { + x_291 = x_256; + lean_ctor_set_tag(x_291, 1); +} +lean_ctor_set(x_291, 0, x_267); +lean_ctor_set(x_291, 1, x_290); return x_291; } } else { -lean_object* x_292; lean_object* x_293; lean_object* x_294; lean_object* x_295; lean_object* x_296; lean_object* x_297; lean_object* x_298; lean_object* x_299; lean_object* x_300; lean_object* x_301; lean_object* x_302; lean_object* x_303; -x_292 = lean_ctor_get(x_255, 0); -x_293 = lean_ctor_get(x_255, 1); -x_294 = lean_ctor_get(x_255, 3); -x_295 = lean_ctor_get(x_255, 4); -x_296 = lean_ctor_get(x_255, 5); -lean_inc(x_296); -lean_inc(x_295); -lean_inc(x_294); -lean_inc(x_293); +lean_object* x_292; lean_object* x_293; uint8_t x_294; +x_292 = lean_ctor_get(x_265, 2); lean_inc(x_292); -lean_dec(x_255); -x_297 = lean_ctor_get(x_280, 0); -lean_inc(x_297); -x_298 = lean_ctor_get(x_280, 1); -lean_inc(x_298); -x_299 = lean_ctor_get(x_280, 3); +x_293 = lean_ctor_get(x_264, 0); +lean_inc(x_293); +lean_dec(x_264); +x_294 = !lean_is_exclusive(x_265); +if (x_294 == 0) +{ +lean_object* x_295; uint8_t x_296; +x_295 = lean_ctor_get(x_265, 2); +lean_dec(x_295); +x_296 = !lean_is_exclusive(x_292); +if (x_296 == 0) +{ +lean_object* x_297; lean_object* x_298; +x_297 = lean_ctor_get(x_292, 2); +lean_dec(x_297); +lean_ctor_set(x_292, 2, x_263); +if (lean_is_scalar(x_256)) { + x_298 = lean_alloc_ctor(0, 2, 0); +} else { + x_298 = x_256; +} +lean_ctor_set(x_298, 0, x_293); +lean_ctor_set(x_298, 1, x_265); +return x_298; +} +else +{ +lean_object* x_299; lean_object* x_300; lean_object* x_301; lean_object* x_302; lean_object* x_303; lean_object* x_304; +x_299 = lean_ctor_get(x_292, 0); +x_300 = lean_ctor_get(x_292, 1); +x_301 = lean_ctor_get(x_292, 3); +x_302 = lean_ctor_get(x_292, 4); +lean_inc(x_302); +lean_inc(x_301); +lean_inc(x_300); lean_inc(x_299); -if (lean_is_exclusive(x_280)) { - lean_ctor_release(x_280, 0); - lean_ctor_release(x_280, 1); - lean_ctor_release(x_280, 2); - lean_ctor_release(x_280, 3); - x_300 = x_280; +lean_dec(x_292); +x_303 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_303, 0, x_299); +lean_ctor_set(x_303, 1, x_300); +lean_ctor_set(x_303, 2, x_263); +lean_ctor_set(x_303, 3, x_301); +lean_ctor_set(x_303, 4, x_302); +lean_ctor_set(x_265, 2, x_303); +if (lean_is_scalar(x_256)) { + x_304 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_280); - x_300 = lean_box(0); + x_304 = x_256; } -if (lean_is_scalar(x_300)) { - x_301 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_304, 0, x_293); +lean_ctor_set(x_304, 1, x_265); +return x_304; +} +} +else +{ +lean_object* x_305; lean_object* x_306; lean_object* x_307; lean_object* x_308; lean_object* x_309; lean_object* x_310; lean_object* x_311; lean_object* x_312; lean_object* x_313; lean_object* x_314; lean_object* x_315; lean_object* x_316; lean_object* x_317; +x_305 = lean_ctor_get(x_265, 0); +x_306 = lean_ctor_get(x_265, 1); +x_307 = lean_ctor_get(x_265, 3); +x_308 = lean_ctor_get(x_265, 4); +x_309 = lean_ctor_get(x_265, 5); +lean_inc(x_309); +lean_inc(x_308); +lean_inc(x_307); +lean_inc(x_306); +lean_inc(x_305); +lean_dec(x_265); +x_310 = lean_ctor_get(x_292, 0); +lean_inc(x_310); +x_311 = lean_ctor_get(x_292, 1); +lean_inc(x_311); +x_312 = lean_ctor_get(x_292, 3); +lean_inc(x_312); +x_313 = lean_ctor_get(x_292, 4); +lean_inc(x_313); +if (lean_is_exclusive(x_292)) { + lean_ctor_release(x_292, 0); + lean_ctor_release(x_292, 1); + lean_ctor_release(x_292, 2); + lean_ctor_release(x_292, 3); + lean_ctor_release(x_292, 4); + x_314 = x_292; } else { - x_301 = x_300; + lean_dec_ref(x_292); + x_314 = lean_box(0); } -lean_ctor_set(x_301, 0, x_297); -lean_ctor_set(x_301, 1, x_298); -lean_ctor_set(x_301, 2, x_253); -lean_ctor_set(x_301, 3, x_299); -x_302 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_302, 0, x_292); -lean_ctor_set(x_302, 1, x_293); -lean_ctor_set(x_302, 2, x_301); -lean_ctor_set(x_302, 3, x_294); -lean_ctor_set(x_302, 4, x_295); -lean_ctor_set(x_302, 5, x_296); -if (lean_is_scalar(x_246)) { - x_303 = lean_alloc_ctor(0, 2, 0); +if (lean_is_scalar(x_314)) { + x_315 = lean_alloc_ctor(0, 5, 0); } else { - x_303 = x_246; + x_315 = x_314; } -lean_ctor_set(x_303, 0, x_281); -lean_ctor_set(x_303, 1, x_302); -return x_303; +lean_ctor_set(x_315, 0, x_310); +lean_ctor_set(x_315, 1, x_311); +lean_ctor_set(x_315, 2, x_263); +lean_ctor_set(x_315, 3, x_312); +lean_ctor_set(x_315, 4, x_313); +x_316 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_316, 0, x_305); +lean_ctor_set(x_316, 1, x_306); +lean_ctor_set(x_316, 2, x_315); +lean_ctor_set(x_316, 3, x_307); +lean_ctor_set(x_316, 4, x_308); +lean_ctor_set(x_316, 5, x_309); +if (lean_is_scalar(x_256)) { + x_317 = lean_alloc_ctor(0, 2, 0); +} else { + x_317 = x_256; +} +lean_ctor_set(x_317, 0, x_293); +lean_ctor_set(x_317, 1, x_316); +return x_317; } } } } else { -lean_object* x_332; lean_object* x_333; lean_object* x_334; lean_object* x_335; lean_object* x_336; lean_object* x_337; lean_object* x_369; lean_object* x_370; lean_object* x_371; lean_object* x_372; lean_object* x_373; lean_object* x_374; lean_object* x_375; lean_object* x_376; lean_object* x_377; lean_object* x_378; lean_object* x_379; lean_object* x_380; -x_332 = lean_ctor_get(x_251, 0); -x_333 = lean_ctor_get(x_251, 1); -x_334 = lean_ctor_get(x_251, 2); -x_335 = lean_ctor_get(x_251, 3); -lean_inc(x_335); -lean_inc(x_334); -lean_inc(x_333); -lean_inc(x_332); -lean_dec(x_251); -x_369 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_370 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_370, 0, x_332); -lean_ctor_set(x_370, 1, x_333); -lean_ctor_set(x_370, 2, x_369); -lean_ctor_set(x_370, 3, x_335); -lean_ctor_set(x_245, 2, x_370); -x_371 = lean_ctor_get(x_13, 0); -lean_inc(x_371); -x_372 = lean_ctor_get(x_13, 1); -lean_inc(x_372); -x_373 = lean_ctor_get(x_13, 2); -lean_inc(x_373); -x_374 = lean_ctor_get(x_13, 3); -lean_inc(x_374); -x_375 = lean_ctor_get(x_13, 4); -lean_inc(x_375); +lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; lean_object* x_350; lean_object* x_351; lean_object* x_352; lean_object* x_386; lean_object* x_387; lean_object* x_388; lean_object* x_389; lean_object* x_390; lean_object* x_391; lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; +x_346 = lean_ctor_get(x_261, 0); +x_347 = lean_ctor_get(x_261, 1); +x_348 = lean_ctor_get(x_261, 2); +x_349 = lean_ctor_get(x_261, 3); +x_350 = lean_ctor_get(x_261, 4); +lean_inc(x_350); +lean_inc(x_349); +lean_inc(x_348); +lean_inc(x_347); +lean_inc(x_346); +lean_dec(x_261); +x_386 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_387 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_387, 0, x_346); +lean_ctor_set(x_387, 1, x_347); +lean_ctor_set(x_387, 2, x_386); +lean_ctor_set(x_387, 3, x_349); +lean_ctor_set(x_387, 4, x_350); +lean_ctor_set(x_255, 2, x_387); +x_388 = lean_ctor_get(x_13, 0); +lean_inc(x_388); +x_389 = lean_ctor_get(x_13, 1); +lean_inc(x_389); +x_390 = lean_ctor_get(x_13, 2); +lean_inc(x_390); +x_391 = lean_ctor_get(x_13, 3); +lean_inc(x_391); +x_392 = lean_ctor_get(x_13, 4); +lean_inc(x_392); if (lean_is_exclusive(x_13)) { lean_ctor_release(x_13, 0); lean_ctor_release(x_13, 1); lean_ctor_release(x_13, 2); lean_ctor_release(x_13, 3); lean_ctor_release(x_13, 4); - x_376 = x_13; + x_393 = x_13; } else { lean_dec_ref(x_13); - x_376 = lean_box(0); + x_393 = lean_box(0); } -x_377 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_377, 0, x_247); -lean_ctor_set(x_377, 1, x_22); -x_378 = lean_array_push(x_373, x_377); -if (lean_is_scalar(x_376)) { - x_379 = lean_alloc_ctor(0, 5, 0); +x_394 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_394, 0, x_257); +lean_ctor_set(x_394, 1, x_22); +x_395 = lean_array_push(x_390, x_394); +if (lean_is_scalar(x_393)) { + x_396 = lean_alloc_ctor(0, 5, 0); } else { - x_379 = x_376; + x_396 = x_393; } -lean_ctor_set(x_379, 0, x_371); -lean_ctor_set(x_379, 1, x_372); -lean_ctor_set(x_379, 2, x_378); -lean_ctor_set(x_379, 3, x_374); -lean_ctor_set(x_379, 4, x_375); -x_380 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_249, x_379, x_245); -if (lean_obj_tag(x_380) == 0) +lean_ctor_set(x_396, 0, x_388); +lean_ctor_set(x_396, 1, x_389); +lean_ctor_set(x_396, 2, x_395); +lean_ctor_set(x_396, 3, x_391); +lean_ctor_set(x_396, 4, x_392); +x_397 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_259, x_396, x_255); +if (lean_obj_tag(x_397) == 0) { -lean_object* x_381; lean_object* x_382; lean_object* x_383; -x_381 = lean_ctor_get(x_380, 0); -lean_inc(x_381); -x_382 = lean_ctor_get(x_380, 1); -lean_inc(x_382); -lean_dec(x_380); -x_383 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_383, 0, x_381); -x_336 = x_383; -x_337 = x_382; -goto block_368; +lean_object* x_398; lean_object* x_399; lean_object* x_400; +x_398 = lean_ctor_get(x_397, 0); +lean_inc(x_398); +x_399 = lean_ctor_get(x_397, 1); +lean_inc(x_399); +lean_dec(x_397); +x_400 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_400, 0, x_398); +x_351 = x_400; +x_352 = x_399; +goto block_385; } else { -lean_object* x_384; lean_object* x_385; lean_object* x_386; -x_384 = lean_ctor_get(x_380, 0); -lean_inc(x_384); -x_385 = lean_ctor_get(x_380, 1); -lean_inc(x_385); -lean_dec(x_380); -x_386 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_386, 0, x_384); -x_336 = x_386; -x_337 = x_385; -goto block_368; +lean_object* x_401; lean_object* x_402; lean_object* x_403; +x_401 = lean_ctor_get(x_397, 0); +lean_inc(x_401); +x_402 = lean_ctor_get(x_397, 1); +lean_inc(x_402); +lean_dec(x_397); +x_403 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_403, 0, x_401); +x_351 = x_403; +x_352 = x_402; +goto block_385; } -block_368: +block_385: { -if (lean_obj_tag(x_336) == 0) +if (lean_obj_tag(x_351) == 0) { -lean_object* x_338; lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; lean_object* x_350; lean_object* x_351; lean_object* x_352; -x_338 = lean_ctor_get(x_337, 2); -lean_inc(x_338); -x_339 = lean_ctor_get(x_336, 0); -lean_inc(x_339); -lean_dec(x_336); -x_340 = lean_ctor_get(x_337, 0); -lean_inc(x_340); -x_341 = lean_ctor_get(x_337, 1); -lean_inc(x_341); -x_342 = lean_ctor_get(x_337, 3); -lean_inc(x_342); -x_343 = lean_ctor_get(x_337, 4); -lean_inc(x_343); -x_344 = lean_ctor_get(x_337, 5); -lean_inc(x_344); -if (lean_is_exclusive(x_337)) { - lean_ctor_release(x_337, 0); - lean_ctor_release(x_337, 1); - lean_ctor_release(x_337, 2); - lean_ctor_release(x_337, 3); - lean_ctor_release(x_337, 4); - lean_ctor_release(x_337, 5); - x_345 = x_337; -} else { - lean_dec_ref(x_337); - x_345 = lean_box(0); -} -x_346 = lean_ctor_get(x_338, 0); -lean_inc(x_346); -x_347 = lean_ctor_get(x_338, 1); -lean_inc(x_347); -x_348 = lean_ctor_get(x_338, 3); -lean_inc(x_348); -if (lean_is_exclusive(x_338)) { - lean_ctor_release(x_338, 0); - lean_ctor_release(x_338, 1); - lean_ctor_release(x_338, 2); - lean_ctor_release(x_338, 3); - x_349 = x_338; -} else { - lean_dec_ref(x_338); - x_349 = lean_box(0); -} -if (lean_is_scalar(x_349)) { - x_350 = lean_alloc_ctor(0, 4, 0); -} else { - x_350 = x_349; -} -lean_ctor_set(x_350, 0, x_346); -lean_ctor_set(x_350, 1, x_347); -lean_ctor_set(x_350, 2, x_334); -lean_ctor_set(x_350, 3, x_348); -if (lean_is_scalar(x_345)) { - x_351 = lean_alloc_ctor(0, 6, 0); -} else { - x_351 = x_345; -} -lean_ctor_set(x_351, 0, x_340); -lean_ctor_set(x_351, 1, x_341); -lean_ctor_set(x_351, 2, x_350); -lean_ctor_set(x_351, 3, x_342); -lean_ctor_set(x_351, 4, x_343); -lean_ctor_set(x_351, 5, x_344); -if (lean_is_scalar(x_246)) { - x_352 = lean_alloc_ctor(1, 2, 0); -} else { - x_352 = x_246; - lean_ctor_set_tag(x_352, 1); -} -lean_ctor_set(x_352, 0, x_339); -lean_ctor_set(x_352, 1, x_351); -return x_352; -} -else -{ -lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; 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; -x_353 = lean_ctor_get(x_337, 2); +lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; 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; +x_353 = lean_ctor_get(x_352, 2); lean_inc(x_353); -x_354 = lean_ctor_get(x_336, 0); +x_354 = lean_ctor_get(x_351, 0); lean_inc(x_354); -lean_dec(x_336); -x_355 = lean_ctor_get(x_337, 0); +lean_dec(x_351); +x_355 = lean_ctor_get(x_352, 0); lean_inc(x_355); -x_356 = lean_ctor_get(x_337, 1); +x_356 = lean_ctor_get(x_352, 1); lean_inc(x_356); -x_357 = lean_ctor_get(x_337, 3); +x_357 = lean_ctor_get(x_352, 3); lean_inc(x_357); -x_358 = lean_ctor_get(x_337, 4); +x_358 = lean_ctor_get(x_352, 4); lean_inc(x_358); -x_359 = lean_ctor_get(x_337, 5); +x_359 = lean_ctor_get(x_352, 5); lean_inc(x_359); -if (lean_is_exclusive(x_337)) { - lean_ctor_release(x_337, 0); - lean_ctor_release(x_337, 1); - lean_ctor_release(x_337, 2); - lean_ctor_release(x_337, 3); - lean_ctor_release(x_337, 4); - lean_ctor_release(x_337, 5); - x_360 = x_337; +if (lean_is_exclusive(x_352)) { + lean_ctor_release(x_352, 0); + lean_ctor_release(x_352, 1); + lean_ctor_release(x_352, 2); + lean_ctor_release(x_352, 3); + lean_ctor_release(x_352, 4); + lean_ctor_release(x_352, 5); + x_360 = x_352; } else { - lean_dec_ref(x_337); + lean_dec_ref(x_352); x_360 = lean_box(0); } x_361 = lean_ctor_get(x_353, 0); @@ -13446,315 +13572,411 @@ x_362 = lean_ctor_get(x_353, 1); lean_inc(x_362); x_363 = lean_ctor_get(x_353, 3); lean_inc(x_363); +x_364 = lean_ctor_get(x_353, 4); +lean_inc(x_364); if (lean_is_exclusive(x_353)) { lean_ctor_release(x_353, 0); lean_ctor_release(x_353, 1); lean_ctor_release(x_353, 2); lean_ctor_release(x_353, 3); - x_364 = x_353; + lean_ctor_release(x_353, 4); + x_365 = x_353; } else { lean_dec_ref(x_353); - x_364 = lean_box(0); + x_365 = lean_box(0); } -if (lean_is_scalar(x_364)) { - x_365 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_365)) { + x_366 = lean_alloc_ctor(0, 5, 0); } else { - x_365 = x_364; + x_366 = x_365; } -lean_ctor_set(x_365, 0, x_361); -lean_ctor_set(x_365, 1, x_362); -lean_ctor_set(x_365, 2, x_334); -lean_ctor_set(x_365, 3, x_363); +lean_ctor_set(x_366, 0, x_361); +lean_ctor_set(x_366, 1, x_362); +lean_ctor_set(x_366, 2, x_348); +lean_ctor_set(x_366, 3, x_363); +lean_ctor_set(x_366, 4, x_364); if (lean_is_scalar(x_360)) { - x_366 = lean_alloc_ctor(0, 6, 0); + x_367 = lean_alloc_ctor(0, 6, 0); } else { - x_366 = x_360; + x_367 = x_360; } -lean_ctor_set(x_366, 0, x_355); -lean_ctor_set(x_366, 1, x_356); -lean_ctor_set(x_366, 2, x_365); -lean_ctor_set(x_366, 3, x_357); -lean_ctor_set(x_366, 4, x_358); -lean_ctor_set(x_366, 5, x_359); -if (lean_is_scalar(x_246)) { - x_367 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_367, 0, x_355); +lean_ctor_set(x_367, 1, x_356); +lean_ctor_set(x_367, 2, x_366); +lean_ctor_set(x_367, 3, x_357); +lean_ctor_set(x_367, 4, x_358); +lean_ctor_set(x_367, 5, x_359); +if (lean_is_scalar(x_256)) { + x_368 = lean_alloc_ctor(1, 2, 0); } else { - x_367 = x_246; + x_368 = x_256; + lean_ctor_set_tag(x_368, 1); } -lean_ctor_set(x_367, 0, x_354); -lean_ctor_set(x_367, 1, x_366); -return x_367; +lean_ctor_set(x_368, 0, x_354); +lean_ctor_set(x_368, 1, x_367); +return x_368; +} +else +{ +lean_object* x_369; lean_object* x_370; lean_object* x_371; lean_object* x_372; lean_object* x_373; lean_object* x_374; lean_object* x_375; 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; +x_369 = lean_ctor_get(x_352, 2); +lean_inc(x_369); +x_370 = lean_ctor_get(x_351, 0); +lean_inc(x_370); +lean_dec(x_351); +x_371 = lean_ctor_get(x_352, 0); +lean_inc(x_371); +x_372 = lean_ctor_get(x_352, 1); +lean_inc(x_372); +x_373 = lean_ctor_get(x_352, 3); +lean_inc(x_373); +x_374 = lean_ctor_get(x_352, 4); +lean_inc(x_374); +x_375 = lean_ctor_get(x_352, 5); +lean_inc(x_375); +if (lean_is_exclusive(x_352)) { + lean_ctor_release(x_352, 0); + lean_ctor_release(x_352, 1); + lean_ctor_release(x_352, 2); + lean_ctor_release(x_352, 3); + lean_ctor_release(x_352, 4); + lean_ctor_release(x_352, 5); + x_376 = x_352; +} else { + lean_dec_ref(x_352); + x_376 = lean_box(0); +} +x_377 = lean_ctor_get(x_369, 0); +lean_inc(x_377); +x_378 = lean_ctor_get(x_369, 1); +lean_inc(x_378); +x_379 = lean_ctor_get(x_369, 3); +lean_inc(x_379); +x_380 = lean_ctor_get(x_369, 4); +lean_inc(x_380); +if (lean_is_exclusive(x_369)) { + lean_ctor_release(x_369, 0); + lean_ctor_release(x_369, 1); + lean_ctor_release(x_369, 2); + lean_ctor_release(x_369, 3); + lean_ctor_release(x_369, 4); + x_381 = x_369; +} else { + lean_dec_ref(x_369); + x_381 = lean_box(0); +} +if (lean_is_scalar(x_381)) { + x_382 = lean_alloc_ctor(0, 5, 0); +} else { + x_382 = x_381; +} +lean_ctor_set(x_382, 0, x_377); +lean_ctor_set(x_382, 1, x_378); +lean_ctor_set(x_382, 2, x_348); +lean_ctor_set(x_382, 3, x_379); +lean_ctor_set(x_382, 4, x_380); +if (lean_is_scalar(x_376)) { + x_383 = lean_alloc_ctor(0, 6, 0); +} else { + x_383 = x_376; +} +lean_ctor_set(x_383, 0, x_371); +lean_ctor_set(x_383, 1, x_372); +lean_ctor_set(x_383, 2, x_382); +lean_ctor_set(x_383, 3, x_373); +lean_ctor_set(x_383, 4, x_374); +lean_ctor_set(x_383, 5, x_375); +if (lean_is_scalar(x_256)) { + x_384 = lean_alloc_ctor(0, 2, 0); +} else { + x_384 = x_256; +} +lean_ctor_set(x_384, 0, x_370); +lean_ctor_set(x_384, 1, x_383); +return x_384; } } } } else { -lean_object* x_387; lean_object* x_388; lean_object* x_389; lean_object* x_390; lean_object* x_391; lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; lean_object* x_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; -x_387 = lean_ctor_get(x_245, 2); -x_388 = lean_ctor_get(x_245, 0); -x_389 = lean_ctor_get(x_245, 1); -x_390 = lean_ctor_get(x_245, 3); -x_391 = lean_ctor_get(x_245, 4); -x_392 = lean_ctor_get(x_245, 5); -lean_inc(x_392); -lean_inc(x_391); -lean_inc(x_390); -lean_inc(x_387); -lean_inc(x_389); -lean_inc(x_388); -lean_dec(x_245); -x_393 = lean_ctor_get(x_387, 0); -lean_inc(x_393); -x_394 = lean_ctor_get(x_387, 1); -lean_inc(x_394); -x_395 = lean_ctor_get(x_387, 2); -lean_inc(x_395); -x_396 = lean_ctor_get(x_387, 3); -lean_inc(x_396); -if (lean_is_exclusive(x_387)) { - lean_ctor_release(x_387, 0); - lean_ctor_release(x_387, 1); - lean_ctor_release(x_387, 2); - lean_ctor_release(x_387, 3); - x_397 = x_387; +lean_object* x_404; lean_object* x_405; lean_object* x_406; lean_object* x_407; lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_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_451; lean_object* x_452; lean_object* x_453; lean_object* x_454; lean_object* x_455; lean_object* x_456; lean_object* x_457; lean_object* x_458; lean_object* x_459; lean_object* x_460; lean_object* x_461; lean_object* x_462; lean_object* x_463; +x_404 = lean_ctor_get(x_255, 2); +x_405 = lean_ctor_get(x_255, 0); +x_406 = lean_ctor_get(x_255, 1); +x_407 = lean_ctor_get(x_255, 3); +x_408 = lean_ctor_get(x_255, 4); +x_409 = lean_ctor_get(x_255, 5); +lean_inc(x_409); +lean_inc(x_408); +lean_inc(x_407); +lean_inc(x_404); +lean_inc(x_406); +lean_inc(x_405); +lean_dec(x_255); +x_410 = lean_ctor_get(x_404, 0); +lean_inc(x_410); +x_411 = lean_ctor_get(x_404, 1); +lean_inc(x_411); +x_412 = lean_ctor_get(x_404, 2); +lean_inc(x_412); +x_413 = lean_ctor_get(x_404, 3); +lean_inc(x_413); +x_414 = lean_ctor_get(x_404, 4); +lean_inc(x_414); +if (lean_is_exclusive(x_404)) { + lean_ctor_release(x_404, 0); + lean_ctor_release(x_404, 1); + lean_ctor_release(x_404, 2); + lean_ctor_release(x_404, 3); + lean_ctor_release(x_404, 4); + x_415 = x_404; } else { - lean_dec_ref(x_387); - x_397 = lean_box(0); + lean_dec_ref(x_404); + x_415 = lean_box(0); } -x_431 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_397)) { - x_432 = lean_alloc_ctor(0, 4, 0); +x_451 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_415)) { + x_452 = lean_alloc_ctor(0, 5, 0); } else { - x_432 = x_397; + x_452 = x_415; } -lean_ctor_set(x_432, 0, x_393); -lean_ctor_set(x_432, 1, x_394); -lean_ctor_set(x_432, 2, x_431); -lean_ctor_set(x_432, 3, x_396); -x_433 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_433, 0, x_388); -lean_ctor_set(x_433, 1, x_389); -lean_ctor_set(x_433, 2, x_432); -lean_ctor_set(x_433, 3, x_390); -lean_ctor_set(x_433, 4, x_391); -lean_ctor_set(x_433, 5, x_392); -x_434 = lean_ctor_get(x_13, 0); -lean_inc(x_434); -x_435 = lean_ctor_get(x_13, 1); -lean_inc(x_435); -x_436 = lean_ctor_get(x_13, 2); -lean_inc(x_436); -x_437 = lean_ctor_get(x_13, 3); -lean_inc(x_437); -x_438 = lean_ctor_get(x_13, 4); -lean_inc(x_438); +lean_ctor_set(x_452, 0, x_410); +lean_ctor_set(x_452, 1, x_411); +lean_ctor_set(x_452, 2, x_451); +lean_ctor_set(x_452, 3, x_413); +lean_ctor_set(x_452, 4, x_414); +x_453 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_453, 0, x_405); +lean_ctor_set(x_453, 1, x_406); +lean_ctor_set(x_453, 2, x_452); +lean_ctor_set(x_453, 3, x_407); +lean_ctor_set(x_453, 4, x_408); +lean_ctor_set(x_453, 5, x_409); +x_454 = lean_ctor_get(x_13, 0); +lean_inc(x_454); +x_455 = lean_ctor_get(x_13, 1); +lean_inc(x_455); +x_456 = lean_ctor_get(x_13, 2); +lean_inc(x_456); +x_457 = lean_ctor_get(x_13, 3); +lean_inc(x_457); +x_458 = lean_ctor_get(x_13, 4); +lean_inc(x_458); if (lean_is_exclusive(x_13)) { lean_ctor_release(x_13, 0); lean_ctor_release(x_13, 1); lean_ctor_release(x_13, 2); lean_ctor_release(x_13, 3); lean_ctor_release(x_13, 4); - x_439 = x_13; + x_459 = x_13; } else { lean_dec_ref(x_13); - x_439 = lean_box(0); + x_459 = lean_box(0); } -x_440 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_440, 0, x_247); -lean_ctor_set(x_440, 1, x_22); -x_441 = lean_array_push(x_436, x_440); -if (lean_is_scalar(x_439)) { - x_442 = lean_alloc_ctor(0, 5, 0); +x_460 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_460, 0, x_257); +lean_ctor_set(x_460, 1, x_22); +x_461 = lean_array_push(x_456, x_460); +if (lean_is_scalar(x_459)) { + x_462 = lean_alloc_ctor(0, 5, 0); } else { - x_442 = x_439; + x_462 = x_459; } -lean_ctor_set(x_442, 0, x_434); -lean_ctor_set(x_442, 1, x_435); -lean_ctor_set(x_442, 2, x_441); -lean_ctor_set(x_442, 3, x_437); -lean_ctor_set(x_442, 4, x_438); -x_443 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_249, x_442, x_433); -if (lean_obj_tag(x_443) == 0) +lean_ctor_set(x_462, 0, x_454); +lean_ctor_set(x_462, 1, x_455); +lean_ctor_set(x_462, 2, x_461); +lean_ctor_set(x_462, 3, x_457); +lean_ctor_set(x_462, 4, x_458); +x_463 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_259, x_462, x_453); +if (lean_obj_tag(x_463) == 0) { -lean_object* x_444; lean_object* x_445; lean_object* x_446; -x_444 = lean_ctor_get(x_443, 0); -lean_inc(x_444); -x_445 = lean_ctor_get(x_443, 1); -lean_inc(x_445); -lean_dec(x_443); -x_446 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_446, 0, x_444); -x_398 = x_446; -x_399 = x_445; -goto block_430; +lean_object* x_464; lean_object* x_465; lean_object* x_466; +x_464 = lean_ctor_get(x_463, 0); +lean_inc(x_464); +x_465 = lean_ctor_get(x_463, 1); +lean_inc(x_465); +lean_dec(x_463); +x_466 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_466, 0, x_464); +x_416 = x_466; +x_417 = x_465; +goto block_450; } else { -lean_object* x_447; lean_object* x_448; lean_object* x_449; -x_447 = lean_ctor_get(x_443, 0); -lean_inc(x_447); -x_448 = lean_ctor_get(x_443, 1); -lean_inc(x_448); -lean_dec(x_443); -x_449 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_449, 0, x_447); -x_398 = x_449; -x_399 = x_448; -goto block_430; +lean_object* x_467; lean_object* x_468; lean_object* x_469; +x_467 = lean_ctor_get(x_463, 0); +lean_inc(x_467); +x_468 = lean_ctor_get(x_463, 1); +lean_inc(x_468); +lean_dec(x_463); +x_469 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_469, 0, x_467); +x_416 = x_469; +x_417 = x_468; +goto block_450; } -block_430: +block_450: { -if (lean_obj_tag(x_398) == 0) +if (lean_obj_tag(x_416) == 0) { -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; lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_object* x_412; lean_object* x_413; lean_object* x_414; -x_400 = lean_ctor_get(x_399, 2); -lean_inc(x_400); -x_401 = lean_ctor_get(x_398, 0); -lean_inc(x_401); -lean_dec(x_398); -x_402 = lean_ctor_get(x_399, 0); -lean_inc(x_402); -x_403 = lean_ctor_get(x_399, 1); -lean_inc(x_403); -x_404 = lean_ctor_get(x_399, 3); -lean_inc(x_404); -x_405 = lean_ctor_get(x_399, 4); -lean_inc(x_405); -x_406 = lean_ctor_get(x_399, 5); -lean_inc(x_406); -if (lean_is_exclusive(x_399)) { - lean_ctor_release(x_399, 0); - lean_ctor_release(x_399, 1); - lean_ctor_release(x_399, 2); - lean_ctor_release(x_399, 3); - lean_ctor_release(x_399, 4); - lean_ctor_release(x_399, 5); - x_407 = x_399; -} else { - lean_dec_ref(x_399); - x_407 = lean_box(0); -} -x_408 = lean_ctor_get(x_400, 0); -lean_inc(x_408); -x_409 = lean_ctor_get(x_400, 1); -lean_inc(x_409); -x_410 = lean_ctor_get(x_400, 3); -lean_inc(x_410); -if (lean_is_exclusive(x_400)) { - lean_ctor_release(x_400, 0); - lean_ctor_release(x_400, 1); - lean_ctor_release(x_400, 2); - lean_ctor_release(x_400, 3); - x_411 = x_400; -} else { - lean_dec_ref(x_400); - x_411 = lean_box(0); -} -if (lean_is_scalar(x_411)) { - x_412 = lean_alloc_ctor(0, 4, 0); -} else { - x_412 = x_411; -} -lean_ctor_set(x_412, 0, x_408); -lean_ctor_set(x_412, 1, x_409); -lean_ctor_set(x_412, 2, x_395); -lean_ctor_set(x_412, 3, x_410); -if (lean_is_scalar(x_407)) { - x_413 = lean_alloc_ctor(0, 6, 0); -} else { - x_413 = x_407; -} -lean_ctor_set(x_413, 0, x_402); -lean_ctor_set(x_413, 1, x_403); -lean_ctor_set(x_413, 2, x_412); -lean_ctor_set(x_413, 3, x_404); -lean_ctor_set(x_413, 4, x_405); -lean_ctor_set(x_413, 5, x_406); -if (lean_is_scalar(x_246)) { - x_414 = lean_alloc_ctor(1, 2, 0); -} else { - x_414 = x_246; - lean_ctor_set_tag(x_414, 1); -} -lean_ctor_set(x_414, 0, x_401); -lean_ctor_set(x_414, 1, x_413); -return x_414; -} -else -{ -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; lean_object* x_426; lean_object* x_427; lean_object* x_428; lean_object* x_429; -x_415 = lean_ctor_get(x_399, 2); -lean_inc(x_415); -x_416 = lean_ctor_get(x_398, 0); -lean_inc(x_416); -lean_dec(x_398); -x_417 = lean_ctor_get(x_399, 0); -lean_inc(x_417); -x_418 = lean_ctor_get(x_399, 1); +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; lean_object* x_426; lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; lean_object* x_432; lean_object* x_433; +x_418 = lean_ctor_get(x_417, 2); lean_inc(x_418); -x_419 = lean_ctor_get(x_399, 3); +x_419 = lean_ctor_get(x_416, 0); lean_inc(x_419); -x_420 = lean_ctor_get(x_399, 4); +lean_dec(x_416); +x_420 = lean_ctor_get(x_417, 0); lean_inc(x_420); -x_421 = lean_ctor_get(x_399, 5); +x_421 = lean_ctor_get(x_417, 1); lean_inc(x_421); -if (lean_is_exclusive(x_399)) { - lean_ctor_release(x_399, 0); - lean_ctor_release(x_399, 1); - lean_ctor_release(x_399, 2); - lean_ctor_release(x_399, 3); - lean_ctor_release(x_399, 4); - lean_ctor_release(x_399, 5); - x_422 = x_399; -} else { - lean_dec_ref(x_399); - x_422 = lean_box(0); -} -x_423 = lean_ctor_get(x_415, 0); +x_422 = lean_ctor_get(x_417, 3); +lean_inc(x_422); +x_423 = lean_ctor_get(x_417, 4); lean_inc(x_423); -x_424 = lean_ctor_get(x_415, 1); +x_424 = lean_ctor_get(x_417, 5); lean_inc(x_424); -x_425 = lean_ctor_get(x_415, 3); -lean_inc(x_425); -if (lean_is_exclusive(x_415)) { - lean_ctor_release(x_415, 0); - lean_ctor_release(x_415, 1); - lean_ctor_release(x_415, 2); - lean_ctor_release(x_415, 3); - x_426 = x_415; +if (lean_is_exclusive(x_417)) { + lean_ctor_release(x_417, 0); + lean_ctor_release(x_417, 1); + lean_ctor_release(x_417, 2); + lean_ctor_release(x_417, 3); + lean_ctor_release(x_417, 4); + lean_ctor_release(x_417, 5); + x_425 = x_417; } else { - lean_dec_ref(x_415); - x_426 = lean_box(0); + lean_dec_ref(x_417); + x_425 = lean_box(0); } -if (lean_is_scalar(x_426)) { - x_427 = lean_alloc_ctor(0, 4, 0); +x_426 = lean_ctor_get(x_418, 0); +lean_inc(x_426); +x_427 = lean_ctor_get(x_418, 1); +lean_inc(x_427); +x_428 = lean_ctor_get(x_418, 3); +lean_inc(x_428); +x_429 = lean_ctor_get(x_418, 4); +lean_inc(x_429); +if (lean_is_exclusive(x_418)) { + lean_ctor_release(x_418, 0); + lean_ctor_release(x_418, 1); + lean_ctor_release(x_418, 2); + lean_ctor_release(x_418, 3); + lean_ctor_release(x_418, 4); + x_430 = x_418; } else { - x_427 = x_426; + lean_dec_ref(x_418); + x_430 = lean_box(0); } -lean_ctor_set(x_427, 0, x_423); -lean_ctor_set(x_427, 1, x_424); -lean_ctor_set(x_427, 2, x_395); -lean_ctor_set(x_427, 3, x_425); -if (lean_is_scalar(x_422)) { - x_428 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_430)) { + x_431 = lean_alloc_ctor(0, 5, 0); } else { - x_428 = x_422; + x_431 = x_430; } -lean_ctor_set(x_428, 0, x_417); -lean_ctor_set(x_428, 1, x_418); -lean_ctor_set(x_428, 2, x_427); -lean_ctor_set(x_428, 3, x_419); -lean_ctor_set(x_428, 4, x_420); -lean_ctor_set(x_428, 5, x_421); -if (lean_is_scalar(x_246)) { - x_429 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_431, 0, x_426); +lean_ctor_set(x_431, 1, x_427); +lean_ctor_set(x_431, 2, x_412); +lean_ctor_set(x_431, 3, x_428); +lean_ctor_set(x_431, 4, x_429); +if (lean_is_scalar(x_425)) { + x_432 = lean_alloc_ctor(0, 6, 0); } else { - x_429 = x_246; + x_432 = x_425; } -lean_ctor_set(x_429, 0, x_416); -lean_ctor_set(x_429, 1, x_428); -return x_429; +lean_ctor_set(x_432, 0, x_420); +lean_ctor_set(x_432, 1, x_421); +lean_ctor_set(x_432, 2, x_431); +lean_ctor_set(x_432, 3, x_422); +lean_ctor_set(x_432, 4, x_423); +lean_ctor_set(x_432, 5, x_424); +if (lean_is_scalar(x_256)) { + x_433 = lean_alloc_ctor(1, 2, 0); +} else { + x_433 = x_256; + lean_ctor_set_tag(x_433, 1); +} +lean_ctor_set(x_433, 0, x_419); +lean_ctor_set(x_433, 1, x_432); +return x_433; +} +else +{ +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; lean_object* x_445; lean_object* x_446; lean_object* x_447; lean_object* x_448; lean_object* x_449; +x_434 = lean_ctor_get(x_417, 2); +lean_inc(x_434); +x_435 = lean_ctor_get(x_416, 0); +lean_inc(x_435); +lean_dec(x_416); +x_436 = lean_ctor_get(x_417, 0); +lean_inc(x_436); +x_437 = lean_ctor_get(x_417, 1); +lean_inc(x_437); +x_438 = lean_ctor_get(x_417, 3); +lean_inc(x_438); +x_439 = lean_ctor_get(x_417, 4); +lean_inc(x_439); +x_440 = lean_ctor_get(x_417, 5); +lean_inc(x_440); +if (lean_is_exclusive(x_417)) { + lean_ctor_release(x_417, 0); + lean_ctor_release(x_417, 1); + lean_ctor_release(x_417, 2); + lean_ctor_release(x_417, 3); + lean_ctor_release(x_417, 4); + lean_ctor_release(x_417, 5); + x_441 = x_417; +} else { + lean_dec_ref(x_417); + x_441 = lean_box(0); +} +x_442 = lean_ctor_get(x_434, 0); +lean_inc(x_442); +x_443 = lean_ctor_get(x_434, 1); +lean_inc(x_443); +x_444 = lean_ctor_get(x_434, 3); +lean_inc(x_444); +x_445 = lean_ctor_get(x_434, 4); +lean_inc(x_445); +if (lean_is_exclusive(x_434)) { + lean_ctor_release(x_434, 0); + lean_ctor_release(x_434, 1); + lean_ctor_release(x_434, 2); + lean_ctor_release(x_434, 3); + lean_ctor_release(x_434, 4); + x_446 = x_434; +} else { + lean_dec_ref(x_434); + x_446 = lean_box(0); +} +if (lean_is_scalar(x_446)) { + x_447 = lean_alloc_ctor(0, 5, 0); +} else { + x_447 = x_446; +} +lean_ctor_set(x_447, 0, x_442); +lean_ctor_set(x_447, 1, x_443); +lean_ctor_set(x_447, 2, x_412); +lean_ctor_set(x_447, 3, x_444); +lean_ctor_set(x_447, 4, x_445); +if (lean_is_scalar(x_441)) { + x_448 = lean_alloc_ctor(0, 6, 0); +} else { + x_448 = x_441; +} +lean_ctor_set(x_448, 0, x_436); +lean_ctor_set(x_448, 1, x_437); +lean_ctor_set(x_448, 2, x_447); +lean_ctor_set(x_448, 3, x_438); +lean_ctor_set(x_448, 4, x_439); +lean_ctor_set(x_448, 5, x_440); +if (lean_is_scalar(x_256)) { + x_449 = lean_alloc_ctor(0, 2, 0); +} else { + x_449 = x_256; +} +lean_ctor_set(x_449, 0, x_435); +lean_ctor_set(x_449, 1, x_448); +return x_449; } } } @@ -13762,7 +13984,7 @@ return x_429; } else { -uint8_t x_450; +uint8_t x_470; lean_dec(x_22); lean_dec(x_13); lean_dec(x_12); @@ -13773,23 +13995,23 @@ lean_dec(x_5); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_450 = !lean_is_exclusive(x_239); -if (x_450 == 0) +x_470 = !lean_is_exclusive(x_249); +if (x_470 == 0) { -return x_239; +return x_249; } else { -lean_object* x_451; lean_object* x_452; lean_object* x_453; -x_451 = lean_ctor_get(x_239, 0); -x_452 = lean_ctor_get(x_239, 1); -lean_inc(x_452); -lean_inc(x_451); -lean_dec(x_239); -x_453 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_453, 0, x_451); -lean_ctor_set(x_453, 1, x_452); -return x_453; +lean_object* x_471; lean_object* x_472; lean_object* x_473; +x_471 = lean_ctor_get(x_249, 0); +x_472 = lean_ctor_get(x_249, 1); +lean_inc(x_472); +lean_inc(x_471); +lean_dec(x_249); +x_473 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_473, 0, x_471); +lean_ctor_set(x_473, 1, x_472); +return x_473; } } } @@ -13797,7 +14019,7 @@ return x_453; } else { -uint8_t x_454; +uint8_t x_474; lean_dec(x_26); lean_dec(x_22); lean_dec(x_13); @@ -13809,29 +14031,29 @@ lean_dec(x_5); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_454 = !lean_is_exclusive(x_27); -if (x_454 == 0) +x_474 = !lean_is_exclusive(x_27); +if (x_474 == 0) { return x_27; } else { -lean_object* x_455; lean_object* x_456; lean_object* x_457; -x_455 = lean_ctor_get(x_27, 0); -x_456 = lean_ctor_get(x_27, 1); -lean_inc(x_456); -lean_inc(x_455); +lean_object* x_475; lean_object* x_476; lean_object* x_477; +x_475 = lean_ctor_get(x_27, 0); +x_476 = lean_ctor_get(x_27, 1); +lean_inc(x_476); +lean_inc(x_475); lean_dec(x_27); -x_457 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_457, 0, x_455); -lean_ctor_set(x_457, 1, x_456); -return x_457; +x_477 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_477, 0, x_475); +lean_ctor_set(x_477, 1, x_476); +return x_477; } } } else { -uint8_t x_458; +uint8_t x_478; lean_dec(x_22); lean_dec(x_13); lean_dec(x_12); @@ -13842,23 +14064,23 @@ lean_dec(x_5); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_458 = !lean_is_exclusive(x_23); -if (x_458 == 0) +x_478 = !lean_is_exclusive(x_23); +if (x_478 == 0) { return x_23; } else { -lean_object* x_459; lean_object* x_460; lean_object* x_461; -x_459 = lean_ctor_get(x_23, 0); -x_460 = lean_ctor_get(x_23, 1); -lean_inc(x_460); -lean_inc(x_459); +lean_object* x_479; lean_object* x_480; lean_object* x_481; +x_479 = lean_ctor_get(x_23, 0); +x_480 = lean_ctor_get(x_23, 1); +lean_inc(x_480); +lean_inc(x_479); lean_dec(x_23); -x_461 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_461, 0, x_459); -lean_ctor_set(x_461, 1, x_460); -return x_461; +x_481 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_481, 0, x_479); +lean_ctor_set(x_481, 1, x_480); +return x_481; } } } @@ -14000,105 +14222,105 @@ x_41 = lean_ctor_get(x_35, 2); x_42 = !lean_is_exclusive(x_41); if (x_42 == 0) { -lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_95; uint8_t x_96; +lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_99; uint8_t x_100; x_43 = lean_ctor_get(x_41, 2); -x_95 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_41, 2, x_95); -x_96 = !lean_is_exclusive(x_8); -if (x_96 == 0) +x_99 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_41, 2, x_99); +x_100 = !lean_is_exclusive(x_8); +if (x_100 == 0) { -lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; -x_97 = lean_ctor_get(x_8, 2); -x_98 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_98, 0, x_37); -lean_ctor_set(x_98, 1, x_24); -x_99 = lean_array_push(x_97, x_98); -lean_ctor_set(x_8, 2, x_99); -x_100 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_39, x_8, x_35); -if (lean_obj_tag(x_100) == 0) +lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; +x_101 = lean_ctor_get(x_8, 2); +x_102 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_102, 0, x_37); +lean_ctor_set(x_102, 1, x_24); +x_103 = lean_array_push(x_101, x_102); +lean_ctor_set(x_8, 2, x_103); +x_104 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_39, x_8, x_35); +if (lean_obj_tag(x_104) == 0) { -lean_object* x_101; lean_object* x_102; lean_object* x_103; -x_101 = lean_ctor_get(x_100, 0); -lean_inc(x_101); -x_102 = lean_ctor_get(x_100, 1); -lean_inc(x_102); -lean_dec(x_100); -x_103 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_103, 0, x_101); -x_44 = x_103; -x_45 = x_102; -goto block_94; -} -else -{ -lean_object* x_104; lean_object* x_105; lean_object* x_106; -x_104 = lean_ctor_get(x_100, 0); -lean_inc(x_104); -x_105 = lean_ctor_get(x_100, 1); +lean_object* x_105; lean_object* x_106; lean_object* x_107; +x_105 = lean_ctor_get(x_104, 0); lean_inc(x_105); -lean_dec(x_100); -x_106 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_106, 0, x_104); -x_44 = x_106; -x_45 = x_105; -goto block_94; -} +x_106 = lean_ctor_get(x_104, 1); +lean_inc(x_106); +lean_dec(x_104); +x_107 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_107, 0, x_105); +x_44 = x_107; +x_45 = x_106; +goto block_98; } else { -lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; -x_107 = lean_ctor_get(x_8, 0); -x_108 = lean_ctor_get(x_8, 1); -x_109 = lean_ctor_get(x_8, 2); -x_110 = lean_ctor_get(x_8, 3); -x_111 = lean_ctor_get(x_8, 4); -lean_inc(x_111); -lean_inc(x_110); -lean_inc(x_109); +lean_object* x_108; lean_object* x_109; lean_object* x_110; +x_108 = lean_ctor_get(x_104, 0); lean_inc(x_108); -lean_inc(x_107); -lean_dec(x_8); -x_112 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_112, 0, x_37); -lean_ctor_set(x_112, 1, x_24); -x_113 = lean_array_push(x_109, x_112); -x_114 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_114, 0, x_107); -lean_ctor_set(x_114, 1, x_108); -lean_ctor_set(x_114, 2, x_113); -lean_ctor_set(x_114, 3, x_110); -lean_ctor_set(x_114, 4, x_111); -x_115 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_39, x_114, x_35); -if (lean_obj_tag(x_115) == 0) -{ -lean_object* x_116; lean_object* x_117; lean_object* x_118; -x_116 = lean_ctor_get(x_115, 0); -lean_inc(x_116); -x_117 = lean_ctor_get(x_115, 1); -lean_inc(x_117); -lean_dec(x_115); -x_118 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_118, 0, x_116); -x_44 = x_118; -x_45 = x_117; -goto block_94; +x_109 = lean_ctor_get(x_104, 1); +lean_inc(x_109); +lean_dec(x_104); +x_110 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_110, 0, x_108); +x_44 = x_110; +x_45 = x_109; +goto block_98; +} } else { -lean_object* x_119; lean_object* x_120; lean_object* x_121; -x_119 = lean_ctor_get(x_115, 0); -lean_inc(x_119); -x_120 = lean_ctor_get(x_115, 1); +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; +x_111 = lean_ctor_get(x_8, 0); +x_112 = lean_ctor_get(x_8, 1); +x_113 = lean_ctor_get(x_8, 2); +x_114 = lean_ctor_get(x_8, 3); +x_115 = lean_ctor_get(x_8, 4); +lean_inc(x_115); +lean_inc(x_114); +lean_inc(x_113); +lean_inc(x_112); +lean_inc(x_111); +lean_dec(x_8); +x_116 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_116, 0, x_37); +lean_ctor_set(x_116, 1, x_24); +x_117 = lean_array_push(x_113, x_116); +x_118 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_118, 0, x_111); +lean_ctor_set(x_118, 1, x_112); +lean_ctor_set(x_118, 2, x_117); +lean_ctor_set(x_118, 3, x_114); +lean_ctor_set(x_118, 4, x_115); +x_119 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_39, x_118, x_35); +if (lean_obj_tag(x_119) == 0) +{ +lean_object* x_120; lean_object* x_121; lean_object* x_122; +x_120 = lean_ctor_get(x_119, 0); lean_inc(x_120); -lean_dec(x_115); -x_121 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_121, 0, x_119); -x_44 = x_121; -x_45 = x_120; -goto block_94; +x_121 = lean_ctor_get(x_119, 1); +lean_inc(x_121); +lean_dec(x_119); +x_122 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_122, 0, x_120); +x_44 = x_122; +x_45 = x_121; +goto block_98; +} +else +{ +lean_object* x_123; lean_object* x_124; lean_object* x_125; +x_123 = lean_ctor_get(x_119, 0); +lean_inc(x_123); +x_124 = lean_ctor_get(x_119, 1); +lean_inc(x_124); +lean_dec(x_119); +x_125 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_125, 0, x_123); +x_44 = x_125; +x_45 = x_124; +goto block_98; } } -block_94: +block_98: { if (lean_obj_tag(x_44) == 0) { @@ -14133,1284 +14355,1262 @@ 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_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; x_53 = lean_ctor_get(x_46, 0); x_54 = lean_ctor_get(x_46, 1); x_55 = lean_ctor_get(x_46, 3); +x_56 = lean_ctor_get(x_46, 4); +lean_inc(x_56); lean_inc(x_55); lean_inc(x_54); lean_inc(x_53); lean_dec(x_46); -x_56 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_56, 0, x_53); -lean_ctor_set(x_56, 1, x_54); -lean_ctor_set(x_56, 2, x_43); -lean_ctor_set(x_56, 3, x_55); -lean_ctor_set(x_45, 2, x_56); +x_57 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_57, 0, x_53); +lean_ctor_set(x_57, 1, x_54); +lean_ctor_set(x_57, 2, x_43); +lean_ctor_set(x_57, 3, x_55); +lean_ctor_set(x_57, 4, x_56); +lean_ctor_set(x_45, 2, x_57); if (lean_is_scalar(x_36)) { - x_57 = lean_alloc_ctor(1, 2, 0); + x_58 = lean_alloc_ctor(1, 2, 0); } else { - x_57 = x_36; - lean_ctor_set_tag(x_57, 1); + x_58 = x_36; + lean_ctor_set_tag(x_58, 1); } -lean_ctor_set(x_57, 0, x_47); -lean_ctor_set(x_57, 1, x_45); -return x_57; +lean_ctor_set(x_58, 0, x_47); +lean_ctor_set(x_58, 1, x_45); +return x_58; } } else { -lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; -x_58 = lean_ctor_get(x_45, 0); -x_59 = lean_ctor_get(x_45, 1); -x_60 = lean_ctor_get(x_45, 3); -x_61 = lean_ctor_get(x_45, 4); -x_62 = lean_ctor_get(x_45, 5); +lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; +x_59 = lean_ctor_get(x_45, 0); +x_60 = lean_ctor_get(x_45, 1); +x_61 = lean_ctor_get(x_45, 3); +x_62 = lean_ctor_get(x_45, 4); +x_63 = lean_ctor_get(x_45, 5); +lean_inc(x_63); lean_inc(x_62); lean_inc(x_61); lean_inc(x_60); lean_inc(x_59); -lean_inc(x_58); lean_dec(x_45); -x_63 = lean_ctor_get(x_46, 0); -lean_inc(x_63); -x_64 = lean_ctor_get(x_46, 1); +x_64 = lean_ctor_get(x_46, 0); lean_inc(x_64); -x_65 = lean_ctor_get(x_46, 3); +x_65 = lean_ctor_get(x_46, 1); lean_inc(x_65); +x_66 = lean_ctor_get(x_46, 3); +lean_inc(x_66); +x_67 = lean_ctor_get(x_46, 4); +lean_inc(x_67); if (lean_is_exclusive(x_46)) { lean_ctor_release(x_46, 0); lean_ctor_release(x_46, 1); lean_ctor_release(x_46, 2); lean_ctor_release(x_46, 3); - x_66 = x_46; + lean_ctor_release(x_46, 4); + x_68 = x_46; } else { lean_dec_ref(x_46); - x_66 = lean_box(0); + x_68 = lean_box(0); } -if (lean_is_scalar(x_66)) { - x_67 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_68)) { + x_69 = lean_alloc_ctor(0, 5, 0); } else { - x_67 = x_66; + x_69 = x_68; } -lean_ctor_set(x_67, 0, x_63); -lean_ctor_set(x_67, 1, x_64); -lean_ctor_set(x_67, 2, x_43); -lean_ctor_set(x_67, 3, x_65); -x_68 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_68, 0, x_58); -lean_ctor_set(x_68, 1, x_59); -lean_ctor_set(x_68, 2, x_67); -lean_ctor_set(x_68, 3, x_60); -lean_ctor_set(x_68, 4, x_61); -lean_ctor_set(x_68, 5, x_62); +lean_ctor_set(x_69, 0, x_64); +lean_ctor_set(x_69, 1, x_65); +lean_ctor_set(x_69, 2, x_43); +lean_ctor_set(x_69, 3, x_66); +lean_ctor_set(x_69, 4, x_67); +x_70 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_70, 0, x_59); +lean_ctor_set(x_70, 1, x_60); +lean_ctor_set(x_70, 2, x_69); +lean_ctor_set(x_70, 3, x_61); +lean_ctor_set(x_70, 4, x_62); +lean_ctor_set(x_70, 5, x_63); if (lean_is_scalar(x_36)) { - x_69 = lean_alloc_ctor(1, 2, 0); + x_71 = lean_alloc_ctor(1, 2, 0); } else { - x_69 = x_36; - lean_ctor_set_tag(x_69, 1); + x_71 = x_36; + lean_ctor_set_tag(x_71, 1); } -lean_ctor_set(x_69, 0, x_47); -lean_ctor_set(x_69, 1, x_68); -return x_69; +lean_ctor_set(x_71, 0, x_47); +lean_ctor_set(x_71, 1, x_70); +return x_71; } } else { -lean_object* x_70; lean_object* x_71; uint8_t x_72; -x_70 = lean_ctor_get(x_45, 2); -lean_inc(x_70); -x_71 = lean_ctor_get(x_44, 0); -lean_inc(x_71); +lean_object* x_72; lean_object* x_73; uint8_t x_74; +x_72 = lean_ctor_get(x_45, 2); +lean_inc(x_72); +x_73 = lean_ctor_get(x_44, 0); +lean_inc(x_73); lean_dec(x_44); -x_72 = !lean_is_exclusive(x_45); -if (x_72 == 0) -{ -lean_object* x_73; uint8_t x_74; -x_73 = lean_ctor_get(x_45, 2); -lean_dec(x_73); -x_74 = !lean_is_exclusive(x_70); +x_74 = !lean_is_exclusive(x_45); if (x_74 == 0) { -lean_object* x_75; lean_object* x_76; -x_75 = lean_ctor_get(x_70, 2); +lean_object* x_75; uint8_t x_76; +x_75 = lean_ctor_get(x_45, 2); lean_dec(x_75); -lean_ctor_set(x_70, 2, x_43); +x_76 = !lean_is_exclusive(x_72); +if (x_76 == 0) +{ +lean_object* x_77; lean_object* x_78; +x_77 = lean_ctor_get(x_72, 2); +lean_dec(x_77); +lean_ctor_set(x_72, 2, x_43); if (lean_is_scalar(x_36)) { - x_76 = lean_alloc_ctor(0, 2, 0); + x_78 = lean_alloc_ctor(0, 2, 0); } else { - x_76 = x_36; + x_78 = x_36; } -lean_ctor_set(x_76, 0, x_71); -lean_ctor_set(x_76, 1, x_45); -return x_76; +lean_ctor_set(x_78, 0, x_73); +lean_ctor_set(x_78, 1, x_45); +return x_78; } else { -lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; -x_77 = lean_ctor_get(x_70, 0); -x_78 = lean_ctor_get(x_70, 1); -x_79 = lean_ctor_get(x_70, 3); +lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; +x_79 = lean_ctor_get(x_72, 0); +x_80 = lean_ctor_get(x_72, 1); +x_81 = lean_ctor_get(x_72, 3); +x_82 = lean_ctor_get(x_72, 4); +lean_inc(x_82); +lean_inc(x_81); +lean_inc(x_80); lean_inc(x_79); -lean_inc(x_78); -lean_inc(x_77); -lean_dec(x_70); -x_80 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_80, 0, x_77); -lean_ctor_set(x_80, 1, x_78); -lean_ctor_set(x_80, 2, x_43); -lean_ctor_set(x_80, 3, x_79); -lean_ctor_set(x_45, 2, x_80); +lean_dec(x_72); +x_83 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_83, 0, x_79); +lean_ctor_set(x_83, 1, x_80); +lean_ctor_set(x_83, 2, x_43); +lean_ctor_set(x_83, 3, x_81); +lean_ctor_set(x_83, 4, x_82); +lean_ctor_set(x_45, 2, x_83); if (lean_is_scalar(x_36)) { - x_81 = lean_alloc_ctor(0, 2, 0); + x_84 = lean_alloc_ctor(0, 2, 0); } else { - x_81 = x_36; + x_84 = x_36; } -lean_ctor_set(x_81, 0, x_71); -lean_ctor_set(x_81, 1, x_45); -return x_81; +lean_ctor_set(x_84, 0, x_73); +lean_ctor_set(x_84, 1, x_45); +return x_84; } } else { -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; -x_82 = lean_ctor_get(x_45, 0); -x_83 = lean_ctor_get(x_45, 1); -x_84 = lean_ctor_get(x_45, 3); -x_85 = lean_ctor_get(x_45, 4); -x_86 = lean_ctor_get(x_45, 5); +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; +x_85 = lean_ctor_get(x_45, 0); +x_86 = lean_ctor_get(x_45, 1); +x_87 = lean_ctor_get(x_45, 3); +x_88 = lean_ctor_get(x_45, 4); +x_89 = lean_ctor_get(x_45, 5); +lean_inc(x_89); +lean_inc(x_88); +lean_inc(x_87); lean_inc(x_86); lean_inc(x_85); -lean_inc(x_84); -lean_inc(x_83); -lean_inc(x_82); lean_dec(x_45); -x_87 = lean_ctor_get(x_70, 0); -lean_inc(x_87); -x_88 = lean_ctor_get(x_70, 1); -lean_inc(x_88); -x_89 = lean_ctor_get(x_70, 3); -lean_inc(x_89); -if (lean_is_exclusive(x_70)) { - lean_ctor_release(x_70, 0); - lean_ctor_release(x_70, 1); - lean_ctor_release(x_70, 2); - lean_ctor_release(x_70, 3); - x_90 = x_70; +x_90 = lean_ctor_get(x_72, 0); +lean_inc(x_90); +x_91 = lean_ctor_get(x_72, 1); +lean_inc(x_91); +x_92 = lean_ctor_get(x_72, 3); +lean_inc(x_92); +x_93 = lean_ctor_get(x_72, 4); +lean_inc(x_93); +if (lean_is_exclusive(x_72)) { + lean_ctor_release(x_72, 0); + lean_ctor_release(x_72, 1); + lean_ctor_release(x_72, 2); + lean_ctor_release(x_72, 3); + lean_ctor_release(x_72, 4); + x_94 = x_72; } else { - lean_dec_ref(x_70); - x_90 = lean_box(0); + lean_dec_ref(x_72); + x_94 = lean_box(0); } -if (lean_is_scalar(x_90)) { - x_91 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_94)) { + x_95 = lean_alloc_ctor(0, 5, 0); } else { - x_91 = x_90; + x_95 = x_94; } -lean_ctor_set(x_91, 0, x_87); -lean_ctor_set(x_91, 1, x_88); -lean_ctor_set(x_91, 2, x_43); -lean_ctor_set(x_91, 3, x_89); -x_92 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_92, 0, x_82); -lean_ctor_set(x_92, 1, x_83); -lean_ctor_set(x_92, 2, x_91); -lean_ctor_set(x_92, 3, x_84); -lean_ctor_set(x_92, 4, x_85); -lean_ctor_set(x_92, 5, x_86); +lean_ctor_set(x_95, 0, x_90); +lean_ctor_set(x_95, 1, x_91); +lean_ctor_set(x_95, 2, x_43); +lean_ctor_set(x_95, 3, x_92); +lean_ctor_set(x_95, 4, x_93); +x_96 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_96, 0, x_85); +lean_ctor_set(x_96, 1, x_86); +lean_ctor_set(x_96, 2, x_95); +lean_ctor_set(x_96, 3, x_87); +lean_ctor_set(x_96, 4, x_88); +lean_ctor_set(x_96, 5, x_89); if (lean_is_scalar(x_36)) { - x_93 = lean_alloc_ctor(0, 2, 0); + x_97 = lean_alloc_ctor(0, 2, 0); } else { - x_93 = x_36; + x_97 = x_36; } -lean_ctor_set(x_93, 0, x_71); -lean_ctor_set(x_93, 1, x_92); -return x_93; +lean_ctor_set(x_97, 0, x_73); +lean_ctor_set(x_97, 1, x_96); +return x_97; } } } } else { -lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; -x_122 = lean_ctor_get(x_41, 0); -x_123 = lean_ctor_get(x_41, 1); -x_124 = lean_ctor_get(x_41, 2); -x_125 = lean_ctor_get(x_41, 3); -lean_inc(x_125); -lean_inc(x_124); -lean_inc(x_123); -lean_inc(x_122); -lean_dec(x_41); -x_159 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_160 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_160, 0, x_122); -lean_ctor_set(x_160, 1, x_123); -lean_ctor_set(x_160, 2, x_159); -lean_ctor_set(x_160, 3, x_125); -lean_ctor_set(x_35, 2, x_160); -x_161 = lean_ctor_get(x_8, 0); -lean_inc(x_161); -x_162 = lean_ctor_get(x_8, 1); -lean_inc(x_162); -x_163 = lean_ctor_get(x_8, 2); -lean_inc(x_163); -x_164 = lean_ctor_get(x_8, 3); -lean_inc(x_164); -x_165 = lean_ctor_get(x_8, 4); -lean_inc(x_165); -if (lean_is_exclusive(x_8)) { - lean_ctor_release(x_8, 0); - lean_ctor_release(x_8, 1); - lean_ctor_release(x_8, 2); - lean_ctor_release(x_8, 3); - lean_ctor_release(x_8, 4); - x_166 = x_8; -} else { - lean_dec_ref(x_8); - x_166 = lean_box(0); -} -x_167 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_167, 0, x_37); -lean_ctor_set(x_167, 1, x_24); -x_168 = lean_array_push(x_163, x_167); -if (lean_is_scalar(x_166)) { - x_169 = lean_alloc_ctor(0, 5, 0); -} else { - x_169 = x_166; -} -lean_ctor_set(x_169, 0, x_161); -lean_ctor_set(x_169, 1, x_162); -lean_ctor_set(x_169, 2, x_168); -lean_ctor_set(x_169, 3, x_164); -lean_ctor_set(x_169, 4, x_165); -x_170 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_39, x_169, x_35); -if (lean_obj_tag(x_170) == 0) -{ -lean_object* x_171; lean_object* x_172; lean_object* x_173; -x_171 = lean_ctor_get(x_170, 0); -lean_inc(x_171); -x_172 = lean_ctor_get(x_170, 1); -lean_inc(x_172); -lean_dec(x_170); -x_173 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_173, 0, x_171); -x_126 = x_173; -x_127 = x_172; -goto block_158; -} -else -{ -lean_object* x_174; lean_object* x_175; lean_object* x_176; -x_174 = lean_ctor_get(x_170, 0); -lean_inc(x_174); -x_175 = lean_ctor_get(x_170, 1); -lean_inc(x_175); -lean_dec(x_170); -x_176 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_176, 0, x_174); -x_126 = x_176; -x_127 = x_175; -goto block_158; -} -block_158: -{ -if (lean_obj_tag(x_126) == 0) -{ -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; -x_128 = lean_ctor_get(x_127, 2); -lean_inc(x_128); -x_129 = lean_ctor_get(x_126, 0); -lean_inc(x_129); -lean_dec(x_126); -x_130 = lean_ctor_get(x_127, 0); +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_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; +x_126 = lean_ctor_get(x_41, 0); +x_127 = lean_ctor_get(x_41, 1); +x_128 = lean_ctor_get(x_41, 2); +x_129 = lean_ctor_get(x_41, 3); +x_130 = lean_ctor_get(x_41, 4); lean_inc(x_130); -x_131 = lean_ctor_get(x_127, 1); -lean_inc(x_131); -x_132 = lean_ctor_get(x_127, 3); -lean_inc(x_132); -x_133 = lean_ctor_get(x_127, 4); -lean_inc(x_133); -x_134 = lean_ctor_get(x_127, 5); -lean_inc(x_134); -if (lean_is_exclusive(x_127)) { - lean_ctor_release(x_127, 0); - lean_ctor_release(x_127, 1); - lean_ctor_release(x_127, 2); - lean_ctor_release(x_127, 3); - lean_ctor_release(x_127, 4); - lean_ctor_release(x_127, 5); - x_135 = x_127; -} else { - lean_dec_ref(x_127); - x_135 = lean_box(0); -} -x_136 = lean_ctor_get(x_128, 0); -lean_inc(x_136); -x_137 = lean_ctor_get(x_128, 1); -lean_inc(x_137); -x_138 = lean_ctor_get(x_128, 3); -lean_inc(x_138); -if (lean_is_exclusive(x_128)) { - lean_ctor_release(x_128, 0); - lean_ctor_release(x_128, 1); - lean_ctor_release(x_128, 2); - lean_ctor_release(x_128, 3); - x_139 = x_128; -} else { - lean_dec_ref(x_128); - x_139 = lean_box(0); -} -if (lean_is_scalar(x_139)) { - x_140 = lean_alloc_ctor(0, 4, 0); -} else { - x_140 = x_139; -} -lean_ctor_set(x_140, 0, x_136); -lean_ctor_set(x_140, 1, x_137); -lean_ctor_set(x_140, 2, x_124); -lean_ctor_set(x_140, 3, x_138); -if (lean_is_scalar(x_135)) { - x_141 = lean_alloc_ctor(0, 6, 0); -} else { - x_141 = x_135; -} -lean_ctor_set(x_141, 0, x_130); -lean_ctor_set(x_141, 1, x_131); -lean_ctor_set(x_141, 2, x_140); -lean_ctor_set(x_141, 3, x_132); -lean_ctor_set(x_141, 4, x_133); -lean_ctor_set(x_141, 5, x_134); -if (lean_is_scalar(x_36)) { - x_142 = lean_alloc_ctor(1, 2, 0); -} else { - x_142 = x_36; - lean_ctor_set_tag(x_142, 1); -} -lean_ctor_set(x_142, 0, x_129); -lean_ctor_set(x_142, 1, x_141); -return x_142; -} -else -{ -lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; 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; -x_143 = lean_ctor_get(x_127, 2); -lean_inc(x_143); -x_144 = lean_ctor_get(x_126, 0); -lean_inc(x_144); -lean_dec(x_126); -x_145 = lean_ctor_get(x_127, 0); -lean_inc(x_145); -x_146 = lean_ctor_get(x_127, 1); -lean_inc(x_146); -x_147 = lean_ctor_get(x_127, 3); -lean_inc(x_147); -x_148 = lean_ctor_get(x_127, 4); -lean_inc(x_148); -x_149 = lean_ctor_get(x_127, 5); -lean_inc(x_149); -if (lean_is_exclusive(x_127)) { - lean_ctor_release(x_127, 0); - lean_ctor_release(x_127, 1); - lean_ctor_release(x_127, 2); - lean_ctor_release(x_127, 3); - lean_ctor_release(x_127, 4); - lean_ctor_release(x_127, 5); - x_150 = x_127; -} else { - lean_dec_ref(x_127); - x_150 = lean_box(0); -} -x_151 = lean_ctor_get(x_143, 0); -lean_inc(x_151); -x_152 = lean_ctor_get(x_143, 1); -lean_inc(x_152); -x_153 = lean_ctor_get(x_143, 3); -lean_inc(x_153); -if (lean_is_exclusive(x_143)) { - lean_ctor_release(x_143, 0); - lean_ctor_release(x_143, 1); - lean_ctor_release(x_143, 2); - lean_ctor_release(x_143, 3); - x_154 = x_143; -} else { - lean_dec_ref(x_143); - x_154 = lean_box(0); -} -if (lean_is_scalar(x_154)) { - x_155 = lean_alloc_ctor(0, 4, 0); -} else { - x_155 = x_154; -} -lean_ctor_set(x_155, 0, x_151); -lean_ctor_set(x_155, 1, x_152); -lean_ctor_set(x_155, 2, x_124); -lean_ctor_set(x_155, 3, x_153); -if (lean_is_scalar(x_150)) { - x_156 = lean_alloc_ctor(0, 6, 0); -} else { - x_156 = x_150; -} -lean_ctor_set(x_156, 0, x_145); -lean_ctor_set(x_156, 1, x_146); -lean_ctor_set(x_156, 2, x_155); -lean_ctor_set(x_156, 3, x_147); -lean_ctor_set(x_156, 4, x_148); -lean_ctor_set(x_156, 5, x_149); -if (lean_is_scalar(x_36)) { - x_157 = lean_alloc_ctor(0, 2, 0); -} else { - x_157 = x_36; -} -lean_ctor_set(x_157, 0, x_144); -lean_ctor_set(x_157, 1, x_156); -return x_157; -} -} -} -} -else -{ -lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; 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_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; lean_object* x_231; lean_object* x_232; lean_object* x_233; -x_177 = lean_ctor_get(x_35, 2); -x_178 = lean_ctor_get(x_35, 0); -x_179 = lean_ctor_get(x_35, 1); -x_180 = lean_ctor_get(x_35, 3); -x_181 = lean_ctor_get(x_35, 4); -x_182 = lean_ctor_get(x_35, 5); -lean_inc(x_182); -lean_inc(x_181); -lean_inc(x_180); -lean_inc(x_177); -lean_inc(x_179); -lean_inc(x_178); -lean_dec(x_35); -x_183 = lean_ctor_get(x_177, 0); -lean_inc(x_183); -x_184 = lean_ctor_get(x_177, 1); -lean_inc(x_184); -x_185 = lean_ctor_get(x_177, 2); -lean_inc(x_185); -x_186 = lean_ctor_get(x_177, 3); -lean_inc(x_186); -if (lean_is_exclusive(x_177)) { - lean_ctor_release(x_177, 0); - lean_ctor_release(x_177, 1); - lean_ctor_release(x_177, 2); - lean_ctor_release(x_177, 3); - x_187 = x_177; -} else { - lean_dec_ref(x_177); - x_187 = lean_box(0); -} -x_221 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_187)) { - x_222 = lean_alloc_ctor(0, 4, 0); -} else { - x_222 = x_187; -} -lean_ctor_set(x_222, 0, x_183); -lean_ctor_set(x_222, 1, x_184); -lean_ctor_set(x_222, 2, x_221); -lean_ctor_set(x_222, 3, x_186); -x_223 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_223, 0, x_178); -lean_ctor_set(x_223, 1, x_179); -lean_ctor_set(x_223, 2, x_222); -lean_ctor_set(x_223, 3, x_180); -lean_ctor_set(x_223, 4, x_181); -lean_ctor_set(x_223, 5, x_182); -x_224 = lean_ctor_get(x_8, 0); -lean_inc(x_224); -x_225 = lean_ctor_get(x_8, 1); -lean_inc(x_225); -x_226 = lean_ctor_get(x_8, 2); -lean_inc(x_226); -x_227 = lean_ctor_get(x_8, 3); -lean_inc(x_227); -x_228 = lean_ctor_get(x_8, 4); -lean_inc(x_228); +lean_inc(x_129); +lean_inc(x_128); +lean_inc(x_127); +lean_inc(x_126); +lean_dec(x_41); +x_166 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_167 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_167, 0, x_126); +lean_ctor_set(x_167, 1, x_127); +lean_ctor_set(x_167, 2, x_166); +lean_ctor_set(x_167, 3, x_129); +lean_ctor_set(x_167, 4, x_130); +lean_ctor_set(x_35, 2, x_167); +x_168 = lean_ctor_get(x_8, 0); +lean_inc(x_168); +x_169 = lean_ctor_get(x_8, 1); +lean_inc(x_169); +x_170 = lean_ctor_get(x_8, 2); +lean_inc(x_170); +x_171 = lean_ctor_get(x_8, 3); +lean_inc(x_171); +x_172 = lean_ctor_get(x_8, 4); +lean_inc(x_172); if (lean_is_exclusive(x_8)) { lean_ctor_release(x_8, 0); lean_ctor_release(x_8, 1); lean_ctor_release(x_8, 2); lean_ctor_release(x_8, 3); lean_ctor_release(x_8, 4); - x_229 = x_8; + x_173 = x_8; } else { lean_dec_ref(x_8); - x_229 = lean_box(0); + x_173 = lean_box(0); } -x_230 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_230, 0, x_37); -lean_ctor_set(x_230, 1, x_24); -x_231 = lean_array_push(x_226, x_230); -if (lean_is_scalar(x_229)) { +x_174 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_174, 0, x_37); +lean_ctor_set(x_174, 1, x_24); +x_175 = lean_array_push(x_170, x_174); +if (lean_is_scalar(x_173)) { + x_176 = lean_alloc_ctor(0, 5, 0); +} else { + x_176 = x_173; +} +lean_ctor_set(x_176, 0, x_168); +lean_ctor_set(x_176, 1, x_169); +lean_ctor_set(x_176, 2, x_175); +lean_ctor_set(x_176, 3, x_171); +lean_ctor_set(x_176, 4, x_172); +x_177 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_39, x_176, x_35); +if (lean_obj_tag(x_177) == 0) +{ +lean_object* x_178; lean_object* x_179; lean_object* x_180; +x_178 = lean_ctor_get(x_177, 0); +lean_inc(x_178); +x_179 = lean_ctor_get(x_177, 1); +lean_inc(x_179); +lean_dec(x_177); +x_180 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_180, 0, x_178); +x_131 = x_180; +x_132 = x_179; +goto block_165; +} +else +{ +lean_object* x_181; lean_object* x_182; lean_object* x_183; +x_181 = lean_ctor_get(x_177, 0); +lean_inc(x_181); +x_182 = lean_ctor_get(x_177, 1); +lean_inc(x_182); +lean_dec(x_177); +x_183 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_183, 0, x_181); +x_131 = x_183; +x_132 = x_182; +goto block_165; +} +block_165: +{ +if (lean_obj_tag(x_131) == 0) +{ +lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; +x_133 = lean_ctor_get(x_132, 2); +lean_inc(x_133); +x_134 = lean_ctor_get(x_131, 0); +lean_inc(x_134); +lean_dec(x_131); +x_135 = lean_ctor_get(x_132, 0); +lean_inc(x_135); +x_136 = lean_ctor_get(x_132, 1); +lean_inc(x_136); +x_137 = lean_ctor_get(x_132, 3); +lean_inc(x_137); +x_138 = lean_ctor_get(x_132, 4); +lean_inc(x_138); +x_139 = lean_ctor_get(x_132, 5); +lean_inc(x_139); +if (lean_is_exclusive(x_132)) { + lean_ctor_release(x_132, 0); + lean_ctor_release(x_132, 1); + lean_ctor_release(x_132, 2); + lean_ctor_release(x_132, 3); + lean_ctor_release(x_132, 4); + lean_ctor_release(x_132, 5); + x_140 = x_132; +} else { + lean_dec_ref(x_132); + x_140 = lean_box(0); +} +x_141 = lean_ctor_get(x_133, 0); +lean_inc(x_141); +x_142 = lean_ctor_get(x_133, 1); +lean_inc(x_142); +x_143 = lean_ctor_get(x_133, 3); +lean_inc(x_143); +x_144 = lean_ctor_get(x_133, 4); +lean_inc(x_144); +if (lean_is_exclusive(x_133)) { + lean_ctor_release(x_133, 0); + lean_ctor_release(x_133, 1); + lean_ctor_release(x_133, 2); + lean_ctor_release(x_133, 3); + lean_ctor_release(x_133, 4); + x_145 = x_133; +} else { + lean_dec_ref(x_133); + x_145 = lean_box(0); +} +if (lean_is_scalar(x_145)) { + x_146 = lean_alloc_ctor(0, 5, 0); +} else { + x_146 = x_145; +} +lean_ctor_set(x_146, 0, x_141); +lean_ctor_set(x_146, 1, x_142); +lean_ctor_set(x_146, 2, x_128); +lean_ctor_set(x_146, 3, x_143); +lean_ctor_set(x_146, 4, x_144); +if (lean_is_scalar(x_140)) { + x_147 = lean_alloc_ctor(0, 6, 0); +} else { + x_147 = x_140; +} +lean_ctor_set(x_147, 0, x_135); +lean_ctor_set(x_147, 1, x_136); +lean_ctor_set(x_147, 2, x_146); +lean_ctor_set(x_147, 3, x_137); +lean_ctor_set(x_147, 4, x_138); +lean_ctor_set(x_147, 5, x_139); +if (lean_is_scalar(x_36)) { + x_148 = lean_alloc_ctor(1, 2, 0); +} else { + x_148 = x_36; + lean_ctor_set_tag(x_148, 1); +} +lean_ctor_set(x_148, 0, x_134); +lean_ctor_set(x_148, 1, x_147); +return x_148; +} +else +{ +lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; +x_149 = lean_ctor_get(x_132, 2); +lean_inc(x_149); +x_150 = lean_ctor_get(x_131, 0); +lean_inc(x_150); +lean_dec(x_131); +x_151 = lean_ctor_get(x_132, 0); +lean_inc(x_151); +x_152 = lean_ctor_get(x_132, 1); +lean_inc(x_152); +x_153 = lean_ctor_get(x_132, 3); +lean_inc(x_153); +x_154 = lean_ctor_get(x_132, 4); +lean_inc(x_154); +x_155 = lean_ctor_get(x_132, 5); +lean_inc(x_155); +if (lean_is_exclusive(x_132)) { + lean_ctor_release(x_132, 0); + lean_ctor_release(x_132, 1); + lean_ctor_release(x_132, 2); + lean_ctor_release(x_132, 3); + lean_ctor_release(x_132, 4); + lean_ctor_release(x_132, 5); + x_156 = x_132; +} else { + lean_dec_ref(x_132); + x_156 = lean_box(0); +} +x_157 = lean_ctor_get(x_149, 0); +lean_inc(x_157); +x_158 = lean_ctor_get(x_149, 1); +lean_inc(x_158); +x_159 = lean_ctor_get(x_149, 3); +lean_inc(x_159); +x_160 = lean_ctor_get(x_149, 4); +lean_inc(x_160); +if (lean_is_exclusive(x_149)) { + lean_ctor_release(x_149, 0); + lean_ctor_release(x_149, 1); + lean_ctor_release(x_149, 2); + lean_ctor_release(x_149, 3); + lean_ctor_release(x_149, 4); + x_161 = x_149; +} else { + lean_dec_ref(x_149); + x_161 = lean_box(0); +} +if (lean_is_scalar(x_161)) { + x_162 = lean_alloc_ctor(0, 5, 0); +} else { + x_162 = x_161; +} +lean_ctor_set(x_162, 0, x_157); +lean_ctor_set(x_162, 1, x_158); +lean_ctor_set(x_162, 2, x_128); +lean_ctor_set(x_162, 3, x_159); +lean_ctor_set(x_162, 4, x_160); +if (lean_is_scalar(x_156)) { + x_163 = lean_alloc_ctor(0, 6, 0); +} else { + x_163 = x_156; +} +lean_ctor_set(x_163, 0, x_151); +lean_ctor_set(x_163, 1, x_152); +lean_ctor_set(x_163, 2, x_162); +lean_ctor_set(x_163, 3, x_153); +lean_ctor_set(x_163, 4, x_154); +lean_ctor_set(x_163, 5, x_155); +if (lean_is_scalar(x_36)) { + x_164 = lean_alloc_ctor(0, 2, 0); +} else { + x_164 = x_36; +} +lean_ctor_set(x_164, 0, x_150); +lean_ctor_set(x_164, 1, x_163); +return x_164; +} +} +} +} +else +{ +lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_231; lean_object* x_232; lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_object* x_236; lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; lean_object* x_242; lean_object* x_243; +x_184 = lean_ctor_get(x_35, 2); +x_185 = lean_ctor_get(x_35, 0); +x_186 = lean_ctor_get(x_35, 1); +x_187 = lean_ctor_get(x_35, 3); +x_188 = lean_ctor_get(x_35, 4); +x_189 = lean_ctor_get(x_35, 5); +lean_inc(x_189); +lean_inc(x_188); +lean_inc(x_187); +lean_inc(x_184); +lean_inc(x_186); +lean_inc(x_185); +lean_dec(x_35); +x_190 = lean_ctor_get(x_184, 0); +lean_inc(x_190); +x_191 = lean_ctor_get(x_184, 1); +lean_inc(x_191); +x_192 = lean_ctor_get(x_184, 2); +lean_inc(x_192); +x_193 = lean_ctor_get(x_184, 3); +lean_inc(x_193); +x_194 = lean_ctor_get(x_184, 4); +lean_inc(x_194); +if (lean_is_exclusive(x_184)) { + lean_ctor_release(x_184, 0); + lean_ctor_release(x_184, 1); + lean_ctor_release(x_184, 2); + lean_ctor_release(x_184, 3); + lean_ctor_release(x_184, 4); + x_195 = x_184; +} else { + lean_dec_ref(x_184); + x_195 = lean_box(0); +} +x_231 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_195)) { x_232 = lean_alloc_ctor(0, 5, 0); } else { - x_232 = x_229; + x_232 = x_195; } -lean_ctor_set(x_232, 0, x_224); -lean_ctor_set(x_232, 1, x_225); +lean_ctor_set(x_232, 0, x_190); +lean_ctor_set(x_232, 1, x_191); lean_ctor_set(x_232, 2, x_231); -lean_ctor_set(x_232, 3, x_227); -lean_ctor_set(x_232, 4, x_228); -x_233 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_39, x_232, x_223); -if (lean_obj_tag(x_233) == 0) -{ -lean_object* x_234; lean_object* x_235; lean_object* x_236; -x_234 = lean_ctor_get(x_233, 0); +lean_ctor_set(x_232, 3, x_193); +lean_ctor_set(x_232, 4, x_194); +x_233 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_233, 0, x_185); +lean_ctor_set(x_233, 1, x_186); +lean_ctor_set(x_233, 2, x_232); +lean_ctor_set(x_233, 3, x_187); +lean_ctor_set(x_233, 4, x_188); +lean_ctor_set(x_233, 5, x_189); +x_234 = lean_ctor_get(x_8, 0); lean_inc(x_234); -x_235 = lean_ctor_get(x_233, 1); +x_235 = lean_ctor_get(x_8, 1); lean_inc(x_235); -lean_dec(x_233); -x_236 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_236, 0, x_234); -x_188 = x_236; -x_189 = x_235; -goto block_220; -} -else -{ -lean_object* x_237; lean_object* x_238; lean_object* x_239; -x_237 = lean_ctor_get(x_233, 0); +x_236 = lean_ctor_get(x_8, 2); +lean_inc(x_236); +x_237 = lean_ctor_get(x_8, 3); lean_inc(x_237); -x_238 = lean_ctor_get(x_233, 1); +x_238 = lean_ctor_get(x_8, 4); lean_inc(x_238); -lean_dec(x_233); -x_239 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_239, 0, x_237); -x_188 = x_239; -x_189 = x_238; -goto block_220; +if (lean_is_exclusive(x_8)) { + lean_ctor_release(x_8, 0); + lean_ctor_release(x_8, 1); + lean_ctor_release(x_8, 2); + lean_ctor_release(x_8, 3); + lean_ctor_release(x_8, 4); + x_239 = x_8; +} else { + lean_dec_ref(x_8); + x_239 = lean_box(0); } -block_220: +x_240 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_240, 0, x_37); +lean_ctor_set(x_240, 1, x_24); +x_241 = lean_array_push(x_236, x_240); +if (lean_is_scalar(x_239)) { + x_242 = lean_alloc_ctor(0, 5, 0); +} else { + x_242 = x_239; +} +lean_ctor_set(x_242, 0, x_234); +lean_ctor_set(x_242, 1, x_235); +lean_ctor_set(x_242, 2, x_241); +lean_ctor_set(x_242, 3, x_237); +lean_ctor_set(x_242, 4, x_238); +x_243 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_39, x_242, x_233); +if (lean_obj_tag(x_243) == 0) { -if (lean_obj_tag(x_188) == 0) -{ -lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; -x_190 = lean_ctor_get(x_189, 2); -lean_inc(x_190); -x_191 = lean_ctor_get(x_188, 0); -lean_inc(x_191); -lean_dec(x_188); -x_192 = lean_ctor_get(x_189, 0); -lean_inc(x_192); -x_193 = lean_ctor_get(x_189, 1); -lean_inc(x_193); -x_194 = lean_ctor_get(x_189, 3); -lean_inc(x_194); -x_195 = lean_ctor_get(x_189, 4); -lean_inc(x_195); -x_196 = lean_ctor_get(x_189, 5); -lean_inc(x_196); -if (lean_is_exclusive(x_189)) { - lean_ctor_release(x_189, 0); - lean_ctor_release(x_189, 1); - lean_ctor_release(x_189, 2); - lean_ctor_release(x_189, 3); - lean_ctor_release(x_189, 4); - lean_ctor_release(x_189, 5); - x_197 = x_189; -} else { - lean_dec_ref(x_189); - x_197 = lean_box(0); -} -x_198 = lean_ctor_get(x_190, 0); -lean_inc(x_198); -x_199 = lean_ctor_get(x_190, 1); -lean_inc(x_199); -x_200 = lean_ctor_get(x_190, 3); -lean_inc(x_200); -if (lean_is_exclusive(x_190)) { - lean_ctor_release(x_190, 0); - lean_ctor_release(x_190, 1); - lean_ctor_release(x_190, 2); - lean_ctor_release(x_190, 3); - x_201 = x_190; -} else { - lean_dec_ref(x_190); - x_201 = lean_box(0); -} -if (lean_is_scalar(x_201)) { - x_202 = lean_alloc_ctor(0, 4, 0); -} else { - x_202 = x_201; -} -lean_ctor_set(x_202, 0, x_198); -lean_ctor_set(x_202, 1, x_199); -lean_ctor_set(x_202, 2, x_185); -lean_ctor_set(x_202, 3, x_200); -if (lean_is_scalar(x_197)) { - x_203 = lean_alloc_ctor(0, 6, 0); -} else { - x_203 = x_197; -} -lean_ctor_set(x_203, 0, x_192); -lean_ctor_set(x_203, 1, x_193); -lean_ctor_set(x_203, 2, x_202); -lean_ctor_set(x_203, 3, x_194); -lean_ctor_set(x_203, 4, x_195); -lean_ctor_set(x_203, 5, x_196); -if (lean_is_scalar(x_36)) { - x_204 = lean_alloc_ctor(1, 2, 0); -} else { - x_204 = x_36; - lean_ctor_set_tag(x_204, 1); -} -lean_ctor_set(x_204, 0, x_191); -lean_ctor_set(x_204, 1, x_203); -return x_204; +lean_object* x_244; lean_object* x_245; lean_object* x_246; +x_244 = lean_ctor_get(x_243, 0); +lean_inc(x_244); +x_245 = lean_ctor_get(x_243, 1); +lean_inc(x_245); +lean_dec(x_243); +x_246 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_246, 0, x_244); +x_196 = x_246; +x_197 = x_245; +goto block_230; } else { -lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; -x_205 = lean_ctor_get(x_189, 2); -lean_inc(x_205); -x_206 = lean_ctor_get(x_188, 0); +lean_object* x_247; lean_object* x_248; lean_object* x_249; +x_247 = lean_ctor_get(x_243, 0); +lean_inc(x_247); +x_248 = lean_ctor_get(x_243, 1); +lean_inc(x_248); +lean_dec(x_243); +x_249 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_249, 0, x_247); +x_196 = x_249; +x_197 = x_248; +goto block_230; +} +block_230: +{ +if (lean_obj_tag(x_196) == 0) +{ +lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; +x_198 = lean_ctor_get(x_197, 2); +lean_inc(x_198); +x_199 = lean_ctor_get(x_196, 0); +lean_inc(x_199); +lean_dec(x_196); +x_200 = lean_ctor_get(x_197, 0); +lean_inc(x_200); +x_201 = lean_ctor_get(x_197, 1); +lean_inc(x_201); +x_202 = lean_ctor_get(x_197, 3); +lean_inc(x_202); +x_203 = lean_ctor_get(x_197, 4); +lean_inc(x_203); +x_204 = lean_ctor_get(x_197, 5); +lean_inc(x_204); +if (lean_is_exclusive(x_197)) { + lean_ctor_release(x_197, 0); + lean_ctor_release(x_197, 1); + lean_ctor_release(x_197, 2); + lean_ctor_release(x_197, 3); + lean_ctor_release(x_197, 4); + lean_ctor_release(x_197, 5); + x_205 = x_197; +} else { + lean_dec_ref(x_197); + x_205 = lean_box(0); +} +x_206 = lean_ctor_get(x_198, 0); lean_inc(x_206); -lean_dec(x_188); -x_207 = lean_ctor_get(x_189, 0); +x_207 = lean_ctor_get(x_198, 1); lean_inc(x_207); -x_208 = lean_ctor_get(x_189, 1); +x_208 = lean_ctor_get(x_198, 3); lean_inc(x_208); -x_209 = lean_ctor_get(x_189, 3); +x_209 = lean_ctor_get(x_198, 4); lean_inc(x_209); -x_210 = lean_ctor_get(x_189, 4); -lean_inc(x_210); -x_211 = lean_ctor_get(x_189, 5); -lean_inc(x_211); -if (lean_is_exclusive(x_189)) { - lean_ctor_release(x_189, 0); - lean_ctor_release(x_189, 1); - lean_ctor_release(x_189, 2); - lean_ctor_release(x_189, 3); - lean_ctor_release(x_189, 4); - lean_ctor_release(x_189, 5); - x_212 = x_189; +if (lean_is_exclusive(x_198)) { + lean_ctor_release(x_198, 0); + lean_ctor_release(x_198, 1); + lean_ctor_release(x_198, 2); + lean_ctor_release(x_198, 3); + lean_ctor_release(x_198, 4); + x_210 = x_198; } else { - lean_dec_ref(x_189); - x_212 = lean_box(0); + lean_dec_ref(x_198); + x_210 = lean_box(0); } -x_213 = lean_ctor_get(x_205, 0); -lean_inc(x_213); -x_214 = lean_ctor_get(x_205, 1); -lean_inc(x_214); -x_215 = lean_ctor_get(x_205, 3); -lean_inc(x_215); -if (lean_is_exclusive(x_205)) { - lean_ctor_release(x_205, 0); - lean_ctor_release(x_205, 1); - lean_ctor_release(x_205, 2); - lean_ctor_release(x_205, 3); - x_216 = x_205; +if (lean_is_scalar(x_210)) { + x_211 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_205); - x_216 = lean_box(0); + x_211 = x_210; } -if (lean_is_scalar(x_216)) { - x_217 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_211, 0, x_206); +lean_ctor_set(x_211, 1, x_207); +lean_ctor_set(x_211, 2, x_192); +lean_ctor_set(x_211, 3, x_208); +lean_ctor_set(x_211, 4, x_209); +if (lean_is_scalar(x_205)) { + x_212 = lean_alloc_ctor(0, 6, 0); } else { - x_217 = x_216; + x_212 = x_205; } -lean_ctor_set(x_217, 0, x_213); -lean_ctor_set(x_217, 1, x_214); -lean_ctor_set(x_217, 2, x_185); -lean_ctor_set(x_217, 3, x_215); -if (lean_is_scalar(x_212)) { - x_218 = lean_alloc_ctor(0, 6, 0); -} else { - x_218 = x_212; -} -lean_ctor_set(x_218, 0, x_207); -lean_ctor_set(x_218, 1, x_208); -lean_ctor_set(x_218, 2, x_217); -lean_ctor_set(x_218, 3, x_209); -lean_ctor_set(x_218, 4, x_210); -lean_ctor_set(x_218, 5, x_211); +lean_ctor_set(x_212, 0, x_200); +lean_ctor_set(x_212, 1, x_201); +lean_ctor_set(x_212, 2, x_211); +lean_ctor_set(x_212, 3, x_202); +lean_ctor_set(x_212, 4, x_203); +lean_ctor_set(x_212, 5, x_204); if (lean_is_scalar(x_36)) { - x_219 = lean_alloc_ctor(0, 2, 0); + x_213 = lean_alloc_ctor(1, 2, 0); } else { - x_219 = x_36; + x_213 = x_36; + lean_ctor_set_tag(x_213, 1); } -lean_ctor_set(x_219, 0, x_206); -lean_ctor_set(x_219, 1, x_218); -return x_219; +lean_ctor_set(x_213, 0, x_199); +lean_ctor_set(x_213, 1, x_212); +return x_213; +} +else +{ +lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; 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; +x_214 = lean_ctor_get(x_197, 2); +lean_inc(x_214); +x_215 = lean_ctor_get(x_196, 0); +lean_inc(x_215); +lean_dec(x_196); +x_216 = lean_ctor_get(x_197, 0); +lean_inc(x_216); +x_217 = lean_ctor_get(x_197, 1); +lean_inc(x_217); +x_218 = lean_ctor_get(x_197, 3); +lean_inc(x_218); +x_219 = lean_ctor_get(x_197, 4); +lean_inc(x_219); +x_220 = lean_ctor_get(x_197, 5); +lean_inc(x_220); +if (lean_is_exclusive(x_197)) { + lean_ctor_release(x_197, 0); + lean_ctor_release(x_197, 1); + lean_ctor_release(x_197, 2); + lean_ctor_release(x_197, 3); + lean_ctor_release(x_197, 4); + lean_ctor_release(x_197, 5); + x_221 = x_197; +} else { + lean_dec_ref(x_197); + x_221 = lean_box(0); +} +x_222 = lean_ctor_get(x_214, 0); +lean_inc(x_222); +x_223 = lean_ctor_get(x_214, 1); +lean_inc(x_223); +x_224 = lean_ctor_get(x_214, 3); +lean_inc(x_224); +x_225 = lean_ctor_get(x_214, 4); +lean_inc(x_225); +if (lean_is_exclusive(x_214)) { + lean_ctor_release(x_214, 0); + lean_ctor_release(x_214, 1); + lean_ctor_release(x_214, 2); + lean_ctor_release(x_214, 3); + lean_ctor_release(x_214, 4); + x_226 = x_214; +} else { + lean_dec_ref(x_214); + x_226 = lean_box(0); +} +if (lean_is_scalar(x_226)) { + x_227 = lean_alloc_ctor(0, 5, 0); +} else { + x_227 = x_226; +} +lean_ctor_set(x_227, 0, x_222); +lean_ctor_set(x_227, 1, x_223); +lean_ctor_set(x_227, 2, x_192); +lean_ctor_set(x_227, 3, x_224); +lean_ctor_set(x_227, 4, x_225); +if (lean_is_scalar(x_221)) { + x_228 = lean_alloc_ctor(0, 6, 0); +} else { + x_228 = x_221; +} +lean_ctor_set(x_228, 0, x_216); +lean_ctor_set(x_228, 1, x_217); +lean_ctor_set(x_228, 2, x_227); +lean_ctor_set(x_228, 3, x_218); +lean_ctor_set(x_228, 4, x_219); +lean_ctor_set(x_228, 5, x_220); +if (lean_is_scalar(x_36)) { + x_229 = lean_alloc_ctor(0, 2, 0); +} else { + x_229 = x_36; +} +lean_ctor_set(x_229, 0, x_215); +lean_ctor_set(x_229, 1, x_228); +return x_229; } } } } default: { -lean_object* x_240; lean_object* x_241; -x_240 = lean_ctor_get(x_29, 1); -lean_inc(x_240); +lean_object* x_250; lean_object* x_251; +x_250 = lean_ctor_get(x_29, 1); +lean_inc(x_250); lean_dec(x_29); lean_inc(x_8); -x_241 = l_Lean_Meta_isClassExpensive___main(x_28, x_8, x_240); -if (lean_obj_tag(x_241) == 0) +x_251 = l_Lean_Meta_isClassExpensive___main(x_28, x_8, x_250); +if (lean_obj_tag(x_251) == 0) { -lean_object* x_242; -x_242 = lean_ctor_get(x_241, 0); -lean_inc(x_242); -if (lean_obj_tag(x_242) == 0) +lean_object* x_252; +x_252 = lean_ctor_get(x_251, 0); +lean_inc(x_252); +if (lean_obj_tag(x_252) == 0) { -lean_object* x_243; lean_object* x_244; lean_object* x_245; +lean_object* x_253; lean_object* x_254; lean_object* x_255; lean_dec(x_24); -x_243 = lean_ctor_get(x_241, 1); -lean_inc(x_243); -lean_dec(x_241); -x_244 = lean_unsigned_to_nat(1u); -x_245 = lean_nat_add(x_7, x_244); +x_253 = lean_ctor_get(x_251, 1); +lean_inc(x_253); +lean_dec(x_251); +x_254 = lean_unsigned_to_nat(1u); +x_255 = lean_nat_add(x_7, x_254); lean_dec(x_7); -x_7 = x_245; -x_9 = x_243; +x_7 = x_255; +x_9 = x_253; goto _start; } else { -lean_object* x_247; lean_object* x_248; lean_object* x_249; lean_object* x_250; lean_object* x_251; uint8_t x_252; -x_247 = lean_ctor_get(x_241, 1); -lean_inc(x_247); -if (lean_is_exclusive(x_241)) { - lean_ctor_release(x_241, 0); - lean_ctor_release(x_241, 1); - x_248 = x_241; +lean_object* x_257; lean_object* x_258; lean_object* x_259; lean_object* x_260; lean_object* x_261; uint8_t x_262; +x_257 = lean_ctor_get(x_251, 1); +lean_inc(x_257); +if (lean_is_exclusive(x_251)) { + lean_ctor_release(x_251, 0); + lean_ctor_release(x_251, 1); + x_258 = x_251; } else { - lean_dec_ref(x_241); - x_248 = lean_box(0); + lean_dec_ref(x_251); + x_258 = lean_box(0); } -x_249 = lean_ctor_get(x_242, 0); -lean_inc(x_249); -lean_dec(x_242); -x_250 = lean_unsigned_to_nat(1u); -x_251 = lean_nat_add(x_7, x_250); -lean_dec(x_7); -x_252 = !lean_is_exclusive(x_247); -if (x_252 == 0) -{ -lean_object* x_253; uint8_t x_254; -x_253 = lean_ctor_get(x_247, 2); -x_254 = !lean_is_exclusive(x_253); -if (x_254 == 0) -{ -lean_object* x_255; lean_object* x_256; lean_object* x_257; lean_object* x_307; uint8_t x_308; -x_255 = lean_ctor_get(x_253, 2); -x_307 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_253, 2, x_307); -x_308 = !lean_is_exclusive(x_8); -if (x_308 == 0) -{ -lean_object* x_309; lean_object* x_310; lean_object* x_311; lean_object* x_312; -x_309 = lean_ctor_get(x_8, 2); -x_310 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_310, 0, x_249); -lean_ctor_set(x_310, 1, x_24); -x_311 = lean_array_push(x_309, x_310); -lean_ctor_set(x_8, 2, x_311); -x_312 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_251, x_8, x_247); -if (lean_obj_tag(x_312) == 0) -{ -lean_object* x_313; lean_object* x_314; lean_object* x_315; -x_313 = lean_ctor_get(x_312, 0); -lean_inc(x_313); -x_314 = lean_ctor_get(x_312, 1); -lean_inc(x_314); -lean_dec(x_312); -x_315 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_315, 0, x_313); -x_256 = x_315; -x_257 = x_314; -goto block_306; -} -else -{ -lean_object* x_316; lean_object* x_317; lean_object* x_318; -x_316 = lean_ctor_get(x_312, 0); -lean_inc(x_316); -x_317 = lean_ctor_get(x_312, 1); -lean_inc(x_317); -lean_dec(x_312); -x_318 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_318, 0, x_316); -x_256 = x_318; -x_257 = x_317; -goto block_306; -} -} -else -{ -lean_object* x_319; lean_object* x_320; lean_object* x_321; lean_object* x_322; lean_object* x_323; lean_object* x_324; lean_object* x_325; lean_object* x_326; lean_object* x_327; -x_319 = lean_ctor_get(x_8, 0); -x_320 = lean_ctor_get(x_8, 1); -x_321 = lean_ctor_get(x_8, 2); -x_322 = lean_ctor_get(x_8, 3); -x_323 = lean_ctor_get(x_8, 4); -lean_inc(x_323); -lean_inc(x_322); -lean_inc(x_321); -lean_inc(x_320); -lean_inc(x_319); -lean_dec(x_8); -x_324 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_324, 0, x_249); -lean_ctor_set(x_324, 1, x_24); -x_325 = lean_array_push(x_321, x_324); -x_326 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_326, 0, x_319); -lean_ctor_set(x_326, 1, x_320); -lean_ctor_set(x_326, 2, x_325); -lean_ctor_set(x_326, 3, x_322); -lean_ctor_set(x_326, 4, x_323); -x_327 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_251, x_326, x_247); -if (lean_obj_tag(x_327) == 0) -{ -lean_object* x_328; lean_object* x_329; lean_object* x_330; -x_328 = lean_ctor_get(x_327, 0); -lean_inc(x_328); -x_329 = lean_ctor_get(x_327, 1); -lean_inc(x_329); -lean_dec(x_327); -x_330 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_330, 0, x_328); -x_256 = x_330; -x_257 = x_329; -goto block_306; -} -else -{ -lean_object* x_331; lean_object* x_332; lean_object* x_333; -x_331 = lean_ctor_get(x_327, 0); -lean_inc(x_331); -x_332 = lean_ctor_get(x_327, 1); -lean_inc(x_332); -lean_dec(x_327); -x_333 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_333, 0, x_331); -x_256 = x_333; -x_257 = x_332; -goto block_306; -} -} -block_306: -{ -if (lean_obj_tag(x_256) == 0) -{ -lean_object* x_258; lean_object* x_259; uint8_t x_260; -x_258 = lean_ctor_get(x_257, 2); -lean_inc(x_258); -x_259 = lean_ctor_get(x_256, 0); +x_259 = lean_ctor_get(x_252, 0); lean_inc(x_259); -lean_dec(x_256); -x_260 = !lean_is_exclusive(x_257); -if (x_260 == 0) -{ -lean_object* x_261; uint8_t x_262; -x_261 = lean_ctor_get(x_257, 2); -lean_dec(x_261); -x_262 = !lean_is_exclusive(x_258); +lean_dec(x_252); +x_260 = lean_unsigned_to_nat(1u); +x_261 = lean_nat_add(x_7, x_260); +lean_dec(x_7); +x_262 = !lean_is_exclusive(x_257); if (x_262 == 0) { -lean_object* x_263; lean_object* x_264; -x_263 = lean_ctor_get(x_258, 2); -lean_dec(x_263); -lean_ctor_set(x_258, 2, x_255); -if (lean_is_scalar(x_248)) { - x_264 = lean_alloc_ctor(1, 2, 0); -} else { - x_264 = x_248; - lean_ctor_set_tag(x_264, 1); -} -lean_ctor_set(x_264, 0, x_259); -lean_ctor_set(x_264, 1, x_257); -return x_264; +lean_object* x_263; uint8_t x_264; +x_263 = lean_ctor_get(x_257, 2); +x_264 = !lean_is_exclusive(x_263); +if (x_264 == 0) +{ +lean_object* x_265; lean_object* x_266; lean_object* x_267; lean_object* x_321; uint8_t x_322; +x_265 = lean_ctor_get(x_263, 2); +x_321 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_263, 2, x_321); +x_322 = !lean_is_exclusive(x_8); +if (x_322 == 0) +{ +lean_object* x_323; lean_object* x_324; lean_object* x_325; lean_object* x_326; +x_323 = lean_ctor_get(x_8, 2); +x_324 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_324, 0, x_259); +lean_ctor_set(x_324, 1, x_24); +x_325 = lean_array_push(x_323, x_324); +lean_ctor_set(x_8, 2, x_325); +x_326 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_261, x_8, x_257); +if (lean_obj_tag(x_326) == 0) +{ +lean_object* x_327; lean_object* x_328; lean_object* x_329; +x_327 = lean_ctor_get(x_326, 0); +lean_inc(x_327); +x_328 = lean_ctor_get(x_326, 1); +lean_inc(x_328); +lean_dec(x_326); +x_329 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_329, 0, x_327); +x_266 = x_329; +x_267 = x_328; +goto block_320; } else { -lean_object* x_265; lean_object* x_266; lean_object* x_267; lean_object* x_268; lean_object* x_269; -x_265 = lean_ctor_get(x_258, 0); -x_266 = lean_ctor_get(x_258, 1); -x_267 = lean_ctor_get(x_258, 3); -lean_inc(x_267); -lean_inc(x_266); -lean_inc(x_265); -lean_dec(x_258); -x_268 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_268, 0, x_265); -lean_ctor_set(x_268, 1, x_266); -lean_ctor_set(x_268, 2, x_255); -lean_ctor_set(x_268, 3, x_267); -lean_ctor_set(x_257, 2, x_268); -if (lean_is_scalar(x_248)) { - x_269 = lean_alloc_ctor(1, 2, 0); -} else { - x_269 = x_248; - lean_ctor_set_tag(x_269, 1); -} -lean_ctor_set(x_269, 0, x_259); -lean_ctor_set(x_269, 1, x_257); -return x_269; +lean_object* x_330; lean_object* x_331; lean_object* x_332; +x_330 = lean_ctor_get(x_326, 0); +lean_inc(x_330); +x_331 = lean_ctor_get(x_326, 1); +lean_inc(x_331); +lean_dec(x_326); +x_332 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_332, 0, x_330); +x_266 = x_332; +x_267 = x_331; +goto block_320; } } else { -lean_object* x_270; lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_object* x_276; lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; lean_object* x_281; -x_270 = lean_ctor_get(x_257, 0); -x_271 = lean_ctor_get(x_257, 1); -x_272 = lean_ctor_get(x_257, 3); -x_273 = lean_ctor_get(x_257, 4); -x_274 = lean_ctor_get(x_257, 5); -lean_inc(x_274); -lean_inc(x_273); -lean_inc(x_272); -lean_inc(x_271); -lean_inc(x_270); -lean_dec(x_257); -x_275 = lean_ctor_get(x_258, 0); -lean_inc(x_275); -x_276 = lean_ctor_get(x_258, 1); -lean_inc(x_276); -x_277 = lean_ctor_get(x_258, 3); +lean_object* x_333; lean_object* x_334; lean_object* x_335; lean_object* x_336; lean_object* x_337; lean_object* x_338; lean_object* x_339; lean_object* x_340; lean_object* x_341; +x_333 = lean_ctor_get(x_8, 0); +x_334 = lean_ctor_get(x_8, 1); +x_335 = lean_ctor_get(x_8, 2); +x_336 = lean_ctor_get(x_8, 3); +x_337 = lean_ctor_get(x_8, 4); +lean_inc(x_337); +lean_inc(x_336); +lean_inc(x_335); +lean_inc(x_334); +lean_inc(x_333); +lean_dec(x_8); +x_338 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_338, 0, x_259); +lean_ctor_set(x_338, 1, x_24); +x_339 = lean_array_push(x_335, x_338); +x_340 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_340, 0, x_333); +lean_ctor_set(x_340, 1, x_334); +lean_ctor_set(x_340, 2, x_339); +lean_ctor_set(x_340, 3, x_336); +lean_ctor_set(x_340, 4, x_337); +x_341 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_261, x_340, x_257); +if (lean_obj_tag(x_341) == 0) +{ +lean_object* x_342; lean_object* x_343; lean_object* x_344; +x_342 = lean_ctor_get(x_341, 0); +lean_inc(x_342); +x_343 = lean_ctor_get(x_341, 1); +lean_inc(x_343); +lean_dec(x_341); +x_344 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_344, 0, x_342); +x_266 = x_344; +x_267 = x_343; +goto block_320; +} +else +{ +lean_object* x_345; lean_object* x_346; lean_object* x_347; +x_345 = lean_ctor_get(x_341, 0); +lean_inc(x_345); +x_346 = lean_ctor_get(x_341, 1); +lean_inc(x_346); +lean_dec(x_341); +x_347 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_347, 0, x_345); +x_266 = x_347; +x_267 = x_346; +goto block_320; +} +} +block_320: +{ +if (lean_obj_tag(x_266) == 0) +{ +lean_object* x_268; lean_object* x_269; uint8_t x_270; +x_268 = lean_ctor_get(x_267, 2); +lean_inc(x_268); +x_269 = lean_ctor_get(x_266, 0); +lean_inc(x_269); +lean_dec(x_266); +x_270 = !lean_is_exclusive(x_267); +if (x_270 == 0) +{ +lean_object* x_271; uint8_t x_272; +x_271 = lean_ctor_get(x_267, 2); +lean_dec(x_271); +x_272 = !lean_is_exclusive(x_268); +if (x_272 == 0) +{ +lean_object* x_273; lean_object* x_274; +x_273 = lean_ctor_get(x_268, 2); +lean_dec(x_273); +lean_ctor_set(x_268, 2, x_265); +if (lean_is_scalar(x_258)) { + x_274 = lean_alloc_ctor(1, 2, 0); +} else { + x_274 = x_258; + lean_ctor_set_tag(x_274, 1); +} +lean_ctor_set(x_274, 0, x_269); +lean_ctor_set(x_274, 1, x_267); +return x_274; +} +else +{ +lean_object* x_275; lean_object* x_276; lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; +x_275 = lean_ctor_get(x_268, 0); +x_276 = lean_ctor_get(x_268, 1); +x_277 = lean_ctor_get(x_268, 3); +x_278 = lean_ctor_get(x_268, 4); +lean_inc(x_278); lean_inc(x_277); -if (lean_is_exclusive(x_258)) { - lean_ctor_release(x_258, 0); - lean_ctor_release(x_258, 1); - lean_ctor_release(x_258, 2); - lean_ctor_release(x_258, 3); - x_278 = x_258; -} else { - lean_dec_ref(x_258); - x_278 = lean_box(0); -} -if (lean_is_scalar(x_278)) { - x_279 = lean_alloc_ctor(0, 4, 0); -} else { - x_279 = x_278; -} +lean_inc(x_276); +lean_inc(x_275); +lean_dec(x_268); +x_279 = lean_alloc_ctor(0, 5, 0); lean_ctor_set(x_279, 0, x_275); lean_ctor_set(x_279, 1, x_276); -lean_ctor_set(x_279, 2, x_255); +lean_ctor_set(x_279, 2, x_265); lean_ctor_set(x_279, 3, x_277); -x_280 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_280, 0, x_270); -lean_ctor_set(x_280, 1, x_271); -lean_ctor_set(x_280, 2, x_279); -lean_ctor_set(x_280, 3, x_272); -lean_ctor_set(x_280, 4, x_273); -lean_ctor_set(x_280, 5, x_274); -if (lean_is_scalar(x_248)) { - x_281 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_279, 4, x_278); +lean_ctor_set(x_267, 2, x_279); +if (lean_is_scalar(x_258)) { + x_280 = lean_alloc_ctor(1, 2, 0); } else { - x_281 = x_248; - lean_ctor_set_tag(x_281, 1); + x_280 = x_258; + lean_ctor_set_tag(x_280, 1); } -lean_ctor_set(x_281, 0, x_259); -lean_ctor_set(x_281, 1, x_280); -return x_281; +lean_ctor_set(x_280, 0, x_269); +lean_ctor_set(x_280, 1, x_267); +return x_280; } } else { -lean_object* x_282; lean_object* x_283; uint8_t x_284; -x_282 = lean_ctor_get(x_257, 2); -lean_inc(x_282); -x_283 = lean_ctor_get(x_256, 0); +lean_object* x_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; lean_object* x_289; lean_object* x_290; lean_object* x_291; lean_object* x_292; lean_object* x_293; +x_281 = lean_ctor_get(x_267, 0); +x_282 = lean_ctor_get(x_267, 1); +x_283 = lean_ctor_get(x_267, 3); +x_284 = lean_ctor_get(x_267, 4); +x_285 = lean_ctor_get(x_267, 5); +lean_inc(x_285); +lean_inc(x_284); lean_inc(x_283); -lean_dec(x_256); -x_284 = !lean_is_exclusive(x_257); -if (x_284 == 0) -{ -lean_object* x_285; uint8_t x_286; -x_285 = lean_ctor_get(x_257, 2); -lean_dec(x_285); -x_286 = !lean_is_exclusive(x_282); -if (x_286 == 0) -{ -lean_object* x_287; lean_object* x_288; -x_287 = lean_ctor_get(x_282, 2); -lean_dec(x_287); -lean_ctor_set(x_282, 2, x_255); -if (lean_is_scalar(x_248)) { - x_288 = lean_alloc_ctor(0, 2, 0); -} else { - x_288 = x_248; -} -lean_ctor_set(x_288, 0, x_283); -lean_ctor_set(x_288, 1, x_257); -return x_288; -} -else -{ -lean_object* x_289; lean_object* x_290; lean_object* x_291; lean_object* x_292; lean_object* x_293; -x_289 = lean_ctor_get(x_282, 0); -x_290 = lean_ctor_get(x_282, 1); -x_291 = lean_ctor_get(x_282, 3); -lean_inc(x_291); -lean_inc(x_290); +lean_inc(x_282); +lean_inc(x_281); +lean_dec(x_267); +x_286 = lean_ctor_get(x_268, 0); +lean_inc(x_286); +x_287 = lean_ctor_get(x_268, 1); +lean_inc(x_287); +x_288 = lean_ctor_get(x_268, 3); +lean_inc(x_288); +x_289 = lean_ctor_get(x_268, 4); lean_inc(x_289); -lean_dec(x_282); -x_292 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_292, 0, x_289); -lean_ctor_set(x_292, 1, x_290); -lean_ctor_set(x_292, 2, x_255); -lean_ctor_set(x_292, 3, x_291); -lean_ctor_set(x_257, 2, x_292); -if (lean_is_scalar(x_248)) { - x_293 = lean_alloc_ctor(0, 2, 0); +if (lean_is_exclusive(x_268)) { + lean_ctor_release(x_268, 0); + lean_ctor_release(x_268, 1); + lean_ctor_release(x_268, 2); + lean_ctor_release(x_268, 3); + lean_ctor_release(x_268, 4); + x_290 = x_268; } else { - x_293 = x_248; + lean_dec_ref(x_268); + x_290 = lean_box(0); } -lean_ctor_set(x_293, 0, x_283); -lean_ctor_set(x_293, 1, x_257); +if (lean_is_scalar(x_290)) { + x_291 = lean_alloc_ctor(0, 5, 0); +} else { + x_291 = x_290; +} +lean_ctor_set(x_291, 0, x_286); +lean_ctor_set(x_291, 1, x_287); +lean_ctor_set(x_291, 2, x_265); +lean_ctor_set(x_291, 3, x_288); +lean_ctor_set(x_291, 4, x_289); +x_292 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_292, 0, x_281); +lean_ctor_set(x_292, 1, x_282); +lean_ctor_set(x_292, 2, x_291); +lean_ctor_set(x_292, 3, x_283); +lean_ctor_set(x_292, 4, x_284); +lean_ctor_set(x_292, 5, x_285); +if (lean_is_scalar(x_258)) { + x_293 = lean_alloc_ctor(1, 2, 0); +} else { + x_293 = x_258; + lean_ctor_set_tag(x_293, 1); +} +lean_ctor_set(x_293, 0, x_269); +lean_ctor_set(x_293, 1, x_292); return x_293; } } else { -lean_object* x_294; lean_object* x_295; lean_object* x_296; lean_object* x_297; lean_object* x_298; lean_object* x_299; lean_object* x_300; lean_object* x_301; lean_object* x_302; lean_object* x_303; lean_object* x_304; lean_object* x_305; -x_294 = lean_ctor_get(x_257, 0); -x_295 = lean_ctor_get(x_257, 1); -x_296 = lean_ctor_get(x_257, 3); -x_297 = lean_ctor_get(x_257, 4); -x_298 = lean_ctor_get(x_257, 5); -lean_inc(x_298); -lean_inc(x_297); -lean_inc(x_296); -lean_inc(x_295); +lean_object* x_294; lean_object* x_295; uint8_t x_296; +x_294 = lean_ctor_get(x_267, 2); lean_inc(x_294); -lean_dec(x_257); -x_299 = lean_ctor_get(x_282, 0); -lean_inc(x_299); -x_300 = lean_ctor_get(x_282, 1); -lean_inc(x_300); -x_301 = lean_ctor_get(x_282, 3); +x_295 = lean_ctor_get(x_266, 0); +lean_inc(x_295); +lean_dec(x_266); +x_296 = !lean_is_exclusive(x_267); +if (x_296 == 0) +{ +lean_object* x_297; uint8_t x_298; +x_297 = lean_ctor_get(x_267, 2); +lean_dec(x_297); +x_298 = !lean_is_exclusive(x_294); +if (x_298 == 0) +{ +lean_object* x_299; lean_object* x_300; +x_299 = lean_ctor_get(x_294, 2); +lean_dec(x_299); +lean_ctor_set(x_294, 2, x_265); +if (lean_is_scalar(x_258)) { + x_300 = lean_alloc_ctor(0, 2, 0); +} else { + x_300 = x_258; +} +lean_ctor_set(x_300, 0, x_295); +lean_ctor_set(x_300, 1, x_267); +return x_300; +} +else +{ +lean_object* x_301; lean_object* x_302; lean_object* x_303; lean_object* x_304; lean_object* x_305; lean_object* x_306; +x_301 = lean_ctor_get(x_294, 0); +x_302 = lean_ctor_get(x_294, 1); +x_303 = lean_ctor_get(x_294, 3); +x_304 = lean_ctor_get(x_294, 4); +lean_inc(x_304); +lean_inc(x_303); +lean_inc(x_302); lean_inc(x_301); -if (lean_is_exclusive(x_282)) { - lean_ctor_release(x_282, 0); - lean_ctor_release(x_282, 1); - lean_ctor_release(x_282, 2); - lean_ctor_release(x_282, 3); - x_302 = x_282; +lean_dec(x_294); +x_305 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_305, 0, x_301); +lean_ctor_set(x_305, 1, x_302); +lean_ctor_set(x_305, 2, x_265); +lean_ctor_set(x_305, 3, x_303); +lean_ctor_set(x_305, 4, x_304); +lean_ctor_set(x_267, 2, x_305); +if (lean_is_scalar(x_258)) { + x_306 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_282); - x_302 = lean_box(0); + x_306 = x_258; } -if (lean_is_scalar(x_302)) { - x_303 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_306, 0, x_295); +lean_ctor_set(x_306, 1, x_267); +return x_306; +} +} +else +{ +lean_object* x_307; lean_object* x_308; lean_object* x_309; lean_object* x_310; lean_object* x_311; lean_object* x_312; lean_object* x_313; lean_object* x_314; lean_object* x_315; lean_object* x_316; lean_object* x_317; lean_object* x_318; lean_object* x_319; +x_307 = lean_ctor_get(x_267, 0); +x_308 = lean_ctor_get(x_267, 1); +x_309 = lean_ctor_get(x_267, 3); +x_310 = lean_ctor_get(x_267, 4); +x_311 = lean_ctor_get(x_267, 5); +lean_inc(x_311); +lean_inc(x_310); +lean_inc(x_309); +lean_inc(x_308); +lean_inc(x_307); +lean_dec(x_267); +x_312 = lean_ctor_get(x_294, 0); +lean_inc(x_312); +x_313 = lean_ctor_get(x_294, 1); +lean_inc(x_313); +x_314 = lean_ctor_get(x_294, 3); +lean_inc(x_314); +x_315 = lean_ctor_get(x_294, 4); +lean_inc(x_315); +if (lean_is_exclusive(x_294)) { + lean_ctor_release(x_294, 0); + lean_ctor_release(x_294, 1); + lean_ctor_release(x_294, 2); + lean_ctor_release(x_294, 3); + lean_ctor_release(x_294, 4); + x_316 = x_294; } else { - x_303 = x_302; + lean_dec_ref(x_294); + x_316 = lean_box(0); } -lean_ctor_set(x_303, 0, x_299); -lean_ctor_set(x_303, 1, x_300); -lean_ctor_set(x_303, 2, x_255); -lean_ctor_set(x_303, 3, x_301); -x_304 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_304, 0, x_294); -lean_ctor_set(x_304, 1, x_295); -lean_ctor_set(x_304, 2, x_303); -lean_ctor_set(x_304, 3, x_296); -lean_ctor_set(x_304, 4, x_297); -lean_ctor_set(x_304, 5, x_298); -if (lean_is_scalar(x_248)) { - x_305 = lean_alloc_ctor(0, 2, 0); +if (lean_is_scalar(x_316)) { + x_317 = lean_alloc_ctor(0, 5, 0); } else { - x_305 = x_248; + x_317 = x_316; } -lean_ctor_set(x_305, 0, x_283); -lean_ctor_set(x_305, 1, x_304); -return x_305; +lean_ctor_set(x_317, 0, x_312); +lean_ctor_set(x_317, 1, x_313); +lean_ctor_set(x_317, 2, x_265); +lean_ctor_set(x_317, 3, x_314); +lean_ctor_set(x_317, 4, x_315); +x_318 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_318, 0, x_307); +lean_ctor_set(x_318, 1, x_308); +lean_ctor_set(x_318, 2, x_317); +lean_ctor_set(x_318, 3, x_309); +lean_ctor_set(x_318, 4, x_310); +lean_ctor_set(x_318, 5, x_311); +if (lean_is_scalar(x_258)) { + x_319 = lean_alloc_ctor(0, 2, 0); +} else { + x_319 = x_258; +} +lean_ctor_set(x_319, 0, x_295); +lean_ctor_set(x_319, 1, x_318); +return x_319; } } } } else { -lean_object* x_334; lean_object* x_335; lean_object* x_336; lean_object* x_337; lean_object* x_338; lean_object* x_339; lean_object* x_371; lean_object* x_372; lean_object* x_373; lean_object* x_374; lean_object* x_375; 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; -x_334 = lean_ctor_get(x_253, 0); -x_335 = lean_ctor_get(x_253, 1); -x_336 = lean_ctor_get(x_253, 2); -x_337 = lean_ctor_get(x_253, 3); -lean_inc(x_337); -lean_inc(x_336); -lean_inc(x_335); -lean_inc(x_334); -lean_dec(x_253); -x_371 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_372 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_372, 0, x_334); -lean_ctor_set(x_372, 1, x_335); -lean_ctor_set(x_372, 2, x_371); -lean_ctor_set(x_372, 3, x_337); -lean_ctor_set(x_247, 2, x_372); -x_373 = lean_ctor_get(x_8, 0); -lean_inc(x_373); -x_374 = lean_ctor_get(x_8, 1); -lean_inc(x_374); -x_375 = lean_ctor_get(x_8, 2); -lean_inc(x_375); -x_376 = lean_ctor_get(x_8, 3); -lean_inc(x_376); -x_377 = lean_ctor_get(x_8, 4); -lean_inc(x_377); +lean_object* x_348; lean_object* x_349; lean_object* x_350; lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_388; lean_object* x_389; lean_object* x_390; lean_object* x_391; lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; +x_348 = lean_ctor_get(x_263, 0); +x_349 = lean_ctor_get(x_263, 1); +x_350 = lean_ctor_get(x_263, 2); +x_351 = lean_ctor_get(x_263, 3); +x_352 = lean_ctor_get(x_263, 4); +lean_inc(x_352); +lean_inc(x_351); +lean_inc(x_350); +lean_inc(x_349); +lean_inc(x_348); +lean_dec(x_263); +x_388 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_389 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_389, 0, x_348); +lean_ctor_set(x_389, 1, x_349); +lean_ctor_set(x_389, 2, x_388); +lean_ctor_set(x_389, 3, x_351); +lean_ctor_set(x_389, 4, x_352); +lean_ctor_set(x_257, 2, x_389); +x_390 = lean_ctor_get(x_8, 0); +lean_inc(x_390); +x_391 = lean_ctor_get(x_8, 1); +lean_inc(x_391); +x_392 = lean_ctor_get(x_8, 2); +lean_inc(x_392); +x_393 = lean_ctor_get(x_8, 3); +lean_inc(x_393); +x_394 = lean_ctor_get(x_8, 4); +lean_inc(x_394); if (lean_is_exclusive(x_8)) { lean_ctor_release(x_8, 0); lean_ctor_release(x_8, 1); lean_ctor_release(x_8, 2); lean_ctor_release(x_8, 3); lean_ctor_release(x_8, 4); - x_378 = x_8; + x_395 = x_8; } else { lean_dec_ref(x_8); - x_378 = lean_box(0); + x_395 = lean_box(0); } -x_379 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_379, 0, x_249); -lean_ctor_set(x_379, 1, x_24); -x_380 = lean_array_push(x_375, x_379); -if (lean_is_scalar(x_378)) { - x_381 = lean_alloc_ctor(0, 5, 0); +x_396 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_396, 0, x_259); +lean_ctor_set(x_396, 1, x_24); +x_397 = lean_array_push(x_392, x_396); +if (lean_is_scalar(x_395)) { + x_398 = lean_alloc_ctor(0, 5, 0); } else { - x_381 = x_378; + x_398 = x_395; } -lean_ctor_set(x_381, 0, x_373); -lean_ctor_set(x_381, 1, x_374); -lean_ctor_set(x_381, 2, x_380); -lean_ctor_set(x_381, 3, x_376); -lean_ctor_set(x_381, 4, x_377); -x_382 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_251, x_381, x_247); -if (lean_obj_tag(x_382) == 0) +lean_ctor_set(x_398, 0, x_390); +lean_ctor_set(x_398, 1, x_391); +lean_ctor_set(x_398, 2, x_397); +lean_ctor_set(x_398, 3, x_393); +lean_ctor_set(x_398, 4, x_394); +x_399 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_261, x_398, x_257); +if (lean_obj_tag(x_399) == 0) { -lean_object* x_383; lean_object* x_384; lean_object* x_385; -x_383 = lean_ctor_get(x_382, 0); -lean_inc(x_383); -x_384 = lean_ctor_get(x_382, 1); -lean_inc(x_384); -lean_dec(x_382); -x_385 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_385, 0, x_383); -x_338 = x_385; -x_339 = x_384; -goto block_370; +lean_object* x_400; lean_object* x_401; lean_object* x_402; +x_400 = lean_ctor_get(x_399, 0); +lean_inc(x_400); +x_401 = lean_ctor_get(x_399, 1); +lean_inc(x_401); +lean_dec(x_399); +x_402 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_402, 0, x_400); +x_353 = x_402; +x_354 = x_401; +goto block_387; } else { -lean_object* x_386; lean_object* x_387; lean_object* x_388; -x_386 = lean_ctor_get(x_382, 0); -lean_inc(x_386); -x_387 = lean_ctor_get(x_382, 1); -lean_inc(x_387); -lean_dec(x_382); -x_388 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_388, 0, x_386); -x_338 = x_388; -x_339 = x_387; -goto block_370; +lean_object* x_403; lean_object* x_404; lean_object* x_405; +x_403 = lean_ctor_get(x_399, 0); +lean_inc(x_403); +x_404 = lean_ctor_get(x_399, 1); +lean_inc(x_404); +lean_dec(x_399); +x_405 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_405, 0, x_403); +x_353 = x_405; +x_354 = x_404; +goto block_387; } -block_370: +block_387: { -if (lean_obj_tag(x_338) == 0) +if (lean_obj_tag(x_353) == 0) { -lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; lean_object* x_350; lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; -x_340 = lean_ctor_get(x_339, 2); -lean_inc(x_340); -x_341 = lean_ctor_get(x_338, 0); -lean_inc(x_341); -lean_dec(x_338); -x_342 = lean_ctor_get(x_339, 0); -lean_inc(x_342); -x_343 = lean_ctor_get(x_339, 1); -lean_inc(x_343); -x_344 = lean_ctor_get(x_339, 3); -lean_inc(x_344); -x_345 = lean_ctor_get(x_339, 4); -lean_inc(x_345); -x_346 = lean_ctor_get(x_339, 5); -lean_inc(x_346); -if (lean_is_exclusive(x_339)) { - lean_ctor_release(x_339, 0); - lean_ctor_release(x_339, 1); - lean_ctor_release(x_339, 2); - lean_ctor_release(x_339, 3); - lean_ctor_release(x_339, 4); - lean_ctor_release(x_339, 5); - x_347 = x_339; -} else { - lean_dec_ref(x_339); - x_347 = lean_box(0); -} -x_348 = lean_ctor_get(x_340, 0); -lean_inc(x_348); -x_349 = lean_ctor_get(x_340, 1); -lean_inc(x_349); -x_350 = lean_ctor_get(x_340, 3); -lean_inc(x_350); -if (lean_is_exclusive(x_340)) { - lean_ctor_release(x_340, 0); - lean_ctor_release(x_340, 1); - lean_ctor_release(x_340, 2); - lean_ctor_release(x_340, 3); - x_351 = x_340; -} else { - lean_dec_ref(x_340); - x_351 = lean_box(0); -} -if (lean_is_scalar(x_351)) { - x_352 = lean_alloc_ctor(0, 4, 0); -} else { - x_352 = x_351; -} -lean_ctor_set(x_352, 0, x_348); -lean_ctor_set(x_352, 1, x_349); -lean_ctor_set(x_352, 2, x_336); -lean_ctor_set(x_352, 3, x_350); -if (lean_is_scalar(x_347)) { - x_353 = lean_alloc_ctor(0, 6, 0); -} else { - x_353 = x_347; -} -lean_ctor_set(x_353, 0, x_342); -lean_ctor_set(x_353, 1, x_343); -lean_ctor_set(x_353, 2, x_352); -lean_ctor_set(x_353, 3, x_344); -lean_ctor_set(x_353, 4, x_345); -lean_ctor_set(x_353, 5, x_346); -if (lean_is_scalar(x_248)) { - x_354 = lean_alloc_ctor(1, 2, 0); -} else { - x_354 = x_248; - lean_ctor_set_tag(x_354, 1); -} -lean_ctor_set(x_354, 0, x_341); -lean_ctor_set(x_354, 1, x_353); -return x_354; -} -else -{ -lean_object* x_355; lean_object* x_356; lean_object* x_357; 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; -x_355 = lean_ctor_get(x_339, 2); +lean_object* x_355; lean_object* x_356; lean_object* x_357; 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; +x_355 = lean_ctor_get(x_354, 2); lean_inc(x_355); -x_356 = lean_ctor_get(x_338, 0); +x_356 = lean_ctor_get(x_353, 0); lean_inc(x_356); -lean_dec(x_338); -x_357 = lean_ctor_get(x_339, 0); +lean_dec(x_353); +x_357 = lean_ctor_get(x_354, 0); lean_inc(x_357); -x_358 = lean_ctor_get(x_339, 1); +x_358 = lean_ctor_get(x_354, 1); lean_inc(x_358); -x_359 = lean_ctor_get(x_339, 3); +x_359 = lean_ctor_get(x_354, 3); lean_inc(x_359); -x_360 = lean_ctor_get(x_339, 4); +x_360 = lean_ctor_get(x_354, 4); lean_inc(x_360); -x_361 = lean_ctor_get(x_339, 5); +x_361 = lean_ctor_get(x_354, 5); lean_inc(x_361); -if (lean_is_exclusive(x_339)) { - lean_ctor_release(x_339, 0); - lean_ctor_release(x_339, 1); - lean_ctor_release(x_339, 2); - lean_ctor_release(x_339, 3); - lean_ctor_release(x_339, 4); - lean_ctor_release(x_339, 5); - x_362 = x_339; +if (lean_is_exclusive(x_354)) { + lean_ctor_release(x_354, 0); + lean_ctor_release(x_354, 1); + lean_ctor_release(x_354, 2); + lean_ctor_release(x_354, 3); + lean_ctor_release(x_354, 4); + lean_ctor_release(x_354, 5); + x_362 = x_354; } else { - lean_dec_ref(x_339); + lean_dec_ref(x_354); x_362 = lean_box(0); } x_363 = lean_ctor_get(x_355, 0); @@ -15419,315 +15619,411 @@ x_364 = lean_ctor_get(x_355, 1); lean_inc(x_364); x_365 = lean_ctor_get(x_355, 3); lean_inc(x_365); +x_366 = lean_ctor_get(x_355, 4); +lean_inc(x_366); if (lean_is_exclusive(x_355)) { lean_ctor_release(x_355, 0); lean_ctor_release(x_355, 1); lean_ctor_release(x_355, 2); lean_ctor_release(x_355, 3); - x_366 = x_355; + lean_ctor_release(x_355, 4); + x_367 = x_355; } else { lean_dec_ref(x_355); - x_366 = lean_box(0); + x_367 = lean_box(0); } -if (lean_is_scalar(x_366)) { - x_367 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_367)) { + x_368 = lean_alloc_ctor(0, 5, 0); } else { - x_367 = x_366; + x_368 = x_367; } -lean_ctor_set(x_367, 0, x_363); -lean_ctor_set(x_367, 1, x_364); -lean_ctor_set(x_367, 2, x_336); -lean_ctor_set(x_367, 3, x_365); +lean_ctor_set(x_368, 0, x_363); +lean_ctor_set(x_368, 1, x_364); +lean_ctor_set(x_368, 2, x_350); +lean_ctor_set(x_368, 3, x_365); +lean_ctor_set(x_368, 4, x_366); if (lean_is_scalar(x_362)) { - x_368 = lean_alloc_ctor(0, 6, 0); + x_369 = lean_alloc_ctor(0, 6, 0); } else { - x_368 = x_362; + x_369 = x_362; } -lean_ctor_set(x_368, 0, x_357); -lean_ctor_set(x_368, 1, x_358); -lean_ctor_set(x_368, 2, x_367); -lean_ctor_set(x_368, 3, x_359); -lean_ctor_set(x_368, 4, x_360); -lean_ctor_set(x_368, 5, x_361); -if (lean_is_scalar(x_248)) { - x_369 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_369, 0, x_357); +lean_ctor_set(x_369, 1, x_358); +lean_ctor_set(x_369, 2, x_368); +lean_ctor_set(x_369, 3, x_359); +lean_ctor_set(x_369, 4, x_360); +lean_ctor_set(x_369, 5, x_361); +if (lean_is_scalar(x_258)) { + x_370 = lean_alloc_ctor(1, 2, 0); } else { - x_369 = x_248; + x_370 = x_258; + lean_ctor_set_tag(x_370, 1); } -lean_ctor_set(x_369, 0, x_356); -lean_ctor_set(x_369, 1, x_368); -return x_369; +lean_ctor_set(x_370, 0, x_356); +lean_ctor_set(x_370, 1, x_369); +return x_370; +} +else +{ +lean_object* x_371; lean_object* x_372; lean_object* x_373; lean_object* x_374; lean_object* x_375; 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; +x_371 = lean_ctor_get(x_354, 2); +lean_inc(x_371); +x_372 = lean_ctor_get(x_353, 0); +lean_inc(x_372); +lean_dec(x_353); +x_373 = lean_ctor_get(x_354, 0); +lean_inc(x_373); +x_374 = lean_ctor_get(x_354, 1); +lean_inc(x_374); +x_375 = lean_ctor_get(x_354, 3); +lean_inc(x_375); +x_376 = lean_ctor_get(x_354, 4); +lean_inc(x_376); +x_377 = lean_ctor_get(x_354, 5); +lean_inc(x_377); +if (lean_is_exclusive(x_354)) { + lean_ctor_release(x_354, 0); + lean_ctor_release(x_354, 1); + lean_ctor_release(x_354, 2); + lean_ctor_release(x_354, 3); + lean_ctor_release(x_354, 4); + lean_ctor_release(x_354, 5); + x_378 = x_354; +} else { + lean_dec_ref(x_354); + x_378 = lean_box(0); +} +x_379 = lean_ctor_get(x_371, 0); +lean_inc(x_379); +x_380 = lean_ctor_get(x_371, 1); +lean_inc(x_380); +x_381 = lean_ctor_get(x_371, 3); +lean_inc(x_381); +x_382 = lean_ctor_get(x_371, 4); +lean_inc(x_382); +if (lean_is_exclusive(x_371)) { + lean_ctor_release(x_371, 0); + lean_ctor_release(x_371, 1); + lean_ctor_release(x_371, 2); + lean_ctor_release(x_371, 3); + lean_ctor_release(x_371, 4); + x_383 = x_371; +} else { + lean_dec_ref(x_371); + x_383 = lean_box(0); +} +if (lean_is_scalar(x_383)) { + x_384 = lean_alloc_ctor(0, 5, 0); +} else { + x_384 = x_383; +} +lean_ctor_set(x_384, 0, x_379); +lean_ctor_set(x_384, 1, x_380); +lean_ctor_set(x_384, 2, x_350); +lean_ctor_set(x_384, 3, x_381); +lean_ctor_set(x_384, 4, x_382); +if (lean_is_scalar(x_378)) { + x_385 = lean_alloc_ctor(0, 6, 0); +} else { + x_385 = x_378; +} +lean_ctor_set(x_385, 0, x_373); +lean_ctor_set(x_385, 1, x_374); +lean_ctor_set(x_385, 2, x_384); +lean_ctor_set(x_385, 3, x_375); +lean_ctor_set(x_385, 4, x_376); +lean_ctor_set(x_385, 5, x_377); +if (lean_is_scalar(x_258)) { + x_386 = lean_alloc_ctor(0, 2, 0); +} else { + x_386 = x_258; +} +lean_ctor_set(x_386, 0, x_372); +lean_ctor_set(x_386, 1, x_385); +return x_386; } } } } else { -lean_object* x_389; lean_object* x_390; lean_object* x_391; lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; lean_object* x_400; lean_object* x_401; 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; lean_object* x_445; -x_389 = lean_ctor_get(x_247, 2); -x_390 = lean_ctor_get(x_247, 0); -x_391 = lean_ctor_get(x_247, 1); -x_392 = lean_ctor_get(x_247, 3); -x_393 = lean_ctor_get(x_247, 4); -x_394 = lean_ctor_get(x_247, 5); -lean_inc(x_394); -lean_inc(x_393); -lean_inc(x_392); -lean_inc(x_389); -lean_inc(x_391); -lean_inc(x_390); -lean_dec(x_247); -x_395 = lean_ctor_get(x_389, 0); -lean_inc(x_395); -x_396 = lean_ctor_get(x_389, 1); -lean_inc(x_396); -x_397 = lean_ctor_get(x_389, 2); -lean_inc(x_397); -x_398 = lean_ctor_get(x_389, 3); -lean_inc(x_398); -if (lean_is_exclusive(x_389)) { - lean_ctor_release(x_389, 0); - lean_ctor_release(x_389, 1); - lean_ctor_release(x_389, 2); - lean_ctor_release(x_389, 3); - x_399 = x_389; +lean_object* x_406; lean_object* x_407; lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_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_453; lean_object* x_454; lean_object* x_455; lean_object* x_456; lean_object* x_457; lean_object* x_458; lean_object* x_459; lean_object* x_460; lean_object* x_461; lean_object* x_462; lean_object* x_463; lean_object* x_464; lean_object* x_465; +x_406 = lean_ctor_get(x_257, 2); +x_407 = lean_ctor_get(x_257, 0); +x_408 = lean_ctor_get(x_257, 1); +x_409 = lean_ctor_get(x_257, 3); +x_410 = lean_ctor_get(x_257, 4); +x_411 = lean_ctor_get(x_257, 5); +lean_inc(x_411); +lean_inc(x_410); +lean_inc(x_409); +lean_inc(x_406); +lean_inc(x_408); +lean_inc(x_407); +lean_dec(x_257); +x_412 = lean_ctor_get(x_406, 0); +lean_inc(x_412); +x_413 = lean_ctor_get(x_406, 1); +lean_inc(x_413); +x_414 = lean_ctor_get(x_406, 2); +lean_inc(x_414); +x_415 = lean_ctor_get(x_406, 3); +lean_inc(x_415); +x_416 = lean_ctor_get(x_406, 4); +lean_inc(x_416); +if (lean_is_exclusive(x_406)) { + lean_ctor_release(x_406, 0); + lean_ctor_release(x_406, 1); + lean_ctor_release(x_406, 2); + lean_ctor_release(x_406, 3); + lean_ctor_release(x_406, 4); + x_417 = x_406; } else { - lean_dec_ref(x_389); - x_399 = lean_box(0); + lean_dec_ref(x_406); + x_417 = lean_box(0); } -x_433 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_399)) { - x_434 = lean_alloc_ctor(0, 4, 0); +x_453 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_417)) { + x_454 = lean_alloc_ctor(0, 5, 0); } else { - x_434 = x_399; + x_454 = x_417; } -lean_ctor_set(x_434, 0, x_395); -lean_ctor_set(x_434, 1, x_396); -lean_ctor_set(x_434, 2, x_433); -lean_ctor_set(x_434, 3, x_398); -x_435 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_435, 0, x_390); -lean_ctor_set(x_435, 1, x_391); -lean_ctor_set(x_435, 2, x_434); -lean_ctor_set(x_435, 3, x_392); -lean_ctor_set(x_435, 4, x_393); -lean_ctor_set(x_435, 5, x_394); -x_436 = lean_ctor_get(x_8, 0); -lean_inc(x_436); -x_437 = lean_ctor_get(x_8, 1); -lean_inc(x_437); -x_438 = lean_ctor_get(x_8, 2); -lean_inc(x_438); -x_439 = lean_ctor_get(x_8, 3); -lean_inc(x_439); -x_440 = lean_ctor_get(x_8, 4); -lean_inc(x_440); +lean_ctor_set(x_454, 0, x_412); +lean_ctor_set(x_454, 1, x_413); +lean_ctor_set(x_454, 2, x_453); +lean_ctor_set(x_454, 3, x_415); +lean_ctor_set(x_454, 4, x_416); +x_455 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_455, 0, x_407); +lean_ctor_set(x_455, 1, x_408); +lean_ctor_set(x_455, 2, x_454); +lean_ctor_set(x_455, 3, x_409); +lean_ctor_set(x_455, 4, x_410); +lean_ctor_set(x_455, 5, x_411); +x_456 = lean_ctor_get(x_8, 0); +lean_inc(x_456); +x_457 = lean_ctor_get(x_8, 1); +lean_inc(x_457); +x_458 = lean_ctor_get(x_8, 2); +lean_inc(x_458); +x_459 = lean_ctor_get(x_8, 3); +lean_inc(x_459); +x_460 = lean_ctor_get(x_8, 4); +lean_inc(x_460); if (lean_is_exclusive(x_8)) { lean_ctor_release(x_8, 0); lean_ctor_release(x_8, 1); lean_ctor_release(x_8, 2); lean_ctor_release(x_8, 3); lean_ctor_release(x_8, 4); - x_441 = x_8; + x_461 = x_8; } else { lean_dec_ref(x_8); - x_441 = lean_box(0); + x_461 = lean_box(0); } -x_442 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_442, 0, x_249); -lean_ctor_set(x_442, 1, x_24); -x_443 = lean_array_push(x_438, x_442); -if (lean_is_scalar(x_441)) { - x_444 = lean_alloc_ctor(0, 5, 0); +x_462 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_462, 0, x_259); +lean_ctor_set(x_462, 1, x_24); +x_463 = lean_array_push(x_458, x_462); +if (lean_is_scalar(x_461)) { + x_464 = lean_alloc_ctor(0, 5, 0); } else { - x_444 = x_441; + x_464 = x_461; } -lean_ctor_set(x_444, 0, x_436); -lean_ctor_set(x_444, 1, x_437); -lean_ctor_set(x_444, 2, x_443); -lean_ctor_set(x_444, 3, x_439); -lean_ctor_set(x_444, 4, x_440); -x_445 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_251, x_444, x_435); -if (lean_obj_tag(x_445) == 0) +lean_ctor_set(x_464, 0, x_456); +lean_ctor_set(x_464, 1, x_457); +lean_ctor_set(x_464, 2, x_463); +lean_ctor_set(x_464, 3, x_459); +lean_ctor_set(x_464, 4, x_460); +x_465 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_CheckAssignment_assignToConstFun___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_261, x_464, x_455); +if (lean_obj_tag(x_465) == 0) { -lean_object* x_446; lean_object* x_447; lean_object* x_448; -x_446 = lean_ctor_get(x_445, 0); -lean_inc(x_446); -x_447 = lean_ctor_get(x_445, 1); -lean_inc(x_447); -lean_dec(x_445); -x_448 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_448, 0, x_446); -x_400 = x_448; -x_401 = x_447; -goto block_432; +lean_object* x_466; lean_object* x_467; lean_object* x_468; +x_466 = lean_ctor_get(x_465, 0); +lean_inc(x_466); +x_467 = lean_ctor_get(x_465, 1); +lean_inc(x_467); +lean_dec(x_465); +x_468 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_468, 0, x_466); +x_418 = x_468; +x_419 = x_467; +goto block_452; } else { -lean_object* x_449; lean_object* x_450; lean_object* x_451; -x_449 = lean_ctor_get(x_445, 0); -lean_inc(x_449); -x_450 = lean_ctor_get(x_445, 1); -lean_inc(x_450); -lean_dec(x_445); -x_451 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_451, 0, x_449); -x_400 = x_451; -x_401 = x_450; -goto block_432; +lean_object* x_469; lean_object* x_470; lean_object* x_471; +x_469 = lean_ctor_get(x_465, 0); +lean_inc(x_469); +x_470 = lean_ctor_get(x_465, 1); +lean_inc(x_470); +lean_dec(x_465); +x_471 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_471, 0, x_469); +x_418 = x_471; +x_419 = x_470; +goto block_452; } -block_432: +block_452: { -if (lean_obj_tag(x_400) == 0) +if (lean_obj_tag(x_418) == 0) { -lean_object* x_402; lean_object* x_403; lean_object* x_404; lean_object* x_405; lean_object* x_406; lean_object* x_407; lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_object* x_412; lean_object* x_413; lean_object* x_414; lean_object* x_415; lean_object* x_416; -x_402 = lean_ctor_get(x_401, 2); -lean_inc(x_402); -x_403 = lean_ctor_get(x_400, 0); -lean_inc(x_403); -lean_dec(x_400); -x_404 = lean_ctor_get(x_401, 0); -lean_inc(x_404); -x_405 = lean_ctor_get(x_401, 1); -lean_inc(x_405); -x_406 = lean_ctor_get(x_401, 3); -lean_inc(x_406); -x_407 = lean_ctor_get(x_401, 4); -lean_inc(x_407); -x_408 = lean_ctor_get(x_401, 5); -lean_inc(x_408); -if (lean_is_exclusive(x_401)) { - lean_ctor_release(x_401, 0); - lean_ctor_release(x_401, 1); - lean_ctor_release(x_401, 2); - lean_ctor_release(x_401, 3); - lean_ctor_release(x_401, 4); - lean_ctor_release(x_401, 5); - x_409 = x_401; -} else { - lean_dec_ref(x_401); - x_409 = lean_box(0); -} -x_410 = lean_ctor_get(x_402, 0); -lean_inc(x_410); -x_411 = lean_ctor_get(x_402, 1); -lean_inc(x_411); -x_412 = lean_ctor_get(x_402, 3); -lean_inc(x_412); -if (lean_is_exclusive(x_402)) { - lean_ctor_release(x_402, 0); - lean_ctor_release(x_402, 1); - lean_ctor_release(x_402, 2); - lean_ctor_release(x_402, 3); - x_413 = x_402; -} else { - lean_dec_ref(x_402); - x_413 = lean_box(0); -} -if (lean_is_scalar(x_413)) { - x_414 = lean_alloc_ctor(0, 4, 0); -} else { - x_414 = x_413; -} -lean_ctor_set(x_414, 0, x_410); -lean_ctor_set(x_414, 1, x_411); -lean_ctor_set(x_414, 2, x_397); -lean_ctor_set(x_414, 3, x_412); -if (lean_is_scalar(x_409)) { - x_415 = lean_alloc_ctor(0, 6, 0); -} else { - x_415 = x_409; -} -lean_ctor_set(x_415, 0, x_404); -lean_ctor_set(x_415, 1, x_405); -lean_ctor_set(x_415, 2, x_414); -lean_ctor_set(x_415, 3, x_406); -lean_ctor_set(x_415, 4, x_407); -lean_ctor_set(x_415, 5, x_408); -if (lean_is_scalar(x_248)) { - x_416 = lean_alloc_ctor(1, 2, 0); -} else { - x_416 = x_248; - lean_ctor_set_tag(x_416, 1); -} -lean_ctor_set(x_416, 0, x_403); -lean_ctor_set(x_416, 1, x_415); -return x_416; -} -else -{ -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; lean_object* x_426; lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; -x_417 = lean_ctor_get(x_401, 2); -lean_inc(x_417); -x_418 = lean_ctor_get(x_400, 0); -lean_inc(x_418); -lean_dec(x_400); -x_419 = lean_ctor_get(x_401, 0); -lean_inc(x_419); -x_420 = lean_ctor_get(x_401, 1); +lean_object* x_420; lean_object* x_421; lean_object* x_422; lean_object* x_423; lean_object* x_424; lean_object* x_425; lean_object* x_426; lean_object* x_427; 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; +x_420 = lean_ctor_get(x_419, 2); lean_inc(x_420); -x_421 = lean_ctor_get(x_401, 3); +x_421 = lean_ctor_get(x_418, 0); lean_inc(x_421); -x_422 = lean_ctor_get(x_401, 4); +lean_dec(x_418); +x_422 = lean_ctor_get(x_419, 0); lean_inc(x_422); -x_423 = lean_ctor_get(x_401, 5); +x_423 = lean_ctor_get(x_419, 1); lean_inc(x_423); -if (lean_is_exclusive(x_401)) { - lean_ctor_release(x_401, 0); - lean_ctor_release(x_401, 1); - lean_ctor_release(x_401, 2); - lean_ctor_release(x_401, 3); - lean_ctor_release(x_401, 4); - lean_ctor_release(x_401, 5); - x_424 = x_401; -} else { - lean_dec_ref(x_401); - x_424 = lean_box(0); -} -x_425 = lean_ctor_get(x_417, 0); +x_424 = lean_ctor_get(x_419, 3); +lean_inc(x_424); +x_425 = lean_ctor_get(x_419, 4); lean_inc(x_425); -x_426 = lean_ctor_get(x_417, 1); +x_426 = lean_ctor_get(x_419, 5); lean_inc(x_426); -x_427 = lean_ctor_get(x_417, 3); -lean_inc(x_427); -if (lean_is_exclusive(x_417)) { - lean_ctor_release(x_417, 0); - lean_ctor_release(x_417, 1); - lean_ctor_release(x_417, 2); - lean_ctor_release(x_417, 3); - x_428 = x_417; +if (lean_is_exclusive(x_419)) { + lean_ctor_release(x_419, 0); + lean_ctor_release(x_419, 1); + lean_ctor_release(x_419, 2); + lean_ctor_release(x_419, 3); + lean_ctor_release(x_419, 4); + lean_ctor_release(x_419, 5); + x_427 = x_419; } else { - lean_dec_ref(x_417); - x_428 = lean_box(0); + lean_dec_ref(x_419); + x_427 = lean_box(0); } -if (lean_is_scalar(x_428)) { - x_429 = lean_alloc_ctor(0, 4, 0); +x_428 = lean_ctor_get(x_420, 0); +lean_inc(x_428); +x_429 = lean_ctor_get(x_420, 1); +lean_inc(x_429); +x_430 = lean_ctor_get(x_420, 3); +lean_inc(x_430); +x_431 = lean_ctor_get(x_420, 4); +lean_inc(x_431); +if (lean_is_exclusive(x_420)) { + lean_ctor_release(x_420, 0); + lean_ctor_release(x_420, 1); + lean_ctor_release(x_420, 2); + lean_ctor_release(x_420, 3); + lean_ctor_release(x_420, 4); + x_432 = x_420; } else { - x_429 = x_428; + lean_dec_ref(x_420); + x_432 = lean_box(0); } -lean_ctor_set(x_429, 0, x_425); -lean_ctor_set(x_429, 1, x_426); -lean_ctor_set(x_429, 2, x_397); -lean_ctor_set(x_429, 3, x_427); -if (lean_is_scalar(x_424)) { - x_430 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_432)) { + x_433 = lean_alloc_ctor(0, 5, 0); } else { - x_430 = x_424; + x_433 = x_432; } -lean_ctor_set(x_430, 0, x_419); -lean_ctor_set(x_430, 1, x_420); -lean_ctor_set(x_430, 2, x_429); -lean_ctor_set(x_430, 3, x_421); -lean_ctor_set(x_430, 4, x_422); -lean_ctor_set(x_430, 5, x_423); -if (lean_is_scalar(x_248)) { - x_431 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_433, 0, x_428); +lean_ctor_set(x_433, 1, x_429); +lean_ctor_set(x_433, 2, x_414); +lean_ctor_set(x_433, 3, x_430); +lean_ctor_set(x_433, 4, x_431); +if (lean_is_scalar(x_427)) { + x_434 = lean_alloc_ctor(0, 6, 0); } else { - x_431 = x_248; + x_434 = x_427; } -lean_ctor_set(x_431, 0, x_418); -lean_ctor_set(x_431, 1, x_430); -return x_431; +lean_ctor_set(x_434, 0, x_422); +lean_ctor_set(x_434, 1, x_423); +lean_ctor_set(x_434, 2, x_433); +lean_ctor_set(x_434, 3, x_424); +lean_ctor_set(x_434, 4, x_425); +lean_ctor_set(x_434, 5, x_426); +if (lean_is_scalar(x_258)) { + x_435 = lean_alloc_ctor(1, 2, 0); +} else { + x_435 = x_258; + lean_ctor_set_tag(x_435, 1); +} +lean_ctor_set(x_435, 0, x_421); +lean_ctor_set(x_435, 1, x_434); +return x_435; +} +else +{ +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; lean_object* x_445; lean_object* x_446; lean_object* x_447; lean_object* x_448; lean_object* x_449; lean_object* x_450; lean_object* x_451; +x_436 = lean_ctor_get(x_419, 2); +lean_inc(x_436); +x_437 = lean_ctor_get(x_418, 0); +lean_inc(x_437); +lean_dec(x_418); +x_438 = lean_ctor_get(x_419, 0); +lean_inc(x_438); +x_439 = lean_ctor_get(x_419, 1); +lean_inc(x_439); +x_440 = lean_ctor_get(x_419, 3); +lean_inc(x_440); +x_441 = lean_ctor_get(x_419, 4); +lean_inc(x_441); +x_442 = lean_ctor_get(x_419, 5); +lean_inc(x_442); +if (lean_is_exclusive(x_419)) { + lean_ctor_release(x_419, 0); + lean_ctor_release(x_419, 1); + lean_ctor_release(x_419, 2); + lean_ctor_release(x_419, 3); + lean_ctor_release(x_419, 4); + lean_ctor_release(x_419, 5); + x_443 = x_419; +} else { + lean_dec_ref(x_419); + x_443 = lean_box(0); +} +x_444 = lean_ctor_get(x_436, 0); +lean_inc(x_444); +x_445 = lean_ctor_get(x_436, 1); +lean_inc(x_445); +x_446 = lean_ctor_get(x_436, 3); +lean_inc(x_446); +x_447 = lean_ctor_get(x_436, 4); +lean_inc(x_447); +if (lean_is_exclusive(x_436)) { + lean_ctor_release(x_436, 0); + lean_ctor_release(x_436, 1); + lean_ctor_release(x_436, 2); + lean_ctor_release(x_436, 3); + lean_ctor_release(x_436, 4); + x_448 = x_436; +} else { + lean_dec_ref(x_436); + x_448 = lean_box(0); +} +if (lean_is_scalar(x_448)) { + x_449 = lean_alloc_ctor(0, 5, 0); +} else { + x_449 = x_448; +} +lean_ctor_set(x_449, 0, x_444); +lean_ctor_set(x_449, 1, x_445); +lean_ctor_set(x_449, 2, x_414); +lean_ctor_set(x_449, 3, x_446); +lean_ctor_set(x_449, 4, x_447); +if (lean_is_scalar(x_443)) { + x_450 = lean_alloc_ctor(0, 6, 0); +} else { + x_450 = x_443; +} +lean_ctor_set(x_450, 0, x_438); +lean_ctor_set(x_450, 1, x_439); +lean_ctor_set(x_450, 2, x_449); +lean_ctor_set(x_450, 3, x_440); +lean_ctor_set(x_450, 4, x_441); +lean_ctor_set(x_450, 5, x_442); +if (lean_is_scalar(x_258)) { + x_451 = lean_alloc_ctor(0, 2, 0); +} else { + x_451 = x_258; +} +lean_ctor_set(x_451, 0, x_437); +lean_ctor_set(x_451, 1, x_450); +return x_451; } } } @@ -15735,30 +16031,30 @@ return x_431; } else { -uint8_t x_452; +uint8_t x_472; lean_dec(x_24); lean_dec(x_8); lean_dec(x_7); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_452 = !lean_is_exclusive(x_241); -if (x_452 == 0) +x_472 = !lean_is_exclusive(x_251); +if (x_472 == 0) { -return x_241; +return x_251; } else { -lean_object* x_453; lean_object* x_454; lean_object* x_455; -x_453 = lean_ctor_get(x_241, 0); -x_454 = lean_ctor_get(x_241, 1); -lean_inc(x_454); -lean_inc(x_453); -lean_dec(x_241); -x_455 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_455, 0, x_453); -lean_ctor_set(x_455, 1, x_454); -return x_455; +lean_object* x_473; lean_object* x_474; lean_object* x_475; +x_473 = lean_ctor_get(x_251, 0); +x_474 = lean_ctor_get(x_251, 1); +lean_inc(x_474); +lean_inc(x_473); +lean_dec(x_251); +x_475 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_475, 0, x_473); +lean_ctor_set(x_475, 1, x_474); +return x_475; } } } @@ -15766,7 +16062,7 @@ return x_455; } else { -uint8_t x_456; +uint8_t x_476; lean_dec(x_28); lean_dec(x_24); lean_dec(x_8); @@ -15774,52 +16070,52 @@ lean_dec(x_7); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_456 = !lean_is_exclusive(x_29); -if (x_456 == 0) +x_476 = !lean_is_exclusive(x_29); +if (x_476 == 0) { return x_29; } else { -lean_object* x_457; lean_object* x_458; lean_object* x_459; -x_457 = lean_ctor_get(x_29, 0); -x_458 = lean_ctor_get(x_29, 1); -lean_inc(x_458); -lean_inc(x_457); +lean_object* x_477; lean_object* x_478; lean_object* x_479; +x_477 = lean_ctor_get(x_29, 0); +x_478 = lean_ctor_get(x_29, 1); +lean_inc(x_478); +lean_inc(x_477); lean_dec(x_29); -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_479 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_479, 0, x_477); +lean_ctor_set(x_479, 1, x_478); +return x_479; } } } else { -uint8_t x_460; +uint8_t x_480; lean_dec(x_24); lean_dec(x_8); lean_dec(x_7); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_460 = !lean_is_exclusive(x_25); -if (x_460 == 0) +x_480 = !lean_is_exclusive(x_25); +if (x_480 == 0) { return x_25; } else { -lean_object* x_461; lean_object* x_462; lean_object* x_463; -x_461 = lean_ctor_get(x_25, 0); -x_462 = lean_ctor_get(x_25, 1); -lean_inc(x_462); -lean_inc(x_461); +lean_object* x_481; lean_object* x_482; lean_object* x_483; +x_481 = lean_ctor_get(x_25, 0); +x_482 = lean_ctor_get(x_25, 1); +lean_inc(x_482); +lean_inc(x_481); lean_dec(x_25); -x_463 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_463, 0, x_461); -lean_ctor_set(x_463, 1, x_462); -return x_463; +x_483 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_483, 0, x_481); +lean_ctor_set(x_483, 1, x_482); +return x_483; } } } @@ -30176,105 +30472,105 @@ x_41 = lean_ctor_get(x_35, 2); x_42 = !lean_is_exclusive(x_41); if (x_42 == 0) { -lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_95; uint8_t x_96; +lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_99; uint8_t x_100; x_43 = lean_ctor_get(x_41, 2); -x_95 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_41, 2, x_95); -x_96 = !lean_is_exclusive(x_8); -if (x_96 == 0) +x_99 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_41, 2, x_99); +x_100 = !lean_is_exclusive(x_8); +if (x_100 == 0) { -lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; -x_97 = lean_ctor_get(x_8, 2); -x_98 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_98, 0, x_37); -lean_ctor_set(x_98, 1, x_24); -x_99 = lean_array_push(x_97, x_98); -lean_ctor_set(x_8, 2, x_99); -x_100 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_ExprDefEq_18__processConstApprox___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_39, x_8, x_35); -if (lean_obj_tag(x_100) == 0) +lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; +x_101 = lean_ctor_get(x_8, 2); +x_102 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_102, 0, x_37); +lean_ctor_set(x_102, 1, x_24); +x_103 = lean_array_push(x_101, x_102); +lean_ctor_set(x_8, 2, x_103); +x_104 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_ExprDefEq_18__processConstApprox___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_39, x_8, x_35); +if (lean_obj_tag(x_104) == 0) { -lean_object* x_101; lean_object* x_102; lean_object* x_103; -x_101 = lean_ctor_get(x_100, 0); -lean_inc(x_101); -x_102 = lean_ctor_get(x_100, 1); -lean_inc(x_102); -lean_dec(x_100); -x_103 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_103, 0, x_101); -x_44 = x_103; -x_45 = x_102; -goto block_94; -} -else -{ -lean_object* x_104; lean_object* x_105; lean_object* x_106; -x_104 = lean_ctor_get(x_100, 0); -lean_inc(x_104); -x_105 = lean_ctor_get(x_100, 1); +lean_object* x_105; lean_object* x_106; lean_object* x_107; +x_105 = lean_ctor_get(x_104, 0); lean_inc(x_105); -lean_dec(x_100); -x_106 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_106, 0, x_104); -x_44 = x_106; -x_45 = x_105; -goto block_94; -} +x_106 = lean_ctor_get(x_104, 1); +lean_inc(x_106); +lean_dec(x_104); +x_107 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_107, 0, x_105); +x_44 = x_107; +x_45 = x_106; +goto block_98; } else { -lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; -x_107 = lean_ctor_get(x_8, 0); -x_108 = lean_ctor_get(x_8, 1); -x_109 = lean_ctor_get(x_8, 2); -x_110 = lean_ctor_get(x_8, 3); -x_111 = lean_ctor_get(x_8, 4); -lean_inc(x_111); -lean_inc(x_110); -lean_inc(x_109); +lean_object* x_108; lean_object* x_109; lean_object* x_110; +x_108 = lean_ctor_get(x_104, 0); lean_inc(x_108); -lean_inc(x_107); -lean_dec(x_8); -x_112 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_112, 0, x_37); -lean_ctor_set(x_112, 1, x_24); -x_113 = lean_array_push(x_109, x_112); -x_114 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_114, 0, x_107); -lean_ctor_set(x_114, 1, x_108); -lean_ctor_set(x_114, 2, x_113); -lean_ctor_set(x_114, 3, x_110); -lean_ctor_set(x_114, 4, x_111); -x_115 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_ExprDefEq_18__processConstApprox___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_39, x_114, x_35); -if (lean_obj_tag(x_115) == 0) -{ -lean_object* x_116; lean_object* x_117; lean_object* x_118; -x_116 = lean_ctor_get(x_115, 0); -lean_inc(x_116); -x_117 = lean_ctor_get(x_115, 1); -lean_inc(x_117); -lean_dec(x_115); -x_118 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_118, 0, x_116); -x_44 = x_118; -x_45 = x_117; -goto block_94; +x_109 = lean_ctor_get(x_104, 1); +lean_inc(x_109); +lean_dec(x_104); +x_110 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_110, 0, x_108); +x_44 = x_110; +x_45 = x_109; +goto block_98; +} } else { -lean_object* x_119; lean_object* x_120; lean_object* x_121; -x_119 = lean_ctor_get(x_115, 0); -lean_inc(x_119); -x_120 = lean_ctor_get(x_115, 1); +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; +x_111 = lean_ctor_get(x_8, 0); +x_112 = lean_ctor_get(x_8, 1); +x_113 = lean_ctor_get(x_8, 2); +x_114 = lean_ctor_get(x_8, 3); +x_115 = lean_ctor_get(x_8, 4); +lean_inc(x_115); +lean_inc(x_114); +lean_inc(x_113); +lean_inc(x_112); +lean_inc(x_111); +lean_dec(x_8); +x_116 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_116, 0, x_37); +lean_ctor_set(x_116, 1, x_24); +x_117 = lean_array_push(x_113, x_116); +x_118 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_118, 0, x_111); +lean_ctor_set(x_118, 1, x_112); +lean_ctor_set(x_118, 2, x_117); +lean_ctor_set(x_118, 3, x_114); +lean_ctor_set(x_118, 4, x_115); +x_119 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_ExprDefEq_18__processConstApprox___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_39, x_118, x_35); +if (lean_obj_tag(x_119) == 0) +{ +lean_object* x_120; lean_object* x_121; lean_object* x_122; +x_120 = lean_ctor_get(x_119, 0); lean_inc(x_120); -lean_dec(x_115); -x_121 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_121, 0, x_119); -x_44 = x_121; -x_45 = x_120; -goto block_94; +x_121 = lean_ctor_get(x_119, 1); +lean_inc(x_121); +lean_dec(x_119); +x_122 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_122, 0, x_120); +x_44 = x_122; +x_45 = x_121; +goto block_98; +} +else +{ +lean_object* x_123; lean_object* x_124; lean_object* x_125; +x_123 = lean_ctor_get(x_119, 0); +lean_inc(x_123); +x_124 = lean_ctor_get(x_119, 1); +lean_inc(x_124); +lean_dec(x_119); +x_125 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_125, 0, x_123); +x_44 = x_125; +x_45 = x_124; +goto block_98; } } -block_94: +block_98: { if (lean_obj_tag(x_44) == 0) { @@ -30309,1284 +30605,1262 @@ 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_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; x_53 = lean_ctor_get(x_46, 0); x_54 = lean_ctor_get(x_46, 1); x_55 = lean_ctor_get(x_46, 3); +x_56 = lean_ctor_get(x_46, 4); +lean_inc(x_56); lean_inc(x_55); lean_inc(x_54); lean_inc(x_53); lean_dec(x_46); -x_56 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_56, 0, x_53); -lean_ctor_set(x_56, 1, x_54); -lean_ctor_set(x_56, 2, x_43); -lean_ctor_set(x_56, 3, x_55); -lean_ctor_set(x_45, 2, x_56); +x_57 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_57, 0, x_53); +lean_ctor_set(x_57, 1, x_54); +lean_ctor_set(x_57, 2, x_43); +lean_ctor_set(x_57, 3, x_55); +lean_ctor_set(x_57, 4, x_56); +lean_ctor_set(x_45, 2, x_57); if (lean_is_scalar(x_36)) { - x_57 = lean_alloc_ctor(1, 2, 0); + x_58 = lean_alloc_ctor(1, 2, 0); } else { - x_57 = x_36; - lean_ctor_set_tag(x_57, 1); + x_58 = x_36; + lean_ctor_set_tag(x_58, 1); } -lean_ctor_set(x_57, 0, x_47); -lean_ctor_set(x_57, 1, x_45); -return x_57; +lean_ctor_set(x_58, 0, x_47); +lean_ctor_set(x_58, 1, x_45); +return x_58; } } else { -lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; -x_58 = lean_ctor_get(x_45, 0); -x_59 = lean_ctor_get(x_45, 1); -x_60 = lean_ctor_get(x_45, 3); -x_61 = lean_ctor_get(x_45, 4); -x_62 = lean_ctor_get(x_45, 5); +lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; +x_59 = lean_ctor_get(x_45, 0); +x_60 = lean_ctor_get(x_45, 1); +x_61 = lean_ctor_get(x_45, 3); +x_62 = lean_ctor_get(x_45, 4); +x_63 = lean_ctor_get(x_45, 5); +lean_inc(x_63); lean_inc(x_62); lean_inc(x_61); lean_inc(x_60); lean_inc(x_59); -lean_inc(x_58); lean_dec(x_45); -x_63 = lean_ctor_get(x_46, 0); -lean_inc(x_63); -x_64 = lean_ctor_get(x_46, 1); +x_64 = lean_ctor_get(x_46, 0); lean_inc(x_64); -x_65 = lean_ctor_get(x_46, 3); +x_65 = lean_ctor_get(x_46, 1); lean_inc(x_65); +x_66 = lean_ctor_get(x_46, 3); +lean_inc(x_66); +x_67 = lean_ctor_get(x_46, 4); +lean_inc(x_67); if (lean_is_exclusive(x_46)) { lean_ctor_release(x_46, 0); lean_ctor_release(x_46, 1); lean_ctor_release(x_46, 2); lean_ctor_release(x_46, 3); - x_66 = x_46; + lean_ctor_release(x_46, 4); + x_68 = x_46; } else { lean_dec_ref(x_46); - x_66 = lean_box(0); + x_68 = lean_box(0); } -if (lean_is_scalar(x_66)) { - x_67 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_68)) { + x_69 = lean_alloc_ctor(0, 5, 0); } else { - x_67 = x_66; + x_69 = x_68; } -lean_ctor_set(x_67, 0, x_63); -lean_ctor_set(x_67, 1, x_64); -lean_ctor_set(x_67, 2, x_43); -lean_ctor_set(x_67, 3, x_65); -x_68 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_68, 0, x_58); -lean_ctor_set(x_68, 1, x_59); -lean_ctor_set(x_68, 2, x_67); -lean_ctor_set(x_68, 3, x_60); -lean_ctor_set(x_68, 4, x_61); -lean_ctor_set(x_68, 5, x_62); +lean_ctor_set(x_69, 0, x_64); +lean_ctor_set(x_69, 1, x_65); +lean_ctor_set(x_69, 2, x_43); +lean_ctor_set(x_69, 3, x_66); +lean_ctor_set(x_69, 4, x_67); +x_70 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_70, 0, x_59); +lean_ctor_set(x_70, 1, x_60); +lean_ctor_set(x_70, 2, x_69); +lean_ctor_set(x_70, 3, x_61); +lean_ctor_set(x_70, 4, x_62); +lean_ctor_set(x_70, 5, x_63); if (lean_is_scalar(x_36)) { - x_69 = lean_alloc_ctor(1, 2, 0); + x_71 = lean_alloc_ctor(1, 2, 0); } else { - x_69 = x_36; - lean_ctor_set_tag(x_69, 1); + x_71 = x_36; + lean_ctor_set_tag(x_71, 1); } -lean_ctor_set(x_69, 0, x_47); -lean_ctor_set(x_69, 1, x_68); -return x_69; +lean_ctor_set(x_71, 0, x_47); +lean_ctor_set(x_71, 1, x_70); +return x_71; } } else { -lean_object* x_70; lean_object* x_71; uint8_t x_72; -x_70 = lean_ctor_get(x_45, 2); -lean_inc(x_70); -x_71 = lean_ctor_get(x_44, 0); -lean_inc(x_71); +lean_object* x_72; lean_object* x_73; uint8_t x_74; +x_72 = lean_ctor_get(x_45, 2); +lean_inc(x_72); +x_73 = lean_ctor_get(x_44, 0); +lean_inc(x_73); lean_dec(x_44); -x_72 = !lean_is_exclusive(x_45); -if (x_72 == 0) -{ -lean_object* x_73; uint8_t x_74; -x_73 = lean_ctor_get(x_45, 2); -lean_dec(x_73); -x_74 = !lean_is_exclusive(x_70); +x_74 = !lean_is_exclusive(x_45); if (x_74 == 0) { -lean_object* x_75; lean_object* x_76; -x_75 = lean_ctor_get(x_70, 2); +lean_object* x_75; uint8_t x_76; +x_75 = lean_ctor_get(x_45, 2); lean_dec(x_75); -lean_ctor_set(x_70, 2, x_43); +x_76 = !lean_is_exclusive(x_72); +if (x_76 == 0) +{ +lean_object* x_77; lean_object* x_78; +x_77 = lean_ctor_get(x_72, 2); +lean_dec(x_77); +lean_ctor_set(x_72, 2, x_43); if (lean_is_scalar(x_36)) { - x_76 = lean_alloc_ctor(0, 2, 0); + x_78 = lean_alloc_ctor(0, 2, 0); } else { - x_76 = x_36; + x_78 = x_36; } -lean_ctor_set(x_76, 0, x_71); -lean_ctor_set(x_76, 1, x_45); -return x_76; +lean_ctor_set(x_78, 0, x_73); +lean_ctor_set(x_78, 1, x_45); +return x_78; } else { -lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; -x_77 = lean_ctor_get(x_70, 0); -x_78 = lean_ctor_get(x_70, 1); -x_79 = lean_ctor_get(x_70, 3); +lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; +x_79 = lean_ctor_get(x_72, 0); +x_80 = lean_ctor_get(x_72, 1); +x_81 = lean_ctor_get(x_72, 3); +x_82 = lean_ctor_get(x_72, 4); +lean_inc(x_82); +lean_inc(x_81); +lean_inc(x_80); lean_inc(x_79); -lean_inc(x_78); -lean_inc(x_77); -lean_dec(x_70); -x_80 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_80, 0, x_77); -lean_ctor_set(x_80, 1, x_78); -lean_ctor_set(x_80, 2, x_43); -lean_ctor_set(x_80, 3, x_79); -lean_ctor_set(x_45, 2, x_80); +lean_dec(x_72); +x_83 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_83, 0, x_79); +lean_ctor_set(x_83, 1, x_80); +lean_ctor_set(x_83, 2, x_43); +lean_ctor_set(x_83, 3, x_81); +lean_ctor_set(x_83, 4, x_82); +lean_ctor_set(x_45, 2, x_83); if (lean_is_scalar(x_36)) { - x_81 = lean_alloc_ctor(0, 2, 0); + x_84 = lean_alloc_ctor(0, 2, 0); } else { - x_81 = x_36; + x_84 = x_36; } -lean_ctor_set(x_81, 0, x_71); -lean_ctor_set(x_81, 1, x_45); -return x_81; +lean_ctor_set(x_84, 0, x_73); +lean_ctor_set(x_84, 1, x_45); +return x_84; } } else { -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; -x_82 = lean_ctor_get(x_45, 0); -x_83 = lean_ctor_get(x_45, 1); -x_84 = lean_ctor_get(x_45, 3); -x_85 = lean_ctor_get(x_45, 4); -x_86 = lean_ctor_get(x_45, 5); +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; +x_85 = lean_ctor_get(x_45, 0); +x_86 = lean_ctor_get(x_45, 1); +x_87 = lean_ctor_get(x_45, 3); +x_88 = lean_ctor_get(x_45, 4); +x_89 = lean_ctor_get(x_45, 5); +lean_inc(x_89); +lean_inc(x_88); +lean_inc(x_87); lean_inc(x_86); lean_inc(x_85); -lean_inc(x_84); -lean_inc(x_83); -lean_inc(x_82); lean_dec(x_45); -x_87 = lean_ctor_get(x_70, 0); -lean_inc(x_87); -x_88 = lean_ctor_get(x_70, 1); -lean_inc(x_88); -x_89 = lean_ctor_get(x_70, 3); -lean_inc(x_89); -if (lean_is_exclusive(x_70)) { - lean_ctor_release(x_70, 0); - lean_ctor_release(x_70, 1); - lean_ctor_release(x_70, 2); - lean_ctor_release(x_70, 3); - x_90 = x_70; +x_90 = lean_ctor_get(x_72, 0); +lean_inc(x_90); +x_91 = lean_ctor_get(x_72, 1); +lean_inc(x_91); +x_92 = lean_ctor_get(x_72, 3); +lean_inc(x_92); +x_93 = lean_ctor_get(x_72, 4); +lean_inc(x_93); +if (lean_is_exclusive(x_72)) { + lean_ctor_release(x_72, 0); + lean_ctor_release(x_72, 1); + lean_ctor_release(x_72, 2); + lean_ctor_release(x_72, 3); + lean_ctor_release(x_72, 4); + x_94 = x_72; } else { - lean_dec_ref(x_70); - x_90 = lean_box(0); + lean_dec_ref(x_72); + x_94 = lean_box(0); } -if (lean_is_scalar(x_90)) { - x_91 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_94)) { + x_95 = lean_alloc_ctor(0, 5, 0); } else { - x_91 = x_90; + x_95 = x_94; } -lean_ctor_set(x_91, 0, x_87); -lean_ctor_set(x_91, 1, x_88); -lean_ctor_set(x_91, 2, x_43); -lean_ctor_set(x_91, 3, x_89); -x_92 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_92, 0, x_82); -lean_ctor_set(x_92, 1, x_83); -lean_ctor_set(x_92, 2, x_91); -lean_ctor_set(x_92, 3, x_84); -lean_ctor_set(x_92, 4, x_85); -lean_ctor_set(x_92, 5, x_86); +lean_ctor_set(x_95, 0, x_90); +lean_ctor_set(x_95, 1, x_91); +lean_ctor_set(x_95, 2, x_43); +lean_ctor_set(x_95, 3, x_92); +lean_ctor_set(x_95, 4, x_93); +x_96 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_96, 0, x_85); +lean_ctor_set(x_96, 1, x_86); +lean_ctor_set(x_96, 2, x_95); +lean_ctor_set(x_96, 3, x_87); +lean_ctor_set(x_96, 4, x_88); +lean_ctor_set(x_96, 5, x_89); if (lean_is_scalar(x_36)) { - x_93 = lean_alloc_ctor(0, 2, 0); + x_97 = lean_alloc_ctor(0, 2, 0); } else { - x_93 = x_36; + x_97 = x_36; } -lean_ctor_set(x_93, 0, x_71); -lean_ctor_set(x_93, 1, x_92); -return x_93; +lean_ctor_set(x_97, 0, x_73); +lean_ctor_set(x_97, 1, x_96); +return x_97; } } } } else { -lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; -x_122 = lean_ctor_get(x_41, 0); -x_123 = lean_ctor_get(x_41, 1); -x_124 = lean_ctor_get(x_41, 2); -x_125 = lean_ctor_get(x_41, 3); -lean_inc(x_125); -lean_inc(x_124); -lean_inc(x_123); -lean_inc(x_122); -lean_dec(x_41); -x_159 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_160 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_160, 0, x_122); -lean_ctor_set(x_160, 1, x_123); -lean_ctor_set(x_160, 2, x_159); -lean_ctor_set(x_160, 3, x_125); -lean_ctor_set(x_35, 2, x_160); -x_161 = lean_ctor_get(x_8, 0); -lean_inc(x_161); -x_162 = lean_ctor_get(x_8, 1); -lean_inc(x_162); -x_163 = lean_ctor_get(x_8, 2); -lean_inc(x_163); -x_164 = lean_ctor_get(x_8, 3); -lean_inc(x_164); -x_165 = lean_ctor_get(x_8, 4); -lean_inc(x_165); -if (lean_is_exclusive(x_8)) { - lean_ctor_release(x_8, 0); - lean_ctor_release(x_8, 1); - lean_ctor_release(x_8, 2); - lean_ctor_release(x_8, 3); - lean_ctor_release(x_8, 4); - x_166 = x_8; -} else { - lean_dec_ref(x_8); - x_166 = lean_box(0); -} -x_167 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_167, 0, x_37); -lean_ctor_set(x_167, 1, x_24); -x_168 = lean_array_push(x_163, x_167); -if (lean_is_scalar(x_166)) { - x_169 = lean_alloc_ctor(0, 5, 0); -} else { - x_169 = x_166; -} -lean_ctor_set(x_169, 0, x_161); -lean_ctor_set(x_169, 1, x_162); -lean_ctor_set(x_169, 2, x_168); -lean_ctor_set(x_169, 3, x_164); -lean_ctor_set(x_169, 4, x_165); -x_170 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_ExprDefEq_18__processConstApprox___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_39, x_169, x_35); -if (lean_obj_tag(x_170) == 0) -{ -lean_object* x_171; lean_object* x_172; lean_object* x_173; -x_171 = lean_ctor_get(x_170, 0); -lean_inc(x_171); -x_172 = lean_ctor_get(x_170, 1); -lean_inc(x_172); -lean_dec(x_170); -x_173 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_173, 0, x_171); -x_126 = x_173; -x_127 = x_172; -goto block_158; -} -else -{ -lean_object* x_174; lean_object* x_175; lean_object* x_176; -x_174 = lean_ctor_get(x_170, 0); -lean_inc(x_174); -x_175 = lean_ctor_get(x_170, 1); -lean_inc(x_175); -lean_dec(x_170); -x_176 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_176, 0, x_174); -x_126 = x_176; -x_127 = x_175; -goto block_158; -} -block_158: -{ -if (lean_obj_tag(x_126) == 0) -{ -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; -x_128 = lean_ctor_get(x_127, 2); -lean_inc(x_128); -x_129 = lean_ctor_get(x_126, 0); -lean_inc(x_129); -lean_dec(x_126); -x_130 = lean_ctor_get(x_127, 0); +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_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; +x_126 = lean_ctor_get(x_41, 0); +x_127 = lean_ctor_get(x_41, 1); +x_128 = lean_ctor_get(x_41, 2); +x_129 = lean_ctor_get(x_41, 3); +x_130 = lean_ctor_get(x_41, 4); lean_inc(x_130); -x_131 = lean_ctor_get(x_127, 1); -lean_inc(x_131); -x_132 = lean_ctor_get(x_127, 3); -lean_inc(x_132); -x_133 = lean_ctor_get(x_127, 4); -lean_inc(x_133); -x_134 = lean_ctor_get(x_127, 5); -lean_inc(x_134); -if (lean_is_exclusive(x_127)) { - lean_ctor_release(x_127, 0); - lean_ctor_release(x_127, 1); - lean_ctor_release(x_127, 2); - lean_ctor_release(x_127, 3); - lean_ctor_release(x_127, 4); - lean_ctor_release(x_127, 5); - x_135 = x_127; -} else { - lean_dec_ref(x_127); - x_135 = lean_box(0); -} -x_136 = lean_ctor_get(x_128, 0); -lean_inc(x_136); -x_137 = lean_ctor_get(x_128, 1); -lean_inc(x_137); -x_138 = lean_ctor_get(x_128, 3); -lean_inc(x_138); -if (lean_is_exclusive(x_128)) { - lean_ctor_release(x_128, 0); - lean_ctor_release(x_128, 1); - lean_ctor_release(x_128, 2); - lean_ctor_release(x_128, 3); - x_139 = x_128; -} else { - lean_dec_ref(x_128); - x_139 = lean_box(0); -} -if (lean_is_scalar(x_139)) { - x_140 = lean_alloc_ctor(0, 4, 0); -} else { - x_140 = x_139; -} -lean_ctor_set(x_140, 0, x_136); -lean_ctor_set(x_140, 1, x_137); -lean_ctor_set(x_140, 2, x_124); -lean_ctor_set(x_140, 3, x_138); -if (lean_is_scalar(x_135)) { - x_141 = lean_alloc_ctor(0, 6, 0); -} else { - x_141 = x_135; -} -lean_ctor_set(x_141, 0, x_130); -lean_ctor_set(x_141, 1, x_131); -lean_ctor_set(x_141, 2, x_140); -lean_ctor_set(x_141, 3, x_132); -lean_ctor_set(x_141, 4, x_133); -lean_ctor_set(x_141, 5, x_134); -if (lean_is_scalar(x_36)) { - x_142 = lean_alloc_ctor(1, 2, 0); -} else { - x_142 = x_36; - lean_ctor_set_tag(x_142, 1); -} -lean_ctor_set(x_142, 0, x_129); -lean_ctor_set(x_142, 1, x_141); -return x_142; -} -else -{ -lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; 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; -x_143 = lean_ctor_get(x_127, 2); -lean_inc(x_143); -x_144 = lean_ctor_get(x_126, 0); -lean_inc(x_144); -lean_dec(x_126); -x_145 = lean_ctor_get(x_127, 0); -lean_inc(x_145); -x_146 = lean_ctor_get(x_127, 1); -lean_inc(x_146); -x_147 = lean_ctor_get(x_127, 3); -lean_inc(x_147); -x_148 = lean_ctor_get(x_127, 4); -lean_inc(x_148); -x_149 = lean_ctor_get(x_127, 5); -lean_inc(x_149); -if (lean_is_exclusive(x_127)) { - lean_ctor_release(x_127, 0); - lean_ctor_release(x_127, 1); - lean_ctor_release(x_127, 2); - lean_ctor_release(x_127, 3); - lean_ctor_release(x_127, 4); - lean_ctor_release(x_127, 5); - x_150 = x_127; -} else { - lean_dec_ref(x_127); - x_150 = lean_box(0); -} -x_151 = lean_ctor_get(x_143, 0); -lean_inc(x_151); -x_152 = lean_ctor_get(x_143, 1); -lean_inc(x_152); -x_153 = lean_ctor_get(x_143, 3); -lean_inc(x_153); -if (lean_is_exclusive(x_143)) { - lean_ctor_release(x_143, 0); - lean_ctor_release(x_143, 1); - lean_ctor_release(x_143, 2); - lean_ctor_release(x_143, 3); - x_154 = x_143; -} else { - lean_dec_ref(x_143); - x_154 = lean_box(0); -} -if (lean_is_scalar(x_154)) { - x_155 = lean_alloc_ctor(0, 4, 0); -} else { - x_155 = x_154; -} -lean_ctor_set(x_155, 0, x_151); -lean_ctor_set(x_155, 1, x_152); -lean_ctor_set(x_155, 2, x_124); -lean_ctor_set(x_155, 3, x_153); -if (lean_is_scalar(x_150)) { - x_156 = lean_alloc_ctor(0, 6, 0); -} else { - x_156 = x_150; -} -lean_ctor_set(x_156, 0, x_145); -lean_ctor_set(x_156, 1, x_146); -lean_ctor_set(x_156, 2, x_155); -lean_ctor_set(x_156, 3, x_147); -lean_ctor_set(x_156, 4, x_148); -lean_ctor_set(x_156, 5, x_149); -if (lean_is_scalar(x_36)) { - x_157 = lean_alloc_ctor(0, 2, 0); -} else { - x_157 = x_36; -} -lean_ctor_set(x_157, 0, x_144); -lean_ctor_set(x_157, 1, x_156); -return x_157; -} -} -} -} -else -{ -lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; 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_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; lean_object* x_231; lean_object* x_232; lean_object* x_233; -x_177 = lean_ctor_get(x_35, 2); -x_178 = lean_ctor_get(x_35, 0); -x_179 = lean_ctor_get(x_35, 1); -x_180 = lean_ctor_get(x_35, 3); -x_181 = lean_ctor_get(x_35, 4); -x_182 = lean_ctor_get(x_35, 5); -lean_inc(x_182); -lean_inc(x_181); -lean_inc(x_180); -lean_inc(x_177); -lean_inc(x_179); -lean_inc(x_178); -lean_dec(x_35); -x_183 = lean_ctor_get(x_177, 0); -lean_inc(x_183); -x_184 = lean_ctor_get(x_177, 1); -lean_inc(x_184); -x_185 = lean_ctor_get(x_177, 2); -lean_inc(x_185); -x_186 = lean_ctor_get(x_177, 3); -lean_inc(x_186); -if (lean_is_exclusive(x_177)) { - lean_ctor_release(x_177, 0); - lean_ctor_release(x_177, 1); - lean_ctor_release(x_177, 2); - lean_ctor_release(x_177, 3); - x_187 = x_177; -} else { - lean_dec_ref(x_177); - x_187 = lean_box(0); -} -x_221 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_187)) { - x_222 = lean_alloc_ctor(0, 4, 0); -} else { - x_222 = x_187; -} -lean_ctor_set(x_222, 0, x_183); -lean_ctor_set(x_222, 1, x_184); -lean_ctor_set(x_222, 2, x_221); -lean_ctor_set(x_222, 3, x_186); -x_223 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_223, 0, x_178); -lean_ctor_set(x_223, 1, x_179); -lean_ctor_set(x_223, 2, x_222); -lean_ctor_set(x_223, 3, x_180); -lean_ctor_set(x_223, 4, x_181); -lean_ctor_set(x_223, 5, x_182); -x_224 = lean_ctor_get(x_8, 0); -lean_inc(x_224); -x_225 = lean_ctor_get(x_8, 1); -lean_inc(x_225); -x_226 = lean_ctor_get(x_8, 2); -lean_inc(x_226); -x_227 = lean_ctor_get(x_8, 3); -lean_inc(x_227); -x_228 = lean_ctor_get(x_8, 4); -lean_inc(x_228); +lean_inc(x_129); +lean_inc(x_128); +lean_inc(x_127); +lean_inc(x_126); +lean_dec(x_41); +x_166 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_167 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_167, 0, x_126); +lean_ctor_set(x_167, 1, x_127); +lean_ctor_set(x_167, 2, x_166); +lean_ctor_set(x_167, 3, x_129); +lean_ctor_set(x_167, 4, x_130); +lean_ctor_set(x_35, 2, x_167); +x_168 = lean_ctor_get(x_8, 0); +lean_inc(x_168); +x_169 = lean_ctor_get(x_8, 1); +lean_inc(x_169); +x_170 = lean_ctor_get(x_8, 2); +lean_inc(x_170); +x_171 = lean_ctor_get(x_8, 3); +lean_inc(x_171); +x_172 = lean_ctor_get(x_8, 4); +lean_inc(x_172); if (lean_is_exclusive(x_8)) { lean_ctor_release(x_8, 0); lean_ctor_release(x_8, 1); lean_ctor_release(x_8, 2); lean_ctor_release(x_8, 3); lean_ctor_release(x_8, 4); - x_229 = x_8; + x_173 = x_8; } else { lean_dec_ref(x_8); - x_229 = lean_box(0); + x_173 = lean_box(0); } -x_230 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_230, 0, x_37); -lean_ctor_set(x_230, 1, x_24); -x_231 = lean_array_push(x_226, x_230); -if (lean_is_scalar(x_229)) { +x_174 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_174, 0, x_37); +lean_ctor_set(x_174, 1, x_24); +x_175 = lean_array_push(x_170, x_174); +if (lean_is_scalar(x_173)) { + x_176 = lean_alloc_ctor(0, 5, 0); +} else { + x_176 = x_173; +} +lean_ctor_set(x_176, 0, x_168); +lean_ctor_set(x_176, 1, x_169); +lean_ctor_set(x_176, 2, x_175); +lean_ctor_set(x_176, 3, x_171); +lean_ctor_set(x_176, 4, x_172); +x_177 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_ExprDefEq_18__processConstApprox___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_39, x_176, x_35); +if (lean_obj_tag(x_177) == 0) +{ +lean_object* x_178; lean_object* x_179; lean_object* x_180; +x_178 = lean_ctor_get(x_177, 0); +lean_inc(x_178); +x_179 = lean_ctor_get(x_177, 1); +lean_inc(x_179); +lean_dec(x_177); +x_180 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_180, 0, x_178); +x_131 = x_180; +x_132 = x_179; +goto block_165; +} +else +{ +lean_object* x_181; lean_object* x_182; lean_object* x_183; +x_181 = lean_ctor_get(x_177, 0); +lean_inc(x_181); +x_182 = lean_ctor_get(x_177, 1); +lean_inc(x_182); +lean_dec(x_177); +x_183 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_183, 0, x_181); +x_131 = x_183; +x_132 = x_182; +goto block_165; +} +block_165: +{ +if (lean_obj_tag(x_131) == 0) +{ +lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; +x_133 = lean_ctor_get(x_132, 2); +lean_inc(x_133); +x_134 = lean_ctor_get(x_131, 0); +lean_inc(x_134); +lean_dec(x_131); +x_135 = lean_ctor_get(x_132, 0); +lean_inc(x_135); +x_136 = lean_ctor_get(x_132, 1); +lean_inc(x_136); +x_137 = lean_ctor_get(x_132, 3); +lean_inc(x_137); +x_138 = lean_ctor_get(x_132, 4); +lean_inc(x_138); +x_139 = lean_ctor_get(x_132, 5); +lean_inc(x_139); +if (lean_is_exclusive(x_132)) { + lean_ctor_release(x_132, 0); + lean_ctor_release(x_132, 1); + lean_ctor_release(x_132, 2); + lean_ctor_release(x_132, 3); + lean_ctor_release(x_132, 4); + lean_ctor_release(x_132, 5); + x_140 = x_132; +} else { + lean_dec_ref(x_132); + x_140 = lean_box(0); +} +x_141 = lean_ctor_get(x_133, 0); +lean_inc(x_141); +x_142 = lean_ctor_get(x_133, 1); +lean_inc(x_142); +x_143 = lean_ctor_get(x_133, 3); +lean_inc(x_143); +x_144 = lean_ctor_get(x_133, 4); +lean_inc(x_144); +if (lean_is_exclusive(x_133)) { + lean_ctor_release(x_133, 0); + lean_ctor_release(x_133, 1); + lean_ctor_release(x_133, 2); + lean_ctor_release(x_133, 3); + lean_ctor_release(x_133, 4); + x_145 = x_133; +} else { + lean_dec_ref(x_133); + x_145 = lean_box(0); +} +if (lean_is_scalar(x_145)) { + x_146 = lean_alloc_ctor(0, 5, 0); +} else { + x_146 = x_145; +} +lean_ctor_set(x_146, 0, x_141); +lean_ctor_set(x_146, 1, x_142); +lean_ctor_set(x_146, 2, x_128); +lean_ctor_set(x_146, 3, x_143); +lean_ctor_set(x_146, 4, x_144); +if (lean_is_scalar(x_140)) { + x_147 = lean_alloc_ctor(0, 6, 0); +} else { + x_147 = x_140; +} +lean_ctor_set(x_147, 0, x_135); +lean_ctor_set(x_147, 1, x_136); +lean_ctor_set(x_147, 2, x_146); +lean_ctor_set(x_147, 3, x_137); +lean_ctor_set(x_147, 4, x_138); +lean_ctor_set(x_147, 5, x_139); +if (lean_is_scalar(x_36)) { + x_148 = lean_alloc_ctor(1, 2, 0); +} else { + x_148 = x_36; + lean_ctor_set_tag(x_148, 1); +} +lean_ctor_set(x_148, 0, x_134); +lean_ctor_set(x_148, 1, x_147); +return x_148; +} +else +{ +lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; +x_149 = lean_ctor_get(x_132, 2); +lean_inc(x_149); +x_150 = lean_ctor_get(x_131, 0); +lean_inc(x_150); +lean_dec(x_131); +x_151 = lean_ctor_get(x_132, 0); +lean_inc(x_151); +x_152 = lean_ctor_get(x_132, 1); +lean_inc(x_152); +x_153 = lean_ctor_get(x_132, 3); +lean_inc(x_153); +x_154 = lean_ctor_get(x_132, 4); +lean_inc(x_154); +x_155 = lean_ctor_get(x_132, 5); +lean_inc(x_155); +if (lean_is_exclusive(x_132)) { + lean_ctor_release(x_132, 0); + lean_ctor_release(x_132, 1); + lean_ctor_release(x_132, 2); + lean_ctor_release(x_132, 3); + lean_ctor_release(x_132, 4); + lean_ctor_release(x_132, 5); + x_156 = x_132; +} else { + lean_dec_ref(x_132); + x_156 = lean_box(0); +} +x_157 = lean_ctor_get(x_149, 0); +lean_inc(x_157); +x_158 = lean_ctor_get(x_149, 1); +lean_inc(x_158); +x_159 = lean_ctor_get(x_149, 3); +lean_inc(x_159); +x_160 = lean_ctor_get(x_149, 4); +lean_inc(x_160); +if (lean_is_exclusive(x_149)) { + lean_ctor_release(x_149, 0); + lean_ctor_release(x_149, 1); + lean_ctor_release(x_149, 2); + lean_ctor_release(x_149, 3); + lean_ctor_release(x_149, 4); + x_161 = x_149; +} else { + lean_dec_ref(x_149); + x_161 = lean_box(0); +} +if (lean_is_scalar(x_161)) { + x_162 = lean_alloc_ctor(0, 5, 0); +} else { + x_162 = x_161; +} +lean_ctor_set(x_162, 0, x_157); +lean_ctor_set(x_162, 1, x_158); +lean_ctor_set(x_162, 2, x_128); +lean_ctor_set(x_162, 3, x_159); +lean_ctor_set(x_162, 4, x_160); +if (lean_is_scalar(x_156)) { + x_163 = lean_alloc_ctor(0, 6, 0); +} else { + x_163 = x_156; +} +lean_ctor_set(x_163, 0, x_151); +lean_ctor_set(x_163, 1, x_152); +lean_ctor_set(x_163, 2, x_162); +lean_ctor_set(x_163, 3, x_153); +lean_ctor_set(x_163, 4, x_154); +lean_ctor_set(x_163, 5, x_155); +if (lean_is_scalar(x_36)) { + x_164 = lean_alloc_ctor(0, 2, 0); +} else { + x_164 = x_36; +} +lean_ctor_set(x_164, 0, x_150); +lean_ctor_set(x_164, 1, x_163); +return x_164; +} +} +} +} +else +{ +lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_231; lean_object* x_232; lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_object* x_236; lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; lean_object* x_242; lean_object* x_243; +x_184 = lean_ctor_get(x_35, 2); +x_185 = lean_ctor_get(x_35, 0); +x_186 = lean_ctor_get(x_35, 1); +x_187 = lean_ctor_get(x_35, 3); +x_188 = lean_ctor_get(x_35, 4); +x_189 = lean_ctor_get(x_35, 5); +lean_inc(x_189); +lean_inc(x_188); +lean_inc(x_187); +lean_inc(x_184); +lean_inc(x_186); +lean_inc(x_185); +lean_dec(x_35); +x_190 = lean_ctor_get(x_184, 0); +lean_inc(x_190); +x_191 = lean_ctor_get(x_184, 1); +lean_inc(x_191); +x_192 = lean_ctor_get(x_184, 2); +lean_inc(x_192); +x_193 = lean_ctor_get(x_184, 3); +lean_inc(x_193); +x_194 = lean_ctor_get(x_184, 4); +lean_inc(x_194); +if (lean_is_exclusive(x_184)) { + lean_ctor_release(x_184, 0); + lean_ctor_release(x_184, 1); + lean_ctor_release(x_184, 2); + lean_ctor_release(x_184, 3); + lean_ctor_release(x_184, 4); + x_195 = x_184; +} else { + lean_dec_ref(x_184); + x_195 = lean_box(0); +} +x_231 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_195)) { x_232 = lean_alloc_ctor(0, 5, 0); } else { - x_232 = x_229; + x_232 = x_195; } -lean_ctor_set(x_232, 0, x_224); -lean_ctor_set(x_232, 1, x_225); +lean_ctor_set(x_232, 0, x_190); +lean_ctor_set(x_232, 1, x_191); lean_ctor_set(x_232, 2, x_231); -lean_ctor_set(x_232, 3, x_227); -lean_ctor_set(x_232, 4, x_228); -x_233 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_ExprDefEq_18__processConstApprox___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_39, x_232, x_223); -if (lean_obj_tag(x_233) == 0) -{ -lean_object* x_234; lean_object* x_235; lean_object* x_236; -x_234 = lean_ctor_get(x_233, 0); +lean_ctor_set(x_232, 3, x_193); +lean_ctor_set(x_232, 4, x_194); +x_233 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_233, 0, x_185); +lean_ctor_set(x_233, 1, x_186); +lean_ctor_set(x_233, 2, x_232); +lean_ctor_set(x_233, 3, x_187); +lean_ctor_set(x_233, 4, x_188); +lean_ctor_set(x_233, 5, x_189); +x_234 = lean_ctor_get(x_8, 0); lean_inc(x_234); -x_235 = lean_ctor_get(x_233, 1); +x_235 = lean_ctor_get(x_8, 1); lean_inc(x_235); -lean_dec(x_233); -x_236 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_236, 0, x_234); -x_188 = x_236; -x_189 = x_235; -goto block_220; -} -else -{ -lean_object* x_237; lean_object* x_238; lean_object* x_239; -x_237 = lean_ctor_get(x_233, 0); +x_236 = lean_ctor_get(x_8, 2); +lean_inc(x_236); +x_237 = lean_ctor_get(x_8, 3); lean_inc(x_237); -x_238 = lean_ctor_get(x_233, 1); +x_238 = lean_ctor_get(x_8, 4); lean_inc(x_238); -lean_dec(x_233); -x_239 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_239, 0, x_237); -x_188 = x_239; -x_189 = x_238; -goto block_220; +if (lean_is_exclusive(x_8)) { + lean_ctor_release(x_8, 0); + lean_ctor_release(x_8, 1); + lean_ctor_release(x_8, 2); + lean_ctor_release(x_8, 3); + lean_ctor_release(x_8, 4); + x_239 = x_8; +} else { + lean_dec_ref(x_8); + x_239 = lean_box(0); } -block_220: +x_240 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_240, 0, x_37); +lean_ctor_set(x_240, 1, x_24); +x_241 = lean_array_push(x_236, x_240); +if (lean_is_scalar(x_239)) { + x_242 = lean_alloc_ctor(0, 5, 0); +} else { + x_242 = x_239; +} +lean_ctor_set(x_242, 0, x_234); +lean_ctor_set(x_242, 1, x_235); +lean_ctor_set(x_242, 2, x_241); +lean_ctor_set(x_242, 3, x_237); +lean_ctor_set(x_242, 4, x_238); +x_243 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_ExprDefEq_18__processConstApprox___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_39, x_242, x_233); +if (lean_obj_tag(x_243) == 0) { -if (lean_obj_tag(x_188) == 0) -{ -lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; -x_190 = lean_ctor_get(x_189, 2); -lean_inc(x_190); -x_191 = lean_ctor_get(x_188, 0); -lean_inc(x_191); -lean_dec(x_188); -x_192 = lean_ctor_get(x_189, 0); -lean_inc(x_192); -x_193 = lean_ctor_get(x_189, 1); -lean_inc(x_193); -x_194 = lean_ctor_get(x_189, 3); -lean_inc(x_194); -x_195 = lean_ctor_get(x_189, 4); -lean_inc(x_195); -x_196 = lean_ctor_get(x_189, 5); -lean_inc(x_196); -if (lean_is_exclusive(x_189)) { - lean_ctor_release(x_189, 0); - lean_ctor_release(x_189, 1); - lean_ctor_release(x_189, 2); - lean_ctor_release(x_189, 3); - lean_ctor_release(x_189, 4); - lean_ctor_release(x_189, 5); - x_197 = x_189; -} else { - lean_dec_ref(x_189); - x_197 = lean_box(0); -} -x_198 = lean_ctor_get(x_190, 0); -lean_inc(x_198); -x_199 = lean_ctor_get(x_190, 1); -lean_inc(x_199); -x_200 = lean_ctor_get(x_190, 3); -lean_inc(x_200); -if (lean_is_exclusive(x_190)) { - lean_ctor_release(x_190, 0); - lean_ctor_release(x_190, 1); - lean_ctor_release(x_190, 2); - lean_ctor_release(x_190, 3); - x_201 = x_190; -} else { - lean_dec_ref(x_190); - x_201 = lean_box(0); -} -if (lean_is_scalar(x_201)) { - x_202 = lean_alloc_ctor(0, 4, 0); -} else { - x_202 = x_201; -} -lean_ctor_set(x_202, 0, x_198); -lean_ctor_set(x_202, 1, x_199); -lean_ctor_set(x_202, 2, x_185); -lean_ctor_set(x_202, 3, x_200); -if (lean_is_scalar(x_197)) { - x_203 = lean_alloc_ctor(0, 6, 0); -} else { - x_203 = x_197; -} -lean_ctor_set(x_203, 0, x_192); -lean_ctor_set(x_203, 1, x_193); -lean_ctor_set(x_203, 2, x_202); -lean_ctor_set(x_203, 3, x_194); -lean_ctor_set(x_203, 4, x_195); -lean_ctor_set(x_203, 5, x_196); -if (lean_is_scalar(x_36)) { - x_204 = lean_alloc_ctor(1, 2, 0); -} else { - x_204 = x_36; - lean_ctor_set_tag(x_204, 1); -} -lean_ctor_set(x_204, 0, x_191); -lean_ctor_set(x_204, 1, x_203); -return x_204; +lean_object* x_244; lean_object* x_245; lean_object* x_246; +x_244 = lean_ctor_get(x_243, 0); +lean_inc(x_244); +x_245 = lean_ctor_get(x_243, 1); +lean_inc(x_245); +lean_dec(x_243); +x_246 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_246, 0, x_244); +x_196 = x_246; +x_197 = x_245; +goto block_230; } else { -lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; -x_205 = lean_ctor_get(x_189, 2); -lean_inc(x_205); -x_206 = lean_ctor_get(x_188, 0); +lean_object* x_247; lean_object* x_248; lean_object* x_249; +x_247 = lean_ctor_get(x_243, 0); +lean_inc(x_247); +x_248 = lean_ctor_get(x_243, 1); +lean_inc(x_248); +lean_dec(x_243); +x_249 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_249, 0, x_247); +x_196 = x_249; +x_197 = x_248; +goto block_230; +} +block_230: +{ +if (lean_obj_tag(x_196) == 0) +{ +lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; +x_198 = lean_ctor_get(x_197, 2); +lean_inc(x_198); +x_199 = lean_ctor_get(x_196, 0); +lean_inc(x_199); +lean_dec(x_196); +x_200 = lean_ctor_get(x_197, 0); +lean_inc(x_200); +x_201 = lean_ctor_get(x_197, 1); +lean_inc(x_201); +x_202 = lean_ctor_get(x_197, 3); +lean_inc(x_202); +x_203 = lean_ctor_get(x_197, 4); +lean_inc(x_203); +x_204 = lean_ctor_get(x_197, 5); +lean_inc(x_204); +if (lean_is_exclusive(x_197)) { + lean_ctor_release(x_197, 0); + lean_ctor_release(x_197, 1); + lean_ctor_release(x_197, 2); + lean_ctor_release(x_197, 3); + lean_ctor_release(x_197, 4); + lean_ctor_release(x_197, 5); + x_205 = x_197; +} else { + lean_dec_ref(x_197); + x_205 = lean_box(0); +} +x_206 = lean_ctor_get(x_198, 0); lean_inc(x_206); -lean_dec(x_188); -x_207 = lean_ctor_get(x_189, 0); +x_207 = lean_ctor_get(x_198, 1); lean_inc(x_207); -x_208 = lean_ctor_get(x_189, 1); +x_208 = lean_ctor_get(x_198, 3); lean_inc(x_208); -x_209 = lean_ctor_get(x_189, 3); +x_209 = lean_ctor_get(x_198, 4); lean_inc(x_209); -x_210 = lean_ctor_get(x_189, 4); -lean_inc(x_210); -x_211 = lean_ctor_get(x_189, 5); -lean_inc(x_211); -if (lean_is_exclusive(x_189)) { - lean_ctor_release(x_189, 0); - lean_ctor_release(x_189, 1); - lean_ctor_release(x_189, 2); - lean_ctor_release(x_189, 3); - lean_ctor_release(x_189, 4); - lean_ctor_release(x_189, 5); - x_212 = x_189; +if (lean_is_exclusive(x_198)) { + lean_ctor_release(x_198, 0); + lean_ctor_release(x_198, 1); + lean_ctor_release(x_198, 2); + lean_ctor_release(x_198, 3); + lean_ctor_release(x_198, 4); + x_210 = x_198; } else { - lean_dec_ref(x_189); - x_212 = lean_box(0); + lean_dec_ref(x_198); + x_210 = lean_box(0); } -x_213 = lean_ctor_get(x_205, 0); -lean_inc(x_213); -x_214 = lean_ctor_get(x_205, 1); -lean_inc(x_214); -x_215 = lean_ctor_get(x_205, 3); -lean_inc(x_215); -if (lean_is_exclusive(x_205)) { - lean_ctor_release(x_205, 0); - lean_ctor_release(x_205, 1); - lean_ctor_release(x_205, 2); - lean_ctor_release(x_205, 3); - x_216 = x_205; +if (lean_is_scalar(x_210)) { + x_211 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_205); - x_216 = lean_box(0); + x_211 = x_210; } -if (lean_is_scalar(x_216)) { - x_217 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_211, 0, x_206); +lean_ctor_set(x_211, 1, x_207); +lean_ctor_set(x_211, 2, x_192); +lean_ctor_set(x_211, 3, x_208); +lean_ctor_set(x_211, 4, x_209); +if (lean_is_scalar(x_205)) { + x_212 = lean_alloc_ctor(0, 6, 0); } else { - x_217 = x_216; + x_212 = x_205; } -lean_ctor_set(x_217, 0, x_213); -lean_ctor_set(x_217, 1, x_214); -lean_ctor_set(x_217, 2, x_185); -lean_ctor_set(x_217, 3, x_215); -if (lean_is_scalar(x_212)) { - x_218 = lean_alloc_ctor(0, 6, 0); -} else { - x_218 = x_212; -} -lean_ctor_set(x_218, 0, x_207); -lean_ctor_set(x_218, 1, x_208); -lean_ctor_set(x_218, 2, x_217); -lean_ctor_set(x_218, 3, x_209); -lean_ctor_set(x_218, 4, x_210); -lean_ctor_set(x_218, 5, x_211); +lean_ctor_set(x_212, 0, x_200); +lean_ctor_set(x_212, 1, x_201); +lean_ctor_set(x_212, 2, x_211); +lean_ctor_set(x_212, 3, x_202); +lean_ctor_set(x_212, 4, x_203); +lean_ctor_set(x_212, 5, x_204); if (lean_is_scalar(x_36)) { - x_219 = lean_alloc_ctor(0, 2, 0); + x_213 = lean_alloc_ctor(1, 2, 0); } else { - x_219 = x_36; + x_213 = x_36; + lean_ctor_set_tag(x_213, 1); } -lean_ctor_set(x_219, 0, x_206); -lean_ctor_set(x_219, 1, x_218); -return x_219; +lean_ctor_set(x_213, 0, x_199); +lean_ctor_set(x_213, 1, x_212); +return x_213; +} +else +{ +lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; 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; +x_214 = lean_ctor_get(x_197, 2); +lean_inc(x_214); +x_215 = lean_ctor_get(x_196, 0); +lean_inc(x_215); +lean_dec(x_196); +x_216 = lean_ctor_get(x_197, 0); +lean_inc(x_216); +x_217 = lean_ctor_get(x_197, 1); +lean_inc(x_217); +x_218 = lean_ctor_get(x_197, 3); +lean_inc(x_218); +x_219 = lean_ctor_get(x_197, 4); +lean_inc(x_219); +x_220 = lean_ctor_get(x_197, 5); +lean_inc(x_220); +if (lean_is_exclusive(x_197)) { + lean_ctor_release(x_197, 0); + lean_ctor_release(x_197, 1); + lean_ctor_release(x_197, 2); + lean_ctor_release(x_197, 3); + lean_ctor_release(x_197, 4); + lean_ctor_release(x_197, 5); + x_221 = x_197; +} else { + lean_dec_ref(x_197); + x_221 = lean_box(0); +} +x_222 = lean_ctor_get(x_214, 0); +lean_inc(x_222); +x_223 = lean_ctor_get(x_214, 1); +lean_inc(x_223); +x_224 = lean_ctor_get(x_214, 3); +lean_inc(x_224); +x_225 = lean_ctor_get(x_214, 4); +lean_inc(x_225); +if (lean_is_exclusive(x_214)) { + lean_ctor_release(x_214, 0); + lean_ctor_release(x_214, 1); + lean_ctor_release(x_214, 2); + lean_ctor_release(x_214, 3); + lean_ctor_release(x_214, 4); + x_226 = x_214; +} else { + lean_dec_ref(x_214); + x_226 = lean_box(0); +} +if (lean_is_scalar(x_226)) { + x_227 = lean_alloc_ctor(0, 5, 0); +} else { + x_227 = x_226; +} +lean_ctor_set(x_227, 0, x_222); +lean_ctor_set(x_227, 1, x_223); +lean_ctor_set(x_227, 2, x_192); +lean_ctor_set(x_227, 3, x_224); +lean_ctor_set(x_227, 4, x_225); +if (lean_is_scalar(x_221)) { + x_228 = lean_alloc_ctor(0, 6, 0); +} else { + x_228 = x_221; +} +lean_ctor_set(x_228, 0, x_216); +lean_ctor_set(x_228, 1, x_217); +lean_ctor_set(x_228, 2, x_227); +lean_ctor_set(x_228, 3, x_218); +lean_ctor_set(x_228, 4, x_219); +lean_ctor_set(x_228, 5, x_220); +if (lean_is_scalar(x_36)) { + x_229 = lean_alloc_ctor(0, 2, 0); +} else { + x_229 = x_36; +} +lean_ctor_set(x_229, 0, x_215); +lean_ctor_set(x_229, 1, x_228); +return x_229; } } } } default: { -lean_object* x_240; lean_object* x_241; -x_240 = lean_ctor_get(x_29, 1); -lean_inc(x_240); +lean_object* x_250; lean_object* x_251; +x_250 = lean_ctor_get(x_29, 1); +lean_inc(x_250); lean_dec(x_29); lean_inc(x_8); -x_241 = l_Lean_Meta_isClassExpensive___main(x_28, x_8, x_240); -if (lean_obj_tag(x_241) == 0) +x_251 = l_Lean_Meta_isClassExpensive___main(x_28, x_8, x_250); +if (lean_obj_tag(x_251) == 0) { -lean_object* x_242; -x_242 = lean_ctor_get(x_241, 0); -lean_inc(x_242); -if (lean_obj_tag(x_242) == 0) +lean_object* x_252; +x_252 = lean_ctor_get(x_251, 0); +lean_inc(x_252); +if (lean_obj_tag(x_252) == 0) { -lean_object* x_243; lean_object* x_244; lean_object* x_245; +lean_object* x_253; lean_object* x_254; lean_object* x_255; lean_dec(x_24); -x_243 = lean_ctor_get(x_241, 1); -lean_inc(x_243); -lean_dec(x_241); -x_244 = lean_unsigned_to_nat(1u); -x_245 = lean_nat_add(x_7, x_244); +x_253 = lean_ctor_get(x_251, 1); +lean_inc(x_253); +lean_dec(x_251); +x_254 = lean_unsigned_to_nat(1u); +x_255 = lean_nat_add(x_7, x_254); lean_dec(x_7); -x_7 = x_245; -x_9 = x_243; +x_7 = x_255; +x_9 = x_253; goto _start; } else { -lean_object* x_247; lean_object* x_248; lean_object* x_249; lean_object* x_250; lean_object* x_251; uint8_t x_252; -x_247 = lean_ctor_get(x_241, 1); -lean_inc(x_247); -if (lean_is_exclusive(x_241)) { - lean_ctor_release(x_241, 0); - lean_ctor_release(x_241, 1); - x_248 = x_241; +lean_object* x_257; lean_object* x_258; lean_object* x_259; lean_object* x_260; lean_object* x_261; uint8_t x_262; +x_257 = lean_ctor_get(x_251, 1); +lean_inc(x_257); +if (lean_is_exclusive(x_251)) { + lean_ctor_release(x_251, 0); + lean_ctor_release(x_251, 1); + x_258 = x_251; } else { - lean_dec_ref(x_241); - x_248 = lean_box(0); + lean_dec_ref(x_251); + x_258 = lean_box(0); } -x_249 = lean_ctor_get(x_242, 0); -lean_inc(x_249); -lean_dec(x_242); -x_250 = lean_unsigned_to_nat(1u); -x_251 = lean_nat_add(x_7, x_250); -lean_dec(x_7); -x_252 = !lean_is_exclusive(x_247); -if (x_252 == 0) -{ -lean_object* x_253; uint8_t x_254; -x_253 = lean_ctor_get(x_247, 2); -x_254 = !lean_is_exclusive(x_253); -if (x_254 == 0) -{ -lean_object* x_255; lean_object* x_256; lean_object* x_257; lean_object* x_307; uint8_t x_308; -x_255 = lean_ctor_get(x_253, 2); -x_307 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_253, 2, x_307); -x_308 = !lean_is_exclusive(x_8); -if (x_308 == 0) -{ -lean_object* x_309; lean_object* x_310; lean_object* x_311; lean_object* x_312; -x_309 = lean_ctor_get(x_8, 2); -x_310 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_310, 0, x_249); -lean_ctor_set(x_310, 1, x_24); -x_311 = lean_array_push(x_309, x_310); -lean_ctor_set(x_8, 2, x_311); -x_312 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_ExprDefEq_18__processConstApprox___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_251, x_8, x_247); -if (lean_obj_tag(x_312) == 0) -{ -lean_object* x_313; lean_object* x_314; lean_object* x_315; -x_313 = lean_ctor_get(x_312, 0); -lean_inc(x_313); -x_314 = lean_ctor_get(x_312, 1); -lean_inc(x_314); -lean_dec(x_312); -x_315 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_315, 0, x_313); -x_256 = x_315; -x_257 = x_314; -goto block_306; -} -else -{ -lean_object* x_316; lean_object* x_317; lean_object* x_318; -x_316 = lean_ctor_get(x_312, 0); -lean_inc(x_316); -x_317 = lean_ctor_get(x_312, 1); -lean_inc(x_317); -lean_dec(x_312); -x_318 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_318, 0, x_316); -x_256 = x_318; -x_257 = x_317; -goto block_306; -} -} -else -{ -lean_object* x_319; lean_object* x_320; lean_object* x_321; lean_object* x_322; lean_object* x_323; lean_object* x_324; lean_object* x_325; lean_object* x_326; lean_object* x_327; -x_319 = lean_ctor_get(x_8, 0); -x_320 = lean_ctor_get(x_8, 1); -x_321 = lean_ctor_get(x_8, 2); -x_322 = lean_ctor_get(x_8, 3); -x_323 = lean_ctor_get(x_8, 4); -lean_inc(x_323); -lean_inc(x_322); -lean_inc(x_321); -lean_inc(x_320); -lean_inc(x_319); -lean_dec(x_8); -x_324 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_324, 0, x_249); -lean_ctor_set(x_324, 1, x_24); -x_325 = lean_array_push(x_321, x_324); -x_326 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_326, 0, x_319); -lean_ctor_set(x_326, 1, x_320); -lean_ctor_set(x_326, 2, x_325); -lean_ctor_set(x_326, 3, x_322); -lean_ctor_set(x_326, 4, x_323); -x_327 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_ExprDefEq_18__processConstApprox___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_251, x_326, x_247); -if (lean_obj_tag(x_327) == 0) -{ -lean_object* x_328; lean_object* x_329; lean_object* x_330; -x_328 = lean_ctor_get(x_327, 0); -lean_inc(x_328); -x_329 = lean_ctor_get(x_327, 1); -lean_inc(x_329); -lean_dec(x_327); -x_330 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_330, 0, x_328); -x_256 = x_330; -x_257 = x_329; -goto block_306; -} -else -{ -lean_object* x_331; lean_object* x_332; lean_object* x_333; -x_331 = lean_ctor_get(x_327, 0); -lean_inc(x_331); -x_332 = lean_ctor_get(x_327, 1); -lean_inc(x_332); -lean_dec(x_327); -x_333 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_333, 0, x_331); -x_256 = x_333; -x_257 = x_332; -goto block_306; -} -} -block_306: -{ -if (lean_obj_tag(x_256) == 0) -{ -lean_object* x_258; lean_object* x_259; uint8_t x_260; -x_258 = lean_ctor_get(x_257, 2); -lean_inc(x_258); -x_259 = lean_ctor_get(x_256, 0); +x_259 = lean_ctor_get(x_252, 0); lean_inc(x_259); -lean_dec(x_256); -x_260 = !lean_is_exclusive(x_257); -if (x_260 == 0) -{ -lean_object* x_261; uint8_t x_262; -x_261 = lean_ctor_get(x_257, 2); -lean_dec(x_261); -x_262 = !lean_is_exclusive(x_258); +lean_dec(x_252); +x_260 = lean_unsigned_to_nat(1u); +x_261 = lean_nat_add(x_7, x_260); +lean_dec(x_7); +x_262 = !lean_is_exclusive(x_257); if (x_262 == 0) { -lean_object* x_263; lean_object* x_264; -x_263 = lean_ctor_get(x_258, 2); -lean_dec(x_263); -lean_ctor_set(x_258, 2, x_255); -if (lean_is_scalar(x_248)) { - x_264 = lean_alloc_ctor(1, 2, 0); -} else { - x_264 = x_248; - lean_ctor_set_tag(x_264, 1); -} -lean_ctor_set(x_264, 0, x_259); -lean_ctor_set(x_264, 1, x_257); -return x_264; +lean_object* x_263; uint8_t x_264; +x_263 = lean_ctor_get(x_257, 2); +x_264 = !lean_is_exclusive(x_263); +if (x_264 == 0) +{ +lean_object* x_265; lean_object* x_266; lean_object* x_267; lean_object* x_321; uint8_t x_322; +x_265 = lean_ctor_get(x_263, 2); +x_321 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_263, 2, x_321); +x_322 = !lean_is_exclusive(x_8); +if (x_322 == 0) +{ +lean_object* x_323; lean_object* x_324; lean_object* x_325; lean_object* x_326; +x_323 = lean_ctor_get(x_8, 2); +x_324 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_324, 0, x_259); +lean_ctor_set(x_324, 1, x_24); +x_325 = lean_array_push(x_323, x_324); +lean_ctor_set(x_8, 2, x_325); +x_326 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_ExprDefEq_18__processConstApprox___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_261, x_8, x_257); +if (lean_obj_tag(x_326) == 0) +{ +lean_object* x_327; lean_object* x_328; lean_object* x_329; +x_327 = lean_ctor_get(x_326, 0); +lean_inc(x_327); +x_328 = lean_ctor_get(x_326, 1); +lean_inc(x_328); +lean_dec(x_326); +x_329 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_329, 0, x_327); +x_266 = x_329; +x_267 = x_328; +goto block_320; } else { -lean_object* x_265; lean_object* x_266; lean_object* x_267; lean_object* x_268; lean_object* x_269; -x_265 = lean_ctor_get(x_258, 0); -x_266 = lean_ctor_get(x_258, 1); -x_267 = lean_ctor_get(x_258, 3); -lean_inc(x_267); -lean_inc(x_266); -lean_inc(x_265); -lean_dec(x_258); -x_268 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_268, 0, x_265); -lean_ctor_set(x_268, 1, x_266); -lean_ctor_set(x_268, 2, x_255); -lean_ctor_set(x_268, 3, x_267); -lean_ctor_set(x_257, 2, x_268); -if (lean_is_scalar(x_248)) { - x_269 = lean_alloc_ctor(1, 2, 0); -} else { - x_269 = x_248; - lean_ctor_set_tag(x_269, 1); -} -lean_ctor_set(x_269, 0, x_259); -lean_ctor_set(x_269, 1, x_257); -return x_269; +lean_object* x_330; lean_object* x_331; lean_object* x_332; +x_330 = lean_ctor_get(x_326, 0); +lean_inc(x_330); +x_331 = lean_ctor_get(x_326, 1); +lean_inc(x_331); +lean_dec(x_326); +x_332 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_332, 0, x_330); +x_266 = x_332; +x_267 = x_331; +goto block_320; } } else { -lean_object* x_270; lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_object* x_276; lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; lean_object* x_281; -x_270 = lean_ctor_get(x_257, 0); -x_271 = lean_ctor_get(x_257, 1); -x_272 = lean_ctor_get(x_257, 3); -x_273 = lean_ctor_get(x_257, 4); -x_274 = lean_ctor_get(x_257, 5); -lean_inc(x_274); -lean_inc(x_273); -lean_inc(x_272); -lean_inc(x_271); -lean_inc(x_270); -lean_dec(x_257); -x_275 = lean_ctor_get(x_258, 0); -lean_inc(x_275); -x_276 = lean_ctor_get(x_258, 1); -lean_inc(x_276); -x_277 = lean_ctor_get(x_258, 3); +lean_object* x_333; lean_object* x_334; lean_object* x_335; lean_object* x_336; lean_object* x_337; lean_object* x_338; lean_object* x_339; lean_object* x_340; lean_object* x_341; +x_333 = lean_ctor_get(x_8, 0); +x_334 = lean_ctor_get(x_8, 1); +x_335 = lean_ctor_get(x_8, 2); +x_336 = lean_ctor_get(x_8, 3); +x_337 = lean_ctor_get(x_8, 4); +lean_inc(x_337); +lean_inc(x_336); +lean_inc(x_335); +lean_inc(x_334); +lean_inc(x_333); +lean_dec(x_8); +x_338 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_338, 0, x_259); +lean_ctor_set(x_338, 1, x_24); +x_339 = lean_array_push(x_335, x_338); +x_340 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_340, 0, x_333); +lean_ctor_set(x_340, 1, x_334); +lean_ctor_set(x_340, 2, x_339); +lean_ctor_set(x_340, 3, x_336); +lean_ctor_set(x_340, 4, x_337); +x_341 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_ExprDefEq_18__processConstApprox___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_261, x_340, x_257); +if (lean_obj_tag(x_341) == 0) +{ +lean_object* x_342; lean_object* x_343; lean_object* x_344; +x_342 = lean_ctor_get(x_341, 0); +lean_inc(x_342); +x_343 = lean_ctor_get(x_341, 1); +lean_inc(x_343); +lean_dec(x_341); +x_344 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_344, 0, x_342); +x_266 = x_344; +x_267 = x_343; +goto block_320; +} +else +{ +lean_object* x_345; lean_object* x_346; lean_object* x_347; +x_345 = lean_ctor_get(x_341, 0); +lean_inc(x_345); +x_346 = lean_ctor_get(x_341, 1); +lean_inc(x_346); +lean_dec(x_341); +x_347 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_347, 0, x_345); +x_266 = x_347; +x_267 = x_346; +goto block_320; +} +} +block_320: +{ +if (lean_obj_tag(x_266) == 0) +{ +lean_object* x_268; lean_object* x_269; uint8_t x_270; +x_268 = lean_ctor_get(x_267, 2); +lean_inc(x_268); +x_269 = lean_ctor_get(x_266, 0); +lean_inc(x_269); +lean_dec(x_266); +x_270 = !lean_is_exclusive(x_267); +if (x_270 == 0) +{ +lean_object* x_271; uint8_t x_272; +x_271 = lean_ctor_get(x_267, 2); +lean_dec(x_271); +x_272 = !lean_is_exclusive(x_268); +if (x_272 == 0) +{ +lean_object* x_273; lean_object* x_274; +x_273 = lean_ctor_get(x_268, 2); +lean_dec(x_273); +lean_ctor_set(x_268, 2, x_265); +if (lean_is_scalar(x_258)) { + x_274 = lean_alloc_ctor(1, 2, 0); +} else { + x_274 = x_258; + lean_ctor_set_tag(x_274, 1); +} +lean_ctor_set(x_274, 0, x_269); +lean_ctor_set(x_274, 1, x_267); +return x_274; +} +else +{ +lean_object* x_275; lean_object* x_276; lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; +x_275 = lean_ctor_get(x_268, 0); +x_276 = lean_ctor_get(x_268, 1); +x_277 = lean_ctor_get(x_268, 3); +x_278 = lean_ctor_get(x_268, 4); +lean_inc(x_278); lean_inc(x_277); -if (lean_is_exclusive(x_258)) { - lean_ctor_release(x_258, 0); - lean_ctor_release(x_258, 1); - lean_ctor_release(x_258, 2); - lean_ctor_release(x_258, 3); - x_278 = x_258; -} else { - lean_dec_ref(x_258); - x_278 = lean_box(0); -} -if (lean_is_scalar(x_278)) { - x_279 = lean_alloc_ctor(0, 4, 0); -} else { - x_279 = x_278; -} +lean_inc(x_276); +lean_inc(x_275); +lean_dec(x_268); +x_279 = lean_alloc_ctor(0, 5, 0); lean_ctor_set(x_279, 0, x_275); lean_ctor_set(x_279, 1, x_276); -lean_ctor_set(x_279, 2, x_255); +lean_ctor_set(x_279, 2, x_265); lean_ctor_set(x_279, 3, x_277); -x_280 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_280, 0, x_270); -lean_ctor_set(x_280, 1, x_271); -lean_ctor_set(x_280, 2, x_279); -lean_ctor_set(x_280, 3, x_272); -lean_ctor_set(x_280, 4, x_273); -lean_ctor_set(x_280, 5, x_274); -if (lean_is_scalar(x_248)) { - x_281 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_279, 4, x_278); +lean_ctor_set(x_267, 2, x_279); +if (lean_is_scalar(x_258)) { + x_280 = lean_alloc_ctor(1, 2, 0); } else { - x_281 = x_248; - lean_ctor_set_tag(x_281, 1); + x_280 = x_258; + lean_ctor_set_tag(x_280, 1); } -lean_ctor_set(x_281, 0, x_259); -lean_ctor_set(x_281, 1, x_280); -return x_281; +lean_ctor_set(x_280, 0, x_269); +lean_ctor_set(x_280, 1, x_267); +return x_280; } } else { -lean_object* x_282; lean_object* x_283; uint8_t x_284; -x_282 = lean_ctor_get(x_257, 2); -lean_inc(x_282); -x_283 = lean_ctor_get(x_256, 0); +lean_object* x_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; lean_object* x_289; lean_object* x_290; lean_object* x_291; lean_object* x_292; lean_object* x_293; +x_281 = lean_ctor_get(x_267, 0); +x_282 = lean_ctor_get(x_267, 1); +x_283 = lean_ctor_get(x_267, 3); +x_284 = lean_ctor_get(x_267, 4); +x_285 = lean_ctor_get(x_267, 5); +lean_inc(x_285); +lean_inc(x_284); lean_inc(x_283); -lean_dec(x_256); -x_284 = !lean_is_exclusive(x_257); -if (x_284 == 0) -{ -lean_object* x_285; uint8_t x_286; -x_285 = lean_ctor_get(x_257, 2); -lean_dec(x_285); -x_286 = !lean_is_exclusive(x_282); -if (x_286 == 0) -{ -lean_object* x_287; lean_object* x_288; -x_287 = lean_ctor_get(x_282, 2); -lean_dec(x_287); -lean_ctor_set(x_282, 2, x_255); -if (lean_is_scalar(x_248)) { - x_288 = lean_alloc_ctor(0, 2, 0); -} else { - x_288 = x_248; -} -lean_ctor_set(x_288, 0, x_283); -lean_ctor_set(x_288, 1, x_257); -return x_288; -} -else -{ -lean_object* x_289; lean_object* x_290; lean_object* x_291; lean_object* x_292; lean_object* x_293; -x_289 = lean_ctor_get(x_282, 0); -x_290 = lean_ctor_get(x_282, 1); -x_291 = lean_ctor_get(x_282, 3); -lean_inc(x_291); -lean_inc(x_290); +lean_inc(x_282); +lean_inc(x_281); +lean_dec(x_267); +x_286 = lean_ctor_get(x_268, 0); +lean_inc(x_286); +x_287 = lean_ctor_get(x_268, 1); +lean_inc(x_287); +x_288 = lean_ctor_get(x_268, 3); +lean_inc(x_288); +x_289 = lean_ctor_get(x_268, 4); lean_inc(x_289); -lean_dec(x_282); -x_292 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_292, 0, x_289); -lean_ctor_set(x_292, 1, x_290); -lean_ctor_set(x_292, 2, x_255); -lean_ctor_set(x_292, 3, x_291); -lean_ctor_set(x_257, 2, x_292); -if (lean_is_scalar(x_248)) { - x_293 = lean_alloc_ctor(0, 2, 0); +if (lean_is_exclusive(x_268)) { + lean_ctor_release(x_268, 0); + lean_ctor_release(x_268, 1); + lean_ctor_release(x_268, 2); + lean_ctor_release(x_268, 3); + lean_ctor_release(x_268, 4); + x_290 = x_268; } else { - x_293 = x_248; + lean_dec_ref(x_268); + x_290 = lean_box(0); } -lean_ctor_set(x_293, 0, x_283); -lean_ctor_set(x_293, 1, x_257); +if (lean_is_scalar(x_290)) { + x_291 = lean_alloc_ctor(0, 5, 0); +} else { + x_291 = x_290; +} +lean_ctor_set(x_291, 0, x_286); +lean_ctor_set(x_291, 1, x_287); +lean_ctor_set(x_291, 2, x_265); +lean_ctor_set(x_291, 3, x_288); +lean_ctor_set(x_291, 4, x_289); +x_292 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_292, 0, x_281); +lean_ctor_set(x_292, 1, x_282); +lean_ctor_set(x_292, 2, x_291); +lean_ctor_set(x_292, 3, x_283); +lean_ctor_set(x_292, 4, x_284); +lean_ctor_set(x_292, 5, x_285); +if (lean_is_scalar(x_258)) { + x_293 = lean_alloc_ctor(1, 2, 0); +} else { + x_293 = x_258; + lean_ctor_set_tag(x_293, 1); +} +lean_ctor_set(x_293, 0, x_269); +lean_ctor_set(x_293, 1, x_292); return x_293; } } else { -lean_object* x_294; lean_object* x_295; lean_object* x_296; lean_object* x_297; lean_object* x_298; lean_object* x_299; lean_object* x_300; lean_object* x_301; lean_object* x_302; lean_object* x_303; lean_object* x_304; lean_object* x_305; -x_294 = lean_ctor_get(x_257, 0); -x_295 = lean_ctor_get(x_257, 1); -x_296 = lean_ctor_get(x_257, 3); -x_297 = lean_ctor_get(x_257, 4); -x_298 = lean_ctor_get(x_257, 5); -lean_inc(x_298); -lean_inc(x_297); -lean_inc(x_296); -lean_inc(x_295); +lean_object* x_294; lean_object* x_295; uint8_t x_296; +x_294 = lean_ctor_get(x_267, 2); lean_inc(x_294); -lean_dec(x_257); -x_299 = lean_ctor_get(x_282, 0); -lean_inc(x_299); -x_300 = lean_ctor_get(x_282, 1); -lean_inc(x_300); -x_301 = lean_ctor_get(x_282, 3); +x_295 = lean_ctor_get(x_266, 0); +lean_inc(x_295); +lean_dec(x_266); +x_296 = !lean_is_exclusive(x_267); +if (x_296 == 0) +{ +lean_object* x_297; uint8_t x_298; +x_297 = lean_ctor_get(x_267, 2); +lean_dec(x_297); +x_298 = !lean_is_exclusive(x_294); +if (x_298 == 0) +{ +lean_object* x_299; lean_object* x_300; +x_299 = lean_ctor_get(x_294, 2); +lean_dec(x_299); +lean_ctor_set(x_294, 2, x_265); +if (lean_is_scalar(x_258)) { + x_300 = lean_alloc_ctor(0, 2, 0); +} else { + x_300 = x_258; +} +lean_ctor_set(x_300, 0, x_295); +lean_ctor_set(x_300, 1, x_267); +return x_300; +} +else +{ +lean_object* x_301; lean_object* x_302; lean_object* x_303; lean_object* x_304; lean_object* x_305; lean_object* x_306; +x_301 = lean_ctor_get(x_294, 0); +x_302 = lean_ctor_get(x_294, 1); +x_303 = lean_ctor_get(x_294, 3); +x_304 = lean_ctor_get(x_294, 4); +lean_inc(x_304); +lean_inc(x_303); +lean_inc(x_302); lean_inc(x_301); -if (lean_is_exclusive(x_282)) { - lean_ctor_release(x_282, 0); - lean_ctor_release(x_282, 1); - lean_ctor_release(x_282, 2); - lean_ctor_release(x_282, 3); - x_302 = x_282; +lean_dec(x_294); +x_305 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_305, 0, x_301); +lean_ctor_set(x_305, 1, x_302); +lean_ctor_set(x_305, 2, x_265); +lean_ctor_set(x_305, 3, x_303); +lean_ctor_set(x_305, 4, x_304); +lean_ctor_set(x_267, 2, x_305); +if (lean_is_scalar(x_258)) { + x_306 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_282); - x_302 = lean_box(0); + x_306 = x_258; } -if (lean_is_scalar(x_302)) { - x_303 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_306, 0, x_295); +lean_ctor_set(x_306, 1, x_267); +return x_306; +} +} +else +{ +lean_object* x_307; lean_object* x_308; lean_object* x_309; lean_object* x_310; lean_object* x_311; lean_object* x_312; lean_object* x_313; lean_object* x_314; lean_object* x_315; lean_object* x_316; lean_object* x_317; lean_object* x_318; lean_object* x_319; +x_307 = lean_ctor_get(x_267, 0); +x_308 = lean_ctor_get(x_267, 1); +x_309 = lean_ctor_get(x_267, 3); +x_310 = lean_ctor_get(x_267, 4); +x_311 = lean_ctor_get(x_267, 5); +lean_inc(x_311); +lean_inc(x_310); +lean_inc(x_309); +lean_inc(x_308); +lean_inc(x_307); +lean_dec(x_267); +x_312 = lean_ctor_get(x_294, 0); +lean_inc(x_312); +x_313 = lean_ctor_get(x_294, 1); +lean_inc(x_313); +x_314 = lean_ctor_get(x_294, 3); +lean_inc(x_314); +x_315 = lean_ctor_get(x_294, 4); +lean_inc(x_315); +if (lean_is_exclusive(x_294)) { + lean_ctor_release(x_294, 0); + lean_ctor_release(x_294, 1); + lean_ctor_release(x_294, 2); + lean_ctor_release(x_294, 3); + lean_ctor_release(x_294, 4); + x_316 = x_294; } else { - x_303 = x_302; + lean_dec_ref(x_294); + x_316 = lean_box(0); } -lean_ctor_set(x_303, 0, x_299); -lean_ctor_set(x_303, 1, x_300); -lean_ctor_set(x_303, 2, x_255); -lean_ctor_set(x_303, 3, x_301); -x_304 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_304, 0, x_294); -lean_ctor_set(x_304, 1, x_295); -lean_ctor_set(x_304, 2, x_303); -lean_ctor_set(x_304, 3, x_296); -lean_ctor_set(x_304, 4, x_297); -lean_ctor_set(x_304, 5, x_298); -if (lean_is_scalar(x_248)) { - x_305 = lean_alloc_ctor(0, 2, 0); +if (lean_is_scalar(x_316)) { + x_317 = lean_alloc_ctor(0, 5, 0); } else { - x_305 = x_248; + x_317 = x_316; } -lean_ctor_set(x_305, 0, x_283); -lean_ctor_set(x_305, 1, x_304); -return x_305; +lean_ctor_set(x_317, 0, x_312); +lean_ctor_set(x_317, 1, x_313); +lean_ctor_set(x_317, 2, x_265); +lean_ctor_set(x_317, 3, x_314); +lean_ctor_set(x_317, 4, x_315); +x_318 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_318, 0, x_307); +lean_ctor_set(x_318, 1, x_308); +lean_ctor_set(x_318, 2, x_317); +lean_ctor_set(x_318, 3, x_309); +lean_ctor_set(x_318, 4, x_310); +lean_ctor_set(x_318, 5, x_311); +if (lean_is_scalar(x_258)) { + x_319 = lean_alloc_ctor(0, 2, 0); +} else { + x_319 = x_258; +} +lean_ctor_set(x_319, 0, x_295); +lean_ctor_set(x_319, 1, x_318); +return x_319; } } } } else { -lean_object* x_334; lean_object* x_335; lean_object* x_336; lean_object* x_337; lean_object* x_338; lean_object* x_339; lean_object* x_371; lean_object* x_372; lean_object* x_373; lean_object* x_374; lean_object* x_375; 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; -x_334 = lean_ctor_get(x_253, 0); -x_335 = lean_ctor_get(x_253, 1); -x_336 = lean_ctor_get(x_253, 2); -x_337 = lean_ctor_get(x_253, 3); -lean_inc(x_337); -lean_inc(x_336); -lean_inc(x_335); -lean_inc(x_334); -lean_dec(x_253); -x_371 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_372 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_372, 0, x_334); -lean_ctor_set(x_372, 1, x_335); -lean_ctor_set(x_372, 2, x_371); -lean_ctor_set(x_372, 3, x_337); -lean_ctor_set(x_247, 2, x_372); -x_373 = lean_ctor_get(x_8, 0); -lean_inc(x_373); -x_374 = lean_ctor_get(x_8, 1); -lean_inc(x_374); -x_375 = lean_ctor_get(x_8, 2); -lean_inc(x_375); -x_376 = lean_ctor_get(x_8, 3); -lean_inc(x_376); -x_377 = lean_ctor_get(x_8, 4); -lean_inc(x_377); +lean_object* x_348; lean_object* x_349; lean_object* x_350; lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_388; lean_object* x_389; lean_object* x_390; lean_object* x_391; lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; +x_348 = lean_ctor_get(x_263, 0); +x_349 = lean_ctor_get(x_263, 1); +x_350 = lean_ctor_get(x_263, 2); +x_351 = lean_ctor_get(x_263, 3); +x_352 = lean_ctor_get(x_263, 4); +lean_inc(x_352); +lean_inc(x_351); +lean_inc(x_350); +lean_inc(x_349); +lean_inc(x_348); +lean_dec(x_263); +x_388 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_389 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_389, 0, x_348); +lean_ctor_set(x_389, 1, x_349); +lean_ctor_set(x_389, 2, x_388); +lean_ctor_set(x_389, 3, x_351); +lean_ctor_set(x_389, 4, x_352); +lean_ctor_set(x_257, 2, x_389); +x_390 = lean_ctor_get(x_8, 0); +lean_inc(x_390); +x_391 = lean_ctor_get(x_8, 1); +lean_inc(x_391); +x_392 = lean_ctor_get(x_8, 2); +lean_inc(x_392); +x_393 = lean_ctor_get(x_8, 3); +lean_inc(x_393); +x_394 = lean_ctor_get(x_8, 4); +lean_inc(x_394); if (lean_is_exclusive(x_8)) { lean_ctor_release(x_8, 0); lean_ctor_release(x_8, 1); lean_ctor_release(x_8, 2); lean_ctor_release(x_8, 3); lean_ctor_release(x_8, 4); - x_378 = x_8; + x_395 = x_8; } else { lean_dec_ref(x_8); - x_378 = lean_box(0); + x_395 = lean_box(0); } -x_379 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_379, 0, x_249); -lean_ctor_set(x_379, 1, x_24); -x_380 = lean_array_push(x_375, x_379); -if (lean_is_scalar(x_378)) { - x_381 = lean_alloc_ctor(0, 5, 0); +x_396 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_396, 0, x_259); +lean_ctor_set(x_396, 1, x_24); +x_397 = lean_array_push(x_392, x_396); +if (lean_is_scalar(x_395)) { + x_398 = lean_alloc_ctor(0, 5, 0); } else { - x_381 = x_378; + x_398 = x_395; } -lean_ctor_set(x_381, 0, x_373); -lean_ctor_set(x_381, 1, x_374); -lean_ctor_set(x_381, 2, x_380); -lean_ctor_set(x_381, 3, x_376); -lean_ctor_set(x_381, 4, x_377); -x_382 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_ExprDefEq_18__processConstApprox___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_251, x_381, x_247); -if (lean_obj_tag(x_382) == 0) +lean_ctor_set(x_398, 0, x_390); +lean_ctor_set(x_398, 1, x_391); +lean_ctor_set(x_398, 2, x_397); +lean_ctor_set(x_398, 3, x_393); +lean_ctor_set(x_398, 4, x_394); +x_399 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_ExprDefEq_18__processConstApprox___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_261, x_398, x_257); +if (lean_obj_tag(x_399) == 0) { -lean_object* x_383; lean_object* x_384; lean_object* x_385; -x_383 = lean_ctor_get(x_382, 0); -lean_inc(x_383); -x_384 = lean_ctor_get(x_382, 1); -lean_inc(x_384); -lean_dec(x_382); -x_385 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_385, 0, x_383); -x_338 = x_385; -x_339 = x_384; -goto block_370; +lean_object* x_400; lean_object* x_401; lean_object* x_402; +x_400 = lean_ctor_get(x_399, 0); +lean_inc(x_400); +x_401 = lean_ctor_get(x_399, 1); +lean_inc(x_401); +lean_dec(x_399); +x_402 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_402, 0, x_400); +x_353 = x_402; +x_354 = x_401; +goto block_387; } else { -lean_object* x_386; lean_object* x_387; lean_object* x_388; -x_386 = lean_ctor_get(x_382, 0); -lean_inc(x_386); -x_387 = lean_ctor_get(x_382, 1); -lean_inc(x_387); -lean_dec(x_382); -x_388 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_388, 0, x_386); -x_338 = x_388; -x_339 = x_387; -goto block_370; +lean_object* x_403; lean_object* x_404; lean_object* x_405; +x_403 = lean_ctor_get(x_399, 0); +lean_inc(x_403); +x_404 = lean_ctor_get(x_399, 1); +lean_inc(x_404); +lean_dec(x_399); +x_405 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_405, 0, x_403); +x_353 = x_405; +x_354 = x_404; +goto block_387; } -block_370: +block_387: { -if (lean_obj_tag(x_338) == 0) +if (lean_obj_tag(x_353) == 0) { -lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; lean_object* x_350; lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; -x_340 = lean_ctor_get(x_339, 2); -lean_inc(x_340); -x_341 = lean_ctor_get(x_338, 0); -lean_inc(x_341); -lean_dec(x_338); -x_342 = lean_ctor_get(x_339, 0); -lean_inc(x_342); -x_343 = lean_ctor_get(x_339, 1); -lean_inc(x_343); -x_344 = lean_ctor_get(x_339, 3); -lean_inc(x_344); -x_345 = lean_ctor_get(x_339, 4); -lean_inc(x_345); -x_346 = lean_ctor_get(x_339, 5); -lean_inc(x_346); -if (lean_is_exclusive(x_339)) { - lean_ctor_release(x_339, 0); - lean_ctor_release(x_339, 1); - lean_ctor_release(x_339, 2); - lean_ctor_release(x_339, 3); - lean_ctor_release(x_339, 4); - lean_ctor_release(x_339, 5); - x_347 = x_339; -} else { - lean_dec_ref(x_339); - x_347 = lean_box(0); -} -x_348 = lean_ctor_get(x_340, 0); -lean_inc(x_348); -x_349 = lean_ctor_get(x_340, 1); -lean_inc(x_349); -x_350 = lean_ctor_get(x_340, 3); -lean_inc(x_350); -if (lean_is_exclusive(x_340)) { - lean_ctor_release(x_340, 0); - lean_ctor_release(x_340, 1); - lean_ctor_release(x_340, 2); - lean_ctor_release(x_340, 3); - x_351 = x_340; -} else { - lean_dec_ref(x_340); - x_351 = lean_box(0); -} -if (lean_is_scalar(x_351)) { - x_352 = lean_alloc_ctor(0, 4, 0); -} else { - x_352 = x_351; -} -lean_ctor_set(x_352, 0, x_348); -lean_ctor_set(x_352, 1, x_349); -lean_ctor_set(x_352, 2, x_336); -lean_ctor_set(x_352, 3, x_350); -if (lean_is_scalar(x_347)) { - x_353 = lean_alloc_ctor(0, 6, 0); -} else { - x_353 = x_347; -} -lean_ctor_set(x_353, 0, x_342); -lean_ctor_set(x_353, 1, x_343); -lean_ctor_set(x_353, 2, x_352); -lean_ctor_set(x_353, 3, x_344); -lean_ctor_set(x_353, 4, x_345); -lean_ctor_set(x_353, 5, x_346); -if (lean_is_scalar(x_248)) { - x_354 = lean_alloc_ctor(1, 2, 0); -} else { - x_354 = x_248; - lean_ctor_set_tag(x_354, 1); -} -lean_ctor_set(x_354, 0, x_341); -lean_ctor_set(x_354, 1, x_353); -return x_354; -} -else -{ -lean_object* x_355; lean_object* x_356; lean_object* x_357; 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; -x_355 = lean_ctor_get(x_339, 2); +lean_object* x_355; lean_object* x_356; lean_object* x_357; 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; +x_355 = lean_ctor_get(x_354, 2); lean_inc(x_355); -x_356 = lean_ctor_get(x_338, 0); +x_356 = lean_ctor_get(x_353, 0); lean_inc(x_356); -lean_dec(x_338); -x_357 = lean_ctor_get(x_339, 0); +lean_dec(x_353); +x_357 = lean_ctor_get(x_354, 0); lean_inc(x_357); -x_358 = lean_ctor_get(x_339, 1); +x_358 = lean_ctor_get(x_354, 1); lean_inc(x_358); -x_359 = lean_ctor_get(x_339, 3); +x_359 = lean_ctor_get(x_354, 3); lean_inc(x_359); -x_360 = lean_ctor_get(x_339, 4); +x_360 = lean_ctor_get(x_354, 4); lean_inc(x_360); -x_361 = lean_ctor_get(x_339, 5); +x_361 = lean_ctor_get(x_354, 5); lean_inc(x_361); -if (lean_is_exclusive(x_339)) { - lean_ctor_release(x_339, 0); - lean_ctor_release(x_339, 1); - lean_ctor_release(x_339, 2); - lean_ctor_release(x_339, 3); - lean_ctor_release(x_339, 4); - lean_ctor_release(x_339, 5); - x_362 = x_339; +if (lean_is_exclusive(x_354)) { + lean_ctor_release(x_354, 0); + lean_ctor_release(x_354, 1); + lean_ctor_release(x_354, 2); + lean_ctor_release(x_354, 3); + lean_ctor_release(x_354, 4); + lean_ctor_release(x_354, 5); + x_362 = x_354; } else { - lean_dec_ref(x_339); + lean_dec_ref(x_354); x_362 = lean_box(0); } x_363 = lean_ctor_get(x_355, 0); @@ -31595,315 +31869,411 @@ x_364 = lean_ctor_get(x_355, 1); lean_inc(x_364); x_365 = lean_ctor_get(x_355, 3); lean_inc(x_365); +x_366 = lean_ctor_get(x_355, 4); +lean_inc(x_366); if (lean_is_exclusive(x_355)) { lean_ctor_release(x_355, 0); lean_ctor_release(x_355, 1); lean_ctor_release(x_355, 2); lean_ctor_release(x_355, 3); - x_366 = x_355; + lean_ctor_release(x_355, 4); + x_367 = x_355; } else { lean_dec_ref(x_355); - x_366 = lean_box(0); + x_367 = lean_box(0); } -if (lean_is_scalar(x_366)) { - x_367 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_367)) { + x_368 = lean_alloc_ctor(0, 5, 0); } else { - x_367 = x_366; + x_368 = x_367; } -lean_ctor_set(x_367, 0, x_363); -lean_ctor_set(x_367, 1, x_364); -lean_ctor_set(x_367, 2, x_336); -lean_ctor_set(x_367, 3, x_365); +lean_ctor_set(x_368, 0, x_363); +lean_ctor_set(x_368, 1, x_364); +lean_ctor_set(x_368, 2, x_350); +lean_ctor_set(x_368, 3, x_365); +lean_ctor_set(x_368, 4, x_366); if (lean_is_scalar(x_362)) { - x_368 = lean_alloc_ctor(0, 6, 0); + x_369 = lean_alloc_ctor(0, 6, 0); } else { - x_368 = x_362; + x_369 = x_362; } -lean_ctor_set(x_368, 0, x_357); -lean_ctor_set(x_368, 1, x_358); -lean_ctor_set(x_368, 2, x_367); -lean_ctor_set(x_368, 3, x_359); -lean_ctor_set(x_368, 4, x_360); -lean_ctor_set(x_368, 5, x_361); -if (lean_is_scalar(x_248)) { - x_369 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_369, 0, x_357); +lean_ctor_set(x_369, 1, x_358); +lean_ctor_set(x_369, 2, x_368); +lean_ctor_set(x_369, 3, x_359); +lean_ctor_set(x_369, 4, x_360); +lean_ctor_set(x_369, 5, x_361); +if (lean_is_scalar(x_258)) { + x_370 = lean_alloc_ctor(1, 2, 0); } else { - x_369 = x_248; + x_370 = x_258; + lean_ctor_set_tag(x_370, 1); } -lean_ctor_set(x_369, 0, x_356); -lean_ctor_set(x_369, 1, x_368); -return x_369; +lean_ctor_set(x_370, 0, x_356); +lean_ctor_set(x_370, 1, x_369); +return x_370; +} +else +{ +lean_object* x_371; lean_object* x_372; lean_object* x_373; lean_object* x_374; lean_object* x_375; 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; +x_371 = lean_ctor_get(x_354, 2); +lean_inc(x_371); +x_372 = lean_ctor_get(x_353, 0); +lean_inc(x_372); +lean_dec(x_353); +x_373 = lean_ctor_get(x_354, 0); +lean_inc(x_373); +x_374 = lean_ctor_get(x_354, 1); +lean_inc(x_374); +x_375 = lean_ctor_get(x_354, 3); +lean_inc(x_375); +x_376 = lean_ctor_get(x_354, 4); +lean_inc(x_376); +x_377 = lean_ctor_get(x_354, 5); +lean_inc(x_377); +if (lean_is_exclusive(x_354)) { + lean_ctor_release(x_354, 0); + lean_ctor_release(x_354, 1); + lean_ctor_release(x_354, 2); + lean_ctor_release(x_354, 3); + lean_ctor_release(x_354, 4); + lean_ctor_release(x_354, 5); + x_378 = x_354; +} else { + lean_dec_ref(x_354); + x_378 = lean_box(0); +} +x_379 = lean_ctor_get(x_371, 0); +lean_inc(x_379); +x_380 = lean_ctor_get(x_371, 1); +lean_inc(x_380); +x_381 = lean_ctor_get(x_371, 3); +lean_inc(x_381); +x_382 = lean_ctor_get(x_371, 4); +lean_inc(x_382); +if (lean_is_exclusive(x_371)) { + lean_ctor_release(x_371, 0); + lean_ctor_release(x_371, 1); + lean_ctor_release(x_371, 2); + lean_ctor_release(x_371, 3); + lean_ctor_release(x_371, 4); + x_383 = x_371; +} else { + lean_dec_ref(x_371); + x_383 = lean_box(0); +} +if (lean_is_scalar(x_383)) { + x_384 = lean_alloc_ctor(0, 5, 0); +} else { + x_384 = x_383; +} +lean_ctor_set(x_384, 0, x_379); +lean_ctor_set(x_384, 1, x_380); +lean_ctor_set(x_384, 2, x_350); +lean_ctor_set(x_384, 3, x_381); +lean_ctor_set(x_384, 4, x_382); +if (lean_is_scalar(x_378)) { + x_385 = lean_alloc_ctor(0, 6, 0); +} else { + x_385 = x_378; +} +lean_ctor_set(x_385, 0, x_373); +lean_ctor_set(x_385, 1, x_374); +lean_ctor_set(x_385, 2, x_384); +lean_ctor_set(x_385, 3, x_375); +lean_ctor_set(x_385, 4, x_376); +lean_ctor_set(x_385, 5, x_377); +if (lean_is_scalar(x_258)) { + x_386 = lean_alloc_ctor(0, 2, 0); +} else { + x_386 = x_258; +} +lean_ctor_set(x_386, 0, x_372); +lean_ctor_set(x_386, 1, x_385); +return x_386; } } } } else { -lean_object* x_389; lean_object* x_390; lean_object* x_391; lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; lean_object* x_400; lean_object* x_401; 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; lean_object* x_445; -x_389 = lean_ctor_get(x_247, 2); -x_390 = lean_ctor_get(x_247, 0); -x_391 = lean_ctor_get(x_247, 1); -x_392 = lean_ctor_get(x_247, 3); -x_393 = lean_ctor_get(x_247, 4); -x_394 = lean_ctor_get(x_247, 5); -lean_inc(x_394); -lean_inc(x_393); -lean_inc(x_392); -lean_inc(x_389); -lean_inc(x_391); -lean_inc(x_390); -lean_dec(x_247); -x_395 = lean_ctor_get(x_389, 0); -lean_inc(x_395); -x_396 = lean_ctor_get(x_389, 1); -lean_inc(x_396); -x_397 = lean_ctor_get(x_389, 2); -lean_inc(x_397); -x_398 = lean_ctor_get(x_389, 3); -lean_inc(x_398); -if (lean_is_exclusive(x_389)) { - lean_ctor_release(x_389, 0); - lean_ctor_release(x_389, 1); - lean_ctor_release(x_389, 2); - lean_ctor_release(x_389, 3); - x_399 = x_389; +lean_object* x_406; lean_object* x_407; lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_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_453; lean_object* x_454; lean_object* x_455; lean_object* x_456; lean_object* x_457; lean_object* x_458; lean_object* x_459; lean_object* x_460; lean_object* x_461; lean_object* x_462; lean_object* x_463; lean_object* x_464; lean_object* x_465; +x_406 = lean_ctor_get(x_257, 2); +x_407 = lean_ctor_get(x_257, 0); +x_408 = lean_ctor_get(x_257, 1); +x_409 = lean_ctor_get(x_257, 3); +x_410 = lean_ctor_get(x_257, 4); +x_411 = lean_ctor_get(x_257, 5); +lean_inc(x_411); +lean_inc(x_410); +lean_inc(x_409); +lean_inc(x_406); +lean_inc(x_408); +lean_inc(x_407); +lean_dec(x_257); +x_412 = lean_ctor_get(x_406, 0); +lean_inc(x_412); +x_413 = lean_ctor_get(x_406, 1); +lean_inc(x_413); +x_414 = lean_ctor_get(x_406, 2); +lean_inc(x_414); +x_415 = lean_ctor_get(x_406, 3); +lean_inc(x_415); +x_416 = lean_ctor_get(x_406, 4); +lean_inc(x_416); +if (lean_is_exclusive(x_406)) { + lean_ctor_release(x_406, 0); + lean_ctor_release(x_406, 1); + lean_ctor_release(x_406, 2); + lean_ctor_release(x_406, 3); + lean_ctor_release(x_406, 4); + x_417 = x_406; } else { - lean_dec_ref(x_389); - x_399 = lean_box(0); + lean_dec_ref(x_406); + x_417 = lean_box(0); } -x_433 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_399)) { - x_434 = lean_alloc_ctor(0, 4, 0); +x_453 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_417)) { + x_454 = lean_alloc_ctor(0, 5, 0); } else { - x_434 = x_399; + x_454 = x_417; } -lean_ctor_set(x_434, 0, x_395); -lean_ctor_set(x_434, 1, x_396); -lean_ctor_set(x_434, 2, x_433); -lean_ctor_set(x_434, 3, x_398); -x_435 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_435, 0, x_390); -lean_ctor_set(x_435, 1, x_391); -lean_ctor_set(x_435, 2, x_434); -lean_ctor_set(x_435, 3, x_392); -lean_ctor_set(x_435, 4, x_393); -lean_ctor_set(x_435, 5, x_394); -x_436 = lean_ctor_get(x_8, 0); -lean_inc(x_436); -x_437 = lean_ctor_get(x_8, 1); -lean_inc(x_437); -x_438 = lean_ctor_get(x_8, 2); -lean_inc(x_438); -x_439 = lean_ctor_get(x_8, 3); -lean_inc(x_439); -x_440 = lean_ctor_get(x_8, 4); -lean_inc(x_440); +lean_ctor_set(x_454, 0, x_412); +lean_ctor_set(x_454, 1, x_413); +lean_ctor_set(x_454, 2, x_453); +lean_ctor_set(x_454, 3, x_415); +lean_ctor_set(x_454, 4, x_416); +x_455 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_455, 0, x_407); +lean_ctor_set(x_455, 1, x_408); +lean_ctor_set(x_455, 2, x_454); +lean_ctor_set(x_455, 3, x_409); +lean_ctor_set(x_455, 4, x_410); +lean_ctor_set(x_455, 5, x_411); +x_456 = lean_ctor_get(x_8, 0); +lean_inc(x_456); +x_457 = lean_ctor_get(x_8, 1); +lean_inc(x_457); +x_458 = lean_ctor_get(x_8, 2); +lean_inc(x_458); +x_459 = lean_ctor_get(x_8, 3); +lean_inc(x_459); +x_460 = lean_ctor_get(x_8, 4); +lean_inc(x_460); if (lean_is_exclusive(x_8)) { lean_ctor_release(x_8, 0); lean_ctor_release(x_8, 1); lean_ctor_release(x_8, 2); lean_ctor_release(x_8, 3); lean_ctor_release(x_8, 4); - x_441 = x_8; + x_461 = x_8; } else { lean_dec_ref(x_8); - x_441 = lean_box(0); + x_461 = lean_box(0); } -x_442 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_442, 0, x_249); -lean_ctor_set(x_442, 1, x_24); -x_443 = lean_array_push(x_438, x_442); -if (lean_is_scalar(x_441)) { - x_444 = lean_alloc_ctor(0, 5, 0); +x_462 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_462, 0, x_259); +lean_ctor_set(x_462, 1, x_24); +x_463 = lean_array_push(x_458, x_462); +if (lean_is_scalar(x_461)) { + x_464 = lean_alloc_ctor(0, 5, 0); } else { - x_444 = x_441; + x_464 = x_461; } -lean_ctor_set(x_444, 0, x_436); -lean_ctor_set(x_444, 1, x_437); -lean_ctor_set(x_444, 2, x_443); -lean_ctor_set(x_444, 3, x_439); -lean_ctor_set(x_444, 4, x_440); -x_445 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_ExprDefEq_18__processConstApprox___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_251, x_444, x_435); -if (lean_obj_tag(x_445) == 0) +lean_ctor_set(x_464, 0, x_456); +lean_ctor_set(x_464, 1, x_457); +lean_ctor_set(x_464, 2, x_463); +lean_ctor_set(x_464, 3, x_459); +lean_ctor_set(x_464, 4, x_460); +x_465 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_ExprDefEq_18__processConstApprox___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_261, x_464, x_455); +if (lean_obj_tag(x_465) == 0) { -lean_object* x_446; lean_object* x_447; lean_object* x_448; -x_446 = lean_ctor_get(x_445, 0); -lean_inc(x_446); -x_447 = lean_ctor_get(x_445, 1); -lean_inc(x_447); -lean_dec(x_445); -x_448 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_448, 0, x_446); -x_400 = x_448; -x_401 = x_447; -goto block_432; +lean_object* x_466; lean_object* x_467; lean_object* x_468; +x_466 = lean_ctor_get(x_465, 0); +lean_inc(x_466); +x_467 = lean_ctor_get(x_465, 1); +lean_inc(x_467); +lean_dec(x_465); +x_468 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_468, 0, x_466); +x_418 = x_468; +x_419 = x_467; +goto block_452; } else { -lean_object* x_449; lean_object* x_450; lean_object* x_451; -x_449 = lean_ctor_get(x_445, 0); -lean_inc(x_449); -x_450 = lean_ctor_get(x_445, 1); -lean_inc(x_450); -lean_dec(x_445); -x_451 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_451, 0, x_449); -x_400 = x_451; -x_401 = x_450; -goto block_432; +lean_object* x_469; lean_object* x_470; lean_object* x_471; +x_469 = lean_ctor_get(x_465, 0); +lean_inc(x_469); +x_470 = lean_ctor_get(x_465, 1); +lean_inc(x_470); +lean_dec(x_465); +x_471 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_471, 0, x_469); +x_418 = x_471; +x_419 = x_470; +goto block_452; } -block_432: +block_452: { -if (lean_obj_tag(x_400) == 0) +if (lean_obj_tag(x_418) == 0) { -lean_object* x_402; lean_object* x_403; lean_object* x_404; lean_object* x_405; lean_object* x_406; lean_object* x_407; lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_object* x_412; lean_object* x_413; lean_object* x_414; lean_object* x_415; lean_object* x_416; -x_402 = lean_ctor_get(x_401, 2); -lean_inc(x_402); -x_403 = lean_ctor_get(x_400, 0); -lean_inc(x_403); -lean_dec(x_400); -x_404 = lean_ctor_get(x_401, 0); -lean_inc(x_404); -x_405 = lean_ctor_get(x_401, 1); -lean_inc(x_405); -x_406 = lean_ctor_get(x_401, 3); -lean_inc(x_406); -x_407 = lean_ctor_get(x_401, 4); -lean_inc(x_407); -x_408 = lean_ctor_get(x_401, 5); -lean_inc(x_408); -if (lean_is_exclusive(x_401)) { - lean_ctor_release(x_401, 0); - lean_ctor_release(x_401, 1); - lean_ctor_release(x_401, 2); - lean_ctor_release(x_401, 3); - lean_ctor_release(x_401, 4); - lean_ctor_release(x_401, 5); - x_409 = x_401; -} else { - lean_dec_ref(x_401); - x_409 = lean_box(0); -} -x_410 = lean_ctor_get(x_402, 0); -lean_inc(x_410); -x_411 = lean_ctor_get(x_402, 1); -lean_inc(x_411); -x_412 = lean_ctor_get(x_402, 3); -lean_inc(x_412); -if (lean_is_exclusive(x_402)) { - lean_ctor_release(x_402, 0); - lean_ctor_release(x_402, 1); - lean_ctor_release(x_402, 2); - lean_ctor_release(x_402, 3); - x_413 = x_402; -} else { - lean_dec_ref(x_402); - x_413 = lean_box(0); -} -if (lean_is_scalar(x_413)) { - x_414 = lean_alloc_ctor(0, 4, 0); -} else { - x_414 = x_413; -} -lean_ctor_set(x_414, 0, x_410); -lean_ctor_set(x_414, 1, x_411); -lean_ctor_set(x_414, 2, x_397); -lean_ctor_set(x_414, 3, x_412); -if (lean_is_scalar(x_409)) { - x_415 = lean_alloc_ctor(0, 6, 0); -} else { - x_415 = x_409; -} -lean_ctor_set(x_415, 0, x_404); -lean_ctor_set(x_415, 1, x_405); -lean_ctor_set(x_415, 2, x_414); -lean_ctor_set(x_415, 3, x_406); -lean_ctor_set(x_415, 4, x_407); -lean_ctor_set(x_415, 5, x_408); -if (lean_is_scalar(x_248)) { - x_416 = lean_alloc_ctor(1, 2, 0); -} else { - x_416 = x_248; - lean_ctor_set_tag(x_416, 1); -} -lean_ctor_set(x_416, 0, x_403); -lean_ctor_set(x_416, 1, x_415); -return x_416; -} -else -{ -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; lean_object* x_426; lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; -x_417 = lean_ctor_get(x_401, 2); -lean_inc(x_417); -x_418 = lean_ctor_get(x_400, 0); -lean_inc(x_418); -lean_dec(x_400); -x_419 = lean_ctor_get(x_401, 0); -lean_inc(x_419); -x_420 = lean_ctor_get(x_401, 1); +lean_object* x_420; lean_object* x_421; lean_object* x_422; lean_object* x_423; lean_object* x_424; lean_object* x_425; lean_object* x_426; lean_object* x_427; 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; +x_420 = lean_ctor_get(x_419, 2); lean_inc(x_420); -x_421 = lean_ctor_get(x_401, 3); +x_421 = lean_ctor_get(x_418, 0); lean_inc(x_421); -x_422 = lean_ctor_get(x_401, 4); +lean_dec(x_418); +x_422 = lean_ctor_get(x_419, 0); lean_inc(x_422); -x_423 = lean_ctor_get(x_401, 5); +x_423 = lean_ctor_get(x_419, 1); lean_inc(x_423); -if (lean_is_exclusive(x_401)) { - lean_ctor_release(x_401, 0); - lean_ctor_release(x_401, 1); - lean_ctor_release(x_401, 2); - lean_ctor_release(x_401, 3); - lean_ctor_release(x_401, 4); - lean_ctor_release(x_401, 5); - x_424 = x_401; -} else { - lean_dec_ref(x_401); - x_424 = lean_box(0); -} -x_425 = lean_ctor_get(x_417, 0); +x_424 = lean_ctor_get(x_419, 3); +lean_inc(x_424); +x_425 = lean_ctor_get(x_419, 4); lean_inc(x_425); -x_426 = lean_ctor_get(x_417, 1); +x_426 = lean_ctor_get(x_419, 5); lean_inc(x_426); -x_427 = lean_ctor_get(x_417, 3); -lean_inc(x_427); -if (lean_is_exclusive(x_417)) { - lean_ctor_release(x_417, 0); - lean_ctor_release(x_417, 1); - lean_ctor_release(x_417, 2); - lean_ctor_release(x_417, 3); - x_428 = x_417; +if (lean_is_exclusive(x_419)) { + lean_ctor_release(x_419, 0); + lean_ctor_release(x_419, 1); + lean_ctor_release(x_419, 2); + lean_ctor_release(x_419, 3); + lean_ctor_release(x_419, 4); + lean_ctor_release(x_419, 5); + x_427 = x_419; } else { - lean_dec_ref(x_417); - x_428 = lean_box(0); + lean_dec_ref(x_419); + x_427 = lean_box(0); } -if (lean_is_scalar(x_428)) { - x_429 = lean_alloc_ctor(0, 4, 0); +x_428 = lean_ctor_get(x_420, 0); +lean_inc(x_428); +x_429 = lean_ctor_get(x_420, 1); +lean_inc(x_429); +x_430 = lean_ctor_get(x_420, 3); +lean_inc(x_430); +x_431 = lean_ctor_get(x_420, 4); +lean_inc(x_431); +if (lean_is_exclusive(x_420)) { + lean_ctor_release(x_420, 0); + lean_ctor_release(x_420, 1); + lean_ctor_release(x_420, 2); + lean_ctor_release(x_420, 3); + lean_ctor_release(x_420, 4); + x_432 = x_420; } else { - x_429 = x_428; + lean_dec_ref(x_420); + x_432 = lean_box(0); } -lean_ctor_set(x_429, 0, x_425); -lean_ctor_set(x_429, 1, x_426); -lean_ctor_set(x_429, 2, x_397); -lean_ctor_set(x_429, 3, x_427); -if (lean_is_scalar(x_424)) { - x_430 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_432)) { + x_433 = lean_alloc_ctor(0, 5, 0); } else { - x_430 = x_424; + x_433 = x_432; } -lean_ctor_set(x_430, 0, x_419); -lean_ctor_set(x_430, 1, x_420); -lean_ctor_set(x_430, 2, x_429); -lean_ctor_set(x_430, 3, x_421); -lean_ctor_set(x_430, 4, x_422); -lean_ctor_set(x_430, 5, x_423); -if (lean_is_scalar(x_248)) { - x_431 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_433, 0, x_428); +lean_ctor_set(x_433, 1, x_429); +lean_ctor_set(x_433, 2, x_414); +lean_ctor_set(x_433, 3, x_430); +lean_ctor_set(x_433, 4, x_431); +if (lean_is_scalar(x_427)) { + x_434 = lean_alloc_ctor(0, 6, 0); } else { - x_431 = x_248; + x_434 = x_427; } -lean_ctor_set(x_431, 0, x_418); -lean_ctor_set(x_431, 1, x_430); -return x_431; +lean_ctor_set(x_434, 0, x_422); +lean_ctor_set(x_434, 1, x_423); +lean_ctor_set(x_434, 2, x_433); +lean_ctor_set(x_434, 3, x_424); +lean_ctor_set(x_434, 4, x_425); +lean_ctor_set(x_434, 5, x_426); +if (lean_is_scalar(x_258)) { + x_435 = lean_alloc_ctor(1, 2, 0); +} else { + x_435 = x_258; + lean_ctor_set_tag(x_435, 1); +} +lean_ctor_set(x_435, 0, x_421); +lean_ctor_set(x_435, 1, x_434); +return x_435; +} +else +{ +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; lean_object* x_445; lean_object* x_446; lean_object* x_447; lean_object* x_448; lean_object* x_449; lean_object* x_450; lean_object* x_451; +x_436 = lean_ctor_get(x_419, 2); +lean_inc(x_436); +x_437 = lean_ctor_get(x_418, 0); +lean_inc(x_437); +lean_dec(x_418); +x_438 = lean_ctor_get(x_419, 0); +lean_inc(x_438); +x_439 = lean_ctor_get(x_419, 1); +lean_inc(x_439); +x_440 = lean_ctor_get(x_419, 3); +lean_inc(x_440); +x_441 = lean_ctor_get(x_419, 4); +lean_inc(x_441); +x_442 = lean_ctor_get(x_419, 5); +lean_inc(x_442); +if (lean_is_exclusive(x_419)) { + lean_ctor_release(x_419, 0); + lean_ctor_release(x_419, 1); + lean_ctor_release(x_419, 2); + lean_ctor_release(x_419, 3); + lean_ctor_release(x_419, 4); + lean_ctor_release(x_419, 5); + x_443 = x_419; +} else { + lean_dec_ref(x_419); + x_443 = lean_box(0); +} +x_444 = lean_ctor_get(x_436, 0); +lean_inc(x_444); +x_445 = lean_ctor_get(x_436, 1); +lean_inc(x_445); +x_446 = lean_ctor_get(x_436, 3); +lean_inc(x_446); +x_447 = lean_ctor_get(x_436, 4); +lean_inc(x_447); +if (lean_is_exclusive(x_436)) { + lean_ctor_release(x_436, 0); + lean_ctor_release(x_436, 1); + lean_ctor_release(x_436, 2); + lean_ctor_release(x_436, 3); + lean_ctor_release(x_436, 4); + x_448 = x_436; +} else { + lean_dec_ref(x_436); + x_448 = lean_box(0); +} +if (lean_is_scalar(x_448)) { + x_449 = lean_alloc_ctor(0, 5, 0); +} else { + x_449 = x_448; +} +lean_ctor_set(x_449, 0, x_444); +lean_ctor_set(x_449, 1, x_445); +lean_ctor_set(x_449, 2, x_414); +lean_ctor_set(x_449, 3, x_446); +lean_ctor_set(x_449, 4, x_447); +if (lean_is_scalar(x_443)) { + x_450 = lean_alloc_ctor(0, 6, 0); +} else { + x_450 = x_443; +} +lean_ctor_set(x_450, 0, x_438); +lean_ctor_set(x_450, 1, x_439); +lean_ctor_set(x_450, 2, x_449); +lean_ctor_set(x_450, 3, x_440); +lean_ctor_set(x_450, 4, x_441); +lean_ctor_set(x_450, 5, x_442); +if (lean_is_scalar(x_258)) { + x_451 = lean_alloc_ctor(0, 2, 0); +} else { + x_451 = x_258; +} +lean_ctor_set(x_451, 0, x_437); +lean_ctor_set(x_451, 1, x_450); +return x_451; } } } @@ -31911,30 +32281,30 @@ return x_431; } else { -uint8_t x_452; +uint8_t x_472; lean_dec(x_24); lean_dec(x_8); lean_dec(x_7); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_452 = !lean_is_exclusive(x_241); -if (x_452 == 0) +x_472 = !lean_is_exclusive(x_251); +if (x_472 == 0) { -return x_241; +return x_251; } else { -lean_object* x_453; lean_object* x_454; lean_object* x_455; -x_453 = lean_ctor_get(x_241, 0); -x_454 = lean_ctor_get(x_241, 1); -lean_inc(x_454); -lean_inc(x_453); -lean_dec(x_241); -x_455 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_455, 0, x_453); -lean_ctor_set(x_455, 1, x_454); -return x_455; +lean_object* x_473; lean_object* x_474; lean_object* x_475; +x_473 = lean_ctor_get(x_251, 0); +x_474 = lean_ctor_get(x_251, 1); +lean_inc(x_474); +lean_inc(x_473); +lean_dec(x_251); +x_475 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_475, 0, x_473); +lean_ctor_set(x_475, 1, x_474); +return x_475; } } } @@ -31942,7 +32312,7 @@ return x_455; } else { -uint8_t x_456; +uint8_t x_476; lean_dec(x_28); lean_dec(x_24); lean_dec(x_8); @@ -31950,52 +32320,52 @@ lean_dec(x_7); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_456 = !lean_is_exclusive(x_29); -if (x_456 == 0) +x_476 = !lean_is_exclusive(x_29); +if (x_476 == 0) { return x_29; } else { -lean_object* x_457; lean_object* x_458; lean_object* x_459; -x_457 = lean_ctor_get(x_29, 0); -x_458 = lean_ctor_get(x_29, 1); -lean_inc(x_458); -lean_inc(x_457); +lean_object* x_477; lean_object* x_478; lean_object* x_479; +x_477 = lean_ctor_get(x_29, 0); +x_478 = lean_ctor_get(x_29, 1); +lean_inc(x_478); +lean_inc(x_477); lean_dec(x_29); -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_479 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_479, 0, x_477); +lean_ctor_set(x_479, 1, x_478); +return x_479; } } } else { -uint8_t x_460; +uint8_t x_480; lean_dec(x_24); lean_dec(x_8); lean_dec(x_7); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_460 = !lean_is_exclusive(x_25); -if (x_460 == 0) +x_480 = !lean_is_exclusive(x_25); +if (x_480 == 0) { return x_25; } else { -lean_object* x_461; lean_object* x_462; lean_object* x_463; -x_461 = lean_ctor_get(x_25, 0); -x_462 = lean_ctor_get(x_25, 1); -lean_inc(x_462); -lean_inc(x_461); +lean_object* x_481; lean_object* x_482; lean_object* x_483; +x_481 = lean_ctor_get(x_25, 0); +x_482 = lean_ctor_get(x_25, 1); +lean_inc(x_482); +lean_inc(x_481); lean_dec(x_25); -x_463 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_463, 0, x_461); -lean_ctor_set(x_463, 1, x_462); -return x_463; +x_483 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_483, 0, x_481); +lean_ctor_set(x_483, 1, x_482); +return x_483; } } } @@ -32190,105 +32560,105 @@ x_39 = lean_ctor_get(x_33, 2); x_40 = !lean_is_exclusive(x_39); if (x_40 == 0) { -lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_93; uint8_t x_94; +lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_97; uint8_t x_98; x_41 = lean_ctor_get(x_39, 2); -x_93 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_39, 2, x_93); -x_94 = !lean_is_exclusive(x_13); -if (x_94 == 0) +x_97 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_39, 2, x_97); +x_98 = !lean_is_exclusive(x_13); +if (x_98 == 0) { -lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; -x_95 = lean_ctor_get(x_13, 2); -x_96 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_96, 0, x_35); -lean_ctor_set(x_96, 1, x_22); -x_97 = lean_array_push(x_95, x_96); -lean_ctor_set(x_13, 2, x_97); -x_98 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_ExprDefEq_18__processConstApprox___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_37, x_13, x_33); -if (lean_obj_tag(x_98) == 0) +lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; +x_99 = lean_ctor_get(x_13, 2); +x_100 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_100, 0, x_35); +lean_ctor_set(x_100, 1, x_22); +x_101 = lean_array_push(x_99, x_100); +lean_ctor_set(x_13, 2, x_101); +x_102 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_ExprDefEq_18__processConstApprox___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_37, x_13, x_33); +if (lean_obj_tag(x_102) == 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); -x_101 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_101, 0, x_99); -x_42 = x_101; -x_43 = x_100; -goto block_92; -} -else -{ -lean_object* x_102; lean_object* x_103; lean_object* x_104; -x_102 = lean_ctor_get(x_98, 0); -lean_inc(x_102); -x_103 = lean_ctor_get(x_98, 1); +lean_object* x_103; lean_object* x_104; lean_object* x_105; +x_103 = lean_ctor_get(x_102, 0); lean_inc(x_103); -lean_dec(x_98); -x_104 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_104, 0, x_102); -x_42 = x_104; -x_43 = x_103; -goto block_92; -} +x_104 = lean_ctor_get(x_102, 1); +lean_inc(x_104); +lean_dec(x_102); +x_105 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_105, 0, x_103); +x_42 = x_105; +x_43 = x_104; +goto block_96; } else { -lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; -x_105 = lean_ctor_get(x_13, 0); -x_106 = lean_ctor_get(x_13, 1); -x_107 = lean_ctor_get(x_13, 2); -x_108 = lean_ctor_get(x_13, 3); -x_109 = lean_ctor_get(x_13, 4); -lean_inc(x_109); -lean_inc(x_108); -lean_inc(x_107); +lean_object* x_106; lean_object* x_107; lean_object* x_108; +x_106 = lean_ctor_get(x_102, 0); lean_inc(x_106); -lean_inc(x_105); -lean_dec(x_13); -x_110 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_110, 0, x_35); -lean_ctor_set(x_110, 1, x_22); -x_111 = lean_array_push(x_107, x_110); -x_112 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_112, 0, x_105); -lean_ctor_set(x_112, 1, x_106); -lean_ctor_set(x_112, 2, x_111); -lean_ctor_set(x_112, 3, x_108); -lean_ctor_set(x_112, 4, x_109); -x_113 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_ExprDefEq_18__processConstApprox___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_37, x_112, x_33); -if (lean_obj_tag(x_113) == 0) -{ -lean_object* x_114; lean_object* x_115; lean_object* x_116; -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_114); -x_42 = x_116; -x_43 = x_115; -goto block_92; +x_107 = lean_ctor_get(x_102, 1); +lean_inc(x_107); +lean_dec(x_102); +x_108 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_108, 0, x_106); +x_42 = x_108; +x_43 = x_107; +goto block_96; +} } else { -lean_object* x_117; lean_object* x_118; lean_object* x_119; -x_117 = lean_ctor_get(x_113, 0); -lean_inc(x_117); -x_118 = lean_ctor_get(x_113, 1); +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; +x_109 = lean_ctor_get(x_13, 0); +x_110 = lean_ctor_get(x_13, 1); +x_111 = lean_ctor_get(x_13, 2); +x_112 = lean_ctor_get(x_13, 3); +x_113 = lean_ctor_get(x_13, 4); +lean_inc(x_113); +lean_inc(x_112); +lean_inc(x_111); +lean_inc(x_110); +lean_inc(x_109); +lean_dec(x_13); +x_114 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_114, 0, x_35); +lean_ctor_set(x_114, 1, x_22); +x_115 = lean_array_push(x_111, x_114); +x_116 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_116, 0, x_109); +lean_ctor_set(x_116, 1, x_110); +lean_ctor_set(x_116, 2, x_115); +lean_ctor_set(x_116, 3, x_112); +lean_ctor_set(x_116, 4, x_113); +x_117 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_ExprDefEq_18__processConstApprox___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_37, x_116, x_33); +if (lean_obj_tag(x_117) == 0) +{ +lean_object* x_118; lean_object* x_119; lean_object* x_120; +x_118 = lean_ctor_get(x_117, 0); lean_inc(x_118); -lean_dec(x_113); -x_119 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_119, 0, x_117); -x_42 = x_119; -x_43 = x_118; -goto block_92; +x_119 = lean_ctor_get(x_117, 1); +lean_inc(x_119); +lean_dec(x_117); +x_120 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_120, 0, x_118); +x_42 = x_120; +x_43 = x_119; +goto block_96; +} +else +{ +lean_object* x_121; lean_object* x_122; lean_object* x_123; +x_121 = lean_ctor_get(x_117, 0); +lean_inc(x_121); +x_122 = lean_ctor_get(x_117, 1); +lean_inc(x_122); +lean_dec(x_117); +x_123 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_123, 0, x_121); +x_42 = x_123; +x_43 = x_122; +goto block_96; } } -block_92: +block_96: { if (lean_obj_tag(x_42) == 0) { @@ -32323,1284 +32693,1262 @@ return x_50; } else { -lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; +lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; x_51 = lean_ctor_get(x_44, 0); x_52 = lean_ctor_get(x_44, 1); x_53 = lean_ctor_get(x_44, 3); +x_54 = lean_ctor_get(x_44, 4); +lean_inc(x_54); lean_inc(x_53); lean_inc(x_52); lean_inc(x_51); lean_dec(x_44); -x_54 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_54, 0, x_51); -lean_ctor_set(x_54, 1, x_52); -lean_ctor_set(x_54, 2, x_41); -lean_ctor_set(x_54, 3, x_53); -lean_ctor_set(x_43, 2, x_54); +x_55 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_55, 0, x_51); +lean_ctor_set(x_55, 1, x_52); +lean_ctor_set(x_55, 2, x_41); +lean_ctor_set(x_55, 3, x_53); +lean_ctor_set(x_55, 4, x_54); +lean_ctor_set(x_43, 2, x_55); if (lean_is_scalar(x_34)) { - x_55 = lean_alloc_ctor(1, 2, 0); + x_56 = lean_alloc_ctor(1, 2, 0); } else { - x_55 = x_34; - lean_ctor_set_tag(x_55, 1); + x_56 = x_34; + lean_ctor_set_tag(x_56, 1); } -lean_ctor_set(x_55, 0, x_45); -lean_ctor_set(x_55, 1, x_43); -return x_55; +lean_ctor_set(x_56, 0, x_45); +lean_ctor_set(x_56, 1, x_43); +return x_56; } } else { -lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; -x_56 = lean_ctor_get(x_43, 0); -x_57 = lean_ctor_get(x_43, 1); -x_58 = lean_ctor_get(x_43, 3); -x_59 = lean_ctor_get(x_43, 4); -x_60 = lean_ctor_get(x_43, 5); +lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; +x_57 = lean_ctor_get(x_43, 0); +x_58 = lean_ctor_get(x_43, 1); +x_59 = lean_ctor_get(x_43, 3); +x_60 = lean_ctor_get(x_43, 4); +x_61 = lean_ctor_get(x_43, 5); +lean_inc(x_61); lean_inc(x_60); lean_inc(x_59); lean_inc(x_58); lean_inc(x_57); -lean_inc(x_56); lean_dec(x_43); -x_61 = lean_ctor_get(x_44, 0); -lean_inc(x_61); -x_62 = lean_ctor_get(x_44, 1); +x_62 = lean_ctor_get(x_44, 0); lean_inc(x_62); -x_63 = lean_ctor_get(x_44, 3); +x_63 = lean_ctor_get(x_44, 1); lean_inc(x_63); +x_64 = lean_ctor_get(x_44, 3); +lean_inc(x_64); +x_65 = lean_ctor_get(x_44, 4); +lean_inc(x_65); if (lean_is_exclusive(x_44)) { lean_ctor_release(x_44, 0); lean_ctor_release(x_44, 1); lean_ctor_release(x_44, 2); lean_ctor_release(x_44, 3); - x_64 = x_44; + lean_ctor_release(x_44, 4); + x_66 = x_44; } else { lean_dec_ref(x_44); - x_64 = lean_box(0); + x_66 = lean_box(0); } -if (lean_is_scalar(x_64)) { - x_65 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_66)) { + x_67 = lean_alloc_ctor(0, 5, 0); } else { - x_65 = x_64; + x_67 = x_66; } -lean_ctor_set(x_65, 0, x_61); -lean_ctor_set(x_65, 1, x_62); -lean_ctor_set(x_65, 2, x_41); -lean_ctor_set(x_65, 3, x_63); -x_66 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_66, 0, x_56); -lean_ctor_set(x_66, 1, x_57); -lean_ctor_set(x_66, 2, x_65); -lean_ctor_set(x_66, 3, x_58); -lean_ctor_set(x_66, 4, x_59); -lean_ctor_set(x_66, 5, x_60); +lean_ctor_set(x_67, 0, x_62); +lean_ctor_set(x_67, 1, x_63); +lean_ctor_set(x_67, 2, x_41); +lean_ctor_set(x_67, 3, x_64); +lean_ctor_set(x_67, 4, x_65); +x_68 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_68, 0, x_57); +lean_ctor_set(x_68, 1, x_58); +lean_ctor_set(x_68, 2, x_67); +lean_ctor_set(x_68, 3, x_59); +lean_ctor_set(x_68, 4, x_60); +lean_ctor_set(x_68, 5, x_61); if (lean_is_scalar(x_34)) { - x_67 = lean_alloc_ctor(1, 2, 0); + x_69 = lean_alloc_ctor(1, 2, 0); } else { - x_67 = x_34; - lean_ctor_set_tag(x_67, 1); + x_69 = x_34; + lean_ctor_set_tag(x_69, 1); } -lean_ctor_set(x_67, 0, x_45); -lean_ctor_set(x_67, 1, x_66); -return x_67; +lean_ctor_set(x_69, 0, x_45); +lean_ctor_set(x_69, 1, x_68); +return x_69; } } else { -lean_object* x_68; lean_object* x_69; uint8_t x_70; -x_68 = lean_ctor_get(x_43, 2); -lean_inc(x_68); -x_69 = lean_ctor_get(x_42, 0); -lean_inc(x_69); +lean_object* x_70; lean_object* x_71; uint8_t x_72; +x_70 = lean_ctor_get(x_43, 2); +lean_inc(x_70); +x_71 = lean_ctor_get(x_42, 0); +lean_inc(x_71); lean_dec(x_42); -x_70 = !lean_is_exclusive(x_43); -if (x_70 == 0) -{ -lean_object* x_71; uint8_t x_72; -x_71 = lean_ctor_get(x_43, 2); -lean_dec(x_71); -x_72 = !lean_is_exclusive(x_68); +x_72 = !lean_is_exclusive(x_43); if (x_72 == 0) { -lean_object* x_73; lean_object* x_74; -x_73 = lean_ctor_get(x_68, 2); +lean_object* x_73; uint8_t x_74; +x_73 = lean_ctor_get(x_43, 2); lean_dec(x_73); -lean_ctor_set(x_68, 2, x_41); +x_74 = !lean_is_exclusive(x_70); +if (x_74 == 0) +{ +lean_object* x_75; lean_object* x_76; +x_75 = lean_ctor_get(x_70, 2); +lean_dec(x_75); +lean_ctor_set(x_70, 2, x_41); if (lean_is_scalar(x_34)) { - x_74 = lean_alloc_ctor(0, 2, 0); + x_76 = lean_alloc_ctor(0, 2, 0); } else { - x_74 = x_34; + x_76 = x_34; } -lean_ctor_set(x_74, 0, x_69); -lean_ctor_set(x_74, 1, x_43); -return x_74; +lean_ctor_set(x_76, 0, x_71); +lean_ctor_set(x_76, 1, x_43); +return x_76; } else { -lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; -x_75 = lean_ctor_get(x_68, 0); -x_76 = lean_ctor_get(x_68, 1); -x_77 = lean_ctor_get(x_68, 3); +lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; +x_77 = lean_ctor_get(x_70, 0); +x_78 = lean_ctor_get(x_70, 1); +x_79 = lean_ctor_get(x_70, 3); +x_80 = lean_ctor_get(x_70, 4); +lean_inc(x_80); +lean_inc(x_79); +lean_inc(x_78); lean_inc(x_77); -lean_inc(x_76); -lean_inc(x_75); -lean_dec(x_68); -x_78 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_78, 0, x_75); -lean_ctor_set(x_78, 1, x_76); -lean_ctor_set(x_78, 2, x_41); -lean_ctor_set(x_78, 3, x_77); -lean_ctor_set(x_43, 2, x_78); +lean_dec(x_70); +x_81 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_81, 0, x_77); +lean_ctor_set(x_81, 1, x_78); +lean_ctor_set(x_81, 2, x_41); +lean_ctor_set(x_81, 3, x_79); +lean_ctor_set(x_81, 4, x_80); +lean_ctor_set(x_43, 2, x_81); if (lean_is_scalar(x_34)) { - x_79 = lean_alloc_ctor(0, 2, 0); + x_82 = lean_alloc_ctor(0, 2, 0); } else { - x_79 = x_34; + x_82 = x_34; } -lean_ctor_set(x_79, 0, x_69); -lean_ctor_set(x_79, 1, x_43); -return x_79; +lean_ctor_set(x_82, 0, x_71); +lean_ctor_set(x_82, 1, x_43); +return x_82; } } else { -lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; -x_80 = lean_ctor_get(x_43, 0); -x_81 = lean_ctor_get(x_43, 1); -x_82 = lean_ctor_get(x_43, 3); -x_83 = lean_ctor_get(x_43, 4); -x_84 = lean_ctor_get(x_43, 5); +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; +x_83 = lean_ctor_get(x_43, 0); +x_84 = lean_ctor_get(x_43, 1); +x_85 = lean_ctor_get(x_43, 3); +x_86 = lean_ctor_get(x_43, 4); +x_87 = lean_ctor_get(x_43, 5); +lean_inc(x_87); +lean_inc(x_86); +lean_inc(x_85); lean_inc(x_84); lean_inc(x_83); -lean_inc(x_82); -lean_inc(x_81); -lean_inc(x_80); lean_dec(x_43); -x_85 = lean_ctor_get(x_68, 0); -lean_inc(x_85); -x_86 = lean_ctor_get(x_68, 1); -lean_inc(x_86); -x_87 = lean_ctor_get(x_68, 3); -lean_inc(x_87); -if (lean_is_exclusive(x_68)) { - lean_ctor_release(x_68, 0); - lean_ctor_release(x_68, 1); - lean_ctor_release(x_68, 2); - lean_ctor_release(x_68, 3); - x_88 = x_68; +x_88 = lean_ctor_get(x_70, 0); +lean_inc(x_88); +x_89 = lean_ctor_get(x_70, 1); +lean_inc(x_89); +x_90 = lean_ctor_get(x_70, 3); +lean_inc(x_90); +x_91 = lean_ctor_get(x_70, 4); +lean_inc(x_91); +if (lean_is_exclusive(x_70)) { + lean_ctor_release(x_70, 0); + lean_ctor_release(x_70, 1); + lean_ctor_release(x_70, 2); + lean_ctor_release(x_70, 3); + lean_ctor_release(x_70, 4); + x_92 = x_70; } else { - lean_dec_ref(x_68); - x_88 = lean_box(0); + lean_dec_ref(x_70); + x_92 = lean_box(0); } -if (lean_is_scalar(x_88)) { - x_89 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_92)) { + x_93 = lean_alloc_ctor(0, 5, 0); } else { - x_89 = x_88; + x_93 = x_92; } -lean_ctor_set(x_89, 0, x_85); -lean_ctor_set(x_89, 1, x_86); -lean_ctor_set(x_89, 2, x_41); -lean_ctor_set(x_89, 3, x_87); -x_90 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_90, 0, x_80); -lean_ctor_set(x_90, 1, x_81); -lean_ctor_set(x_90, 2, x_89); -lean_ctor_set(x_90, 3, x_82); -lean_ctor_set(x_90, 4, x_83); -lean_ctor_set(x_90, 5, x_84); +lean_ctor_set(x_93, 0, x_88); +lean_ctor_set(x_93, 1, x_89); +lean_ctor_set(x_93, 2, x_41); +lean_ctor_set(x_93, 3, x_90); +lean_ctor_set(x_93, 4, x_91); +x_94 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_94, 0, x_83); +lean_ctor_set(x_94, 1, x_84); +lean_ctor_set(x_94, 2, x_93); +lean_ctor_set(x_94, 3, x_85); +lean_ctor_set(x_94, 4, x_86); +lean_ctor_set(x_94, 5, x_87); if (lean_is_scalar(x_34)) { - x_91 = lean_alloc_ctor(0, 2, 0); + x_95 = lean_alloc_ctor(0, 2, 0); } else { - x_91 = x_34; + x_95 = x_34; } -lean_ctor_set(x_91, 0, x_69); -lean_ctor_set(x_91, 1, x_90); -return x_91; +lean_ctor_set(x_95, 0, x_71); +lean_ctor_set(x_95, 1, x_94); +return x_95; } } } } else { -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_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_120 = lean_ctor_get(x_39, 0); -x_121 = lean_ctor_get(x_39, 1); -x_122 = lean_ctor_get(x_39, 2); -x_123 = lean_ctor_get(x_39, 3); -lean_inc(x_123); -lean_inc(x_122); -lean_inc(x_121); -lean_inc(x_120); -lean_dec(x_39); -x_157 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_158 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_158, 0, x_120); -lean_ctor_set(x_158, 1, x_121); -lean_ctor_set(x_158, 2, x_157); -lean_ctor_set(x_158, 3, x_123); -lean_ctor_set(x_33, 2, x_158); -x_159 = lean_ctor_get(x_13, 0); -lean_inc(x_159); -x_160 = lean_ctor_get(x_13, 1); -lean_inc(x_160); -x_161 = lean_ctor_get(x_13, 2); -lean_inc(x_161); -x_162 = lean_ctor_get(x_13, 3); -lean_inc(x_162); -x_163 = lean_ctor_get(x_13, 4); -lean_inc(x_163); -if (lean_is_exclusive(x_13)) { - lean_ctor_release(x_13, 0); - lean_ctor_release(x_13, 1); - lean_ctor_release(x_13, 2); - lean_ctor_release(x_13, 3); - lean_ctor_release(x_13, 4); - x_164 = x_13; -} else { - lean_dec_ref(x_13); - x_164 = lean_box(0); -} -x_165 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_165, 0, x_35); -lean_ctor_set(x_165, 1, x_22); -x_166 = lean_array_push(x_161, x_165); -if (lean_is_scalar(x_164)) { - x_167 = lean_alloc_ctor(0, 5, 0); -} else { - x_167 = x_164; -} -lean_ctor_set(x_167, 0, x_159); -lean_ctor_set(x_167, 1, x_160); -lean_ctor_set(x_167, 2, x_166); -lean_ctor_set(x_167, 3, x_162); -lean_ctor_set(x_167, 4, x_163); -x_168 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_ExprDefEq_18__processConstApprox___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_37, x_167, x_33); -if (lean_obj_tag(x_168) == 0) -{ -lean_object* x_169; lean_object* x_170; lean_object* x_171; -x_169 = lean_ctor_get(x_168, 0); -lean_inc(x_169); -x_170 = lean_ctor_get(x_168, 1); -lean_inc(x_170); -lean_dec(x_168); -x_171 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_171, 0, x_169); -x_124 = x_171; -x_125 = x_170; -goto block_156; -} -else -{ -lean_object* x_172; lean_object* x_173; lean_object* x_174; -x_172 = lean_ctor_get(x_168, 0); -lean_inc(x_172); -x_173 = lean_ctor_get(x_168, 1); -lean_inc(x_173); -lean_dec(x_168); -x_174 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_174, 0, x_172); -x_124 = x_174; -x_125 = x_173; -goto block_156; -} -block_156: -{ -if (lean_obj_tag(x_124) == 0) -{ -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; -x_126 = lean_ctor_get(x_125, 2); -lean_inc(x_126); -x_127 = lean_ctor_get(x_124, 0); -lean_inc(x_127); -lean_dec(x_124); -x_128 = lean_ctor_get(x_125, 0); +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_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; lean_object* x_173; lean_object* x_174; lean_object* x_175; +x_124 = lean_ctor_get(x_39, 0); +x_125 = lean_ctor_get(x_39, 1); +x_126 = lean_ctor_get(x_39, 2); +x_127 = lean_ctor_get(x_39, 3); +x_128 = lean_ctor_get(x_39, 4); lean_inc(x_128); -x_129 = lean_ctor_get(x_125, 1); -lean_inc(x_129); -x_130 = lean_ctor_get(x_125, 3); -lean_inc(x_130); -x_131 = lean_ctor_get(x_125, 4); -lean_inc(x_131); -x_132 = lean_ctor_get(x_125, 5); -lean_inc(x_132); -if (lean_is_exclusive(x_125)) { - lean_ctor_release(x_125, 0); - lean_ctor_release(x_125, 1); - lean_ctor_release(x_125, 2); - lean_ctor_release(x_125, 3); - lean_ctor_release(x_125, 4); - lean_ctor_release(x_125, 5); - x_133 = x_125; -} else { - lean_dec_ref(x_125); - x_133 = lean_box(0); -} -x_134 = lean_ctor_get(x_126, 0); -lean_inc(x_134); -x_135 = lean_ctor_get(x_126, 1); -lean_inc(x_135); -x_136 = lean_ctor_get(x_126, 3); -lean_inc(x_136); -if (lean_is_exclusive(x_126)) { - lean_ctor_release(x_126, 0); - lean_ctor_release(x_126, 1); - lean_ctor_release(x_126, 2); - lean_ctor_release(x_126, 3); - x_137 = x_126; -} else { - lean_dec_ref(x_126); - x_137 = lean_box(0); -} -if (lean_is_scalar(x_137)) { - x_138 = lean_alloc_ctor(0, 4, 0); -} else { - x_138 = x_137; -} -lean_ctor_set(x_138, 0, x_134); -lean_ctor_set(x_138, 1, x_135); -lean_ctor_set(x_138, 2, x_122); -lean_ctor_set(x_138, 3, x_136); -if (lean_is_scalar(x_133)) { - x_139 = lean_alloc_ctor(0, 6, 0); -} else { - x_139 = x_133; -} -lean_ctor_set(x_139, 0, x_128); -lean_ctor_set(x_139, 1, x_129); -lean_ctor_set(x_139, 2, x_138); -lean_ctor_set(x_139, 3, x_130); -lean_ctor_set(x_139, 4, x_131); -lean_ctor_set(x_139, 5, x_132); -if (lean_is_scalar(x_34)) { - x_140 = lean_alloc_ctor(1, 2, 0); -} else { - x_140 = x_34; - lean_ctor_set_tag(x_140, 1); -} -lean_ctor_set(x_140, 0, x_127); -lean_ctor_set(x_140, 1, x_139); -return x_140; -} -else -{ -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; -x_141 = lean_ctor_get(x_125, 2); -lean_inc(x_141); -x_142 = lean_ctor_get(x_124, 0); -lean_inc(x_142); -lean_dec(x_124); -x_143 = lean_ctor_get(x_125, 0); -lean_inc(x_143); -x_144 = lean_ctor_get(x_125, 1); -lean_inc(x_144); -x_145 = lean_ctor_get(x_125, 3); -lean_inc(x_145); -x_146 = lean_ctor_get(x_125, 4); -lean_inc(x_146); -x_147 = lean_ctor_get(x_125, 5); -lean_inc(x_147); -if (lean_is_exclusive(x_125)) { - lean_ctor_release(x_125, 0); - lean_ctor_release(x_125, 1); - lean_ctor_release(x_125, 2); - lean_ctor_release(x_125, 3); - lean_ctor_release(x_125, 4); - lean_ctor_release(x_125, 5); - x_148 = x_125; -} else { - lean_dec_ref(x_125); - x_148 = lean_box(0); -} -x_149 = lean_ctor_get(x_141, 0); -lean_inc(x_149); -x_150 = lean_ctor_get(x_141, 1); -lean_inc(x_150); -x_151 = lean_ctor_get(x_141, 3); -lean_inc(x_151); -if (lean_is_exclusive(x_141)) { - lean_ctor_release(x_141, 0); - lean_ctor_release(x_141, 1); - lean_ctor_release(x_141, 2); - lean_ctor_release(x_141, 3); - x_152 = x_141; -} else { - lean_dec_ref(x_141); - x_152 = lean_box(0); -} -if (lean_is_scalar(x_152)) { - x_153 = lean_alloc_ctor(0, 4, 0); -} else { - x_153 = x_152; -} -lean_ctor_set(x_153, 0, x_149); -lean_ctor_set(x_153, 1, x_150); -lean_ctor_set(x_153, 2, x_122); -lean_ctor_set(x_153, 3, x_151); -if (lean_is_scalar(x_148)) { - x_154 = lean_alloc_ctor(0, 6, 0); -} else { - x_154 = x_148; -} -lean_ctor_set(x_154, 0, x_143); -lean_ctor_set(x_154, 1, x_144); -lean_ctor_set(x_154, 2, x_153); -lean_ctor_set(x_154, 3, x_145); -lean_ctor_set(x_154, 4, x_146); -lean_ctor_set(x_154, 5, x_147); -if (lean_is_scalar(x_34)) { - x_155 = lean_alloc_ctor(0, 2, 0); -} else { - x_155 = x_34; -} -lean_ctor_set(x_155, 0, x_142); -lean_ctor_set(x_155, 1, x_154); -return x_155; -} -} -} -} -else -{ -lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; 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; lean_object* x_231; -x_175 = lean_ctor_get(x_33, 2); -x_176 = lean_ctor_get(x_33, 0); -x_177 = lean_ctor_get(x_33, 1); -x_178 = lean_ctor_get(x_33, 3); -x_179 = lean_ctor_get(x_33, 4); -x_180 = lean_ctor_get(x_33, 5); -lean_inc(x_180); -lean_inc(x_179); -lean_inc(x_178); -lean_inc(x_175); -lean_inc(x_177); -lean_inc(x_176); -lean_dec(x_33); -x_181 = lean_ctor_get(x_175, 0); -lean_inc(x_181); -x_182 = lean_ctor_get(x_175, 1); -lean_inc(x_182); -x_183 = lean_ctor_get(x_175, 2); -lean_inc(x_183); -x_184 = lean_ctor_get(x_175, 3); -lean_inc(x_184); -if (lean_is_exclusive(x_175)) { - lean_ctor_release(x_175, 0); - lean_ctor_release(x_175, 1); - lean_ctor_release(x_175, 2); - lean_ctor_release(x_175, 3); - x_185 = x_175; -} else { - lean_dec_ref(x_175); - x_185 = lean_box(0); -} -x_219 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_185)) { - x_220 = lean_alloc_ctor(0, 4, 0); -} else { - x_220 = x_185; -} -lean_ctor_set(x_220, 0, x_181); -lean_ctor_set(x_220, 1, x_182); -lean_ctor_set(x_220, 2, x_219); -lean_ctor_set(x_220, 3, x_184); -x_221 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_221, 0, x_176); -lean_ctor_set(x_221, 1, x_177); -lean_ctor_set(x_221, 2, x_220); -lean_ctor_set(x_221, 3, x_178); -lean_ctor_set(x_221, 4, x_179); -lean_ctor_set(x_221, 5, x_180); -x_222 = lean_ctor_get(x_13, 0); -lean_inc(x_222); -x_223 = lean_ctor_get(x_13, 1); -lean_inc(x_223); -x_224 = lean_ctor_get(x_13, 2); -lean_inc(x_224); -x_225 = lean_ctor_get(x_13, 3); -lean_inc(x_225); -x_226 = lean_ctor_get(x_13, 4); -lean_inc(x_226); +lean_inc(x_127); +lean_inc(x_126); +lean_inc(x_125); +lean_inc(x_124); +lean_dec(x_39); +x_164 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_165 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_165, 0, x_124); +lean_ctor_set(x_165, 1, x_125); +lean_ctor_set(x_165, 2, x_164); +lean_ctor_set(x_165, 3, x_127); +lean_ctor_set(x_165, 4, x_128); +lean_ctor_set(x_33, 2, x_165); +x_166 = lean_ctor_get(x_13, 0); +lean_inc(x_166); +x_167 = lean_ctor_get(x_13, 1); +lean_inc(x_167); +x_168 = lean_ctor_get(x_13, 2); +lean_inc(x_168); +x_169 = lean_ctor_get(x_13, 3); +lean_inc(x_169); +x_170 = lean_ctor_get(x_13, 4); +lean_inc(x_170); if (lean_is_exclusive(x_13)) { lean_ctor_release(x_13, 0); lean_ctor_release(x_13, 1); lean_ctor_release(x_13, 2); lean_ctor_release(x_13, 3); lean_ctor_release(x_13, 4); - x_227 = x_13; + x_171 = x_13; } else { lean_dec_ref(x_13); - x_227 = lean_box(0); + x_171 = lean_box(0); } -x_228 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_228, 0, x_35); -lean_ctor_set(x_228, 1, x_22); -x_229 = lean_array_push(x_224, x_228); -if (lean_is_scalar(x_227)) { +x_172 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_172, 0, x_35); +lean_ctor_set(x_172, 1, x_22); +x_173 = lean_array_push(x_168, x_172); +if (lean_is_scalar(x_171)) { + x_174 = lean_alloc_ctor(0, 5, 0); +} else { + x_174 = x_171; +} +lean_ctor_set(x_174, 0, x_166); +lean_ctor_set(x_174, 1, x_167); +lean_ctor_set(x_174, 2, x_173); +lean_ctor_set(x_174, 3, x_169); +lean_ctor_set(x_174, 4, x_170); +x_175 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_ExprDefEq_18__processConstApprox___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_37, x_174, x_33); +if (lean_obj_tag(x_175) == 0) +{ +lean_object* x_176; lean_object* x_177; lean_object* x_178; +x_176 = lean_ctor_get(x_175, 0); +lean_inc(x_176); +x_177 = lean_ctor_get(x_175, 1); +lean_inc(x_177); +lean_dec(x_175); +x_178 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_178, 0, x_176); +x_129 = x_178; +x_130 = x_177; +goto block_163; +} +else +{ +lean_object* x_179; lean_object* x_180; lean_object* x_181; +x_179 = lean_ctor_get(x_175, 0); +lean_inc(x_179); +x_180 = lean_ctor_get(x_175, 1); +lean_inc(x_180); +lean_dec(x_175); +x_181 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_181, 0, x_179); +x_129 = x_181; +x_130 = x_180; +goto block_163; +} +block_163: +{ +if (lean_obj_tag(x_129) == 0) +{ +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; +x_131 = lean_ctor_get(x_130, 2); +lean_inc(x_131); +x_132 = lean_ctor_get(x_129, 0); +lean_inc(x_132); +lean_dec(x_129); +x_133 = lean_ctor_get(x_130, 0); +lean_inc(x_133); +x_134 = lean_ctor_get(x_130, 1); +lean_inc(x_134); +x_135 = lean_ctor_get(x_130, 3); +lean_inc(x_135); +x_136 = lean_ctor_get(x_130, 4); +lean_inc(x_136); +x_137 = lean_ctor_get(x_130, 5); +lean_inc(x_137); +if (lean_is_exclusive(x_130)) { + lean_ctor_release(x_130, 0); + lean_ctor_release(x_130, 1); + lean_ctor_release(x_130, 2); + lean_ctor_release(x_130, 3); + lean_ctor_release(x_130, 4); + lean_ctor_release(x_130, 5); + x_138 = x_130; +} else { + lean_dec_ref(x_130); + x_138 = lean_box(0); +} +x_139 = lean_ctor_get(x_131, 0); +lean_inc(x_139); +x_140 = lean_ctor_get(x_131, 1); +lean_inc(x_140); +x_141 = lean_ctor_get(x_131, 3); +lean_inc(x_141); +x_142 = lean_ctor_get(x_131, 4); +lean_inc(x_142); +if (lean_is_exclusive(x_131)) { + lean_ctor_release(x_131, 0); + lean_ctor_release(x_131, 1); + lean_ctor_release(x_131, 2); + lean_ctor_release(x_131, 3); + lean_ctor_release(x_131, 4); + x_143 = x_131; +} else { + lean_dec_ref(x_131); + x_143 = lean_box(0); +} +if (lean_is_scalar(x_143)) { + x_144 = lean_alloc_ctor(0, 5, 0); +} else { + x_144 = x_143; +} +lean_ctor_set(x_144, 0, x_139); +lean_ctor_set(x_144, 1, x_140); +lean_ctor_set(x_144, 2, x_126); +lean_ctor_set(x_144, 3, x_141); +lean_ctor_set(x_144, 4, x_142); +if (lean_is_scalar(x_138)) { + x_145 = lean_alloc_ctor(0, 6, 0); +} else { + x_145 = x_138; +} +lean_ctor_set(x_145, 0, x_133); +lean_ctor_set(x_145, 1, x_134); +lean_ctor_set(x_145, 2, x_144); +lean_ctor_set(x_145, 3, x_135); +lean_ctor_set(x_145, 4, x_136); +lean_ctor_set(x_145, 5, x_137); +if (lean_is_scalar(x_34)) { + x_146 = lean_alloc_ctor(1, 2, 0); +} else { + x_146 = x_34; + lean_ctor_set_tag(x_146, 1); +} +lean_ctor_set(x_146, 0, x_132); +lean_ctor_set(x_146, 1, x_145); +return x_146; +} +else +{ +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; +x_147 = lean_ctor_get(x_130, 2); +lean_inc(x_147); +x_148 = lean_ctor_get(x_129, 0); +lean_inc(x_148); +lean_dec(x_129); +x_149 = lean_ctor_get(x_130, 0); +lean_inc(x_149); +x_150 = lean_ctor_get(x_130, 1); +lean_inc(x_150); +x_151 = lean_ctor_get(x_130, 3); +lean_inc(x_151); +x_152 = lean_ctor_get(x_130, 4); +lean_inc(x_152); +x_153 = lean_ctor_get(x_130, 5); +lean_inc(x_153); +if (lean_is_exclusive(x_130)) { + lean_ctor_release(x_130, 0); + lean_ctor_release(x_130, 1); + lean_ctor_release(x_130, 2); + lean_ctor_release(x_130, 3); + lean_ctor_release(x_130, 4); + lean_ctor_release(x_130, 5); + x_154 = x_130; +} else { + lean_dec_ref(x_130); + x_154 = lean_box(0); +} +x_155 = lean_ctor_get(x_147, 0); +lean_inc(x_155); +x_156 = lean_ctor_get(x_147, 1); +lean_inc(x_156); +x_157 = lean_ctor_get(x_147, 3); +lean_inc(x_157); +x_158 = lean_ctor_get(x_147, 4); +lean_inc(x_158); +if (lean_is_exclusive(x_147)) { + lean_ctor_release(x_147, 0); + lean_ctor_release(x_147, 1); + lean_ctor_release(x_147, 2); + lean_ctor_release(x_147, 3); + lean_ctor_release(x_147, 4); + x_159 = x_147; +} else { + lean_dec_ref(x_147); + x_159 = lean_box(0); +} +if (lean_is_scalar(x_159)) { + x_160 = lean_alloc_ctor(0, 5, 0); +} else { + x_160 = x_159; +} +lean_ctor_set(x_160, 0, x_155); +lean_ctor_set(x_160, 1, x_156); +lean_ctor_set(x_160, 2, x_126); +lean_ctor_set(x_160, 3, x_157); +lean_ctor_set(x_160, 4, x_158); +if (lean_is_scalar(x_154)) { + x_161 = lean_alloc_ctor(0, 6, 0); +} else { + x_161 = x_154; +} +lean_ctor_set(x_161, 0, x_149); +lean_ctor_set(x_161, 1, x_150); +lean_ctor_set(x_161, 2, x_160); +lean_ctor_set(x_161, 3, x_151); +lean_ctor_set(x_161, 4, x_152); +lean_ctor_set(x_161, 5, x_153); +if (lean_is_scalar(x_34)) { + x_162 = lean_alloc_ctor(0, 2, 0); +} else { + x_162 = x_34; +} +lean_ctor_set(x_162, 0, x_148); +lean_ctor_set(x_162, 1, x_161); +return x_162; +} +} +} +} +else +{ +lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_229; lean_object* x_230; lean_object* x_231; lean_object* x_232; lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_object* x_236; lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; +x_182 = lean_ctor_get(x_33, 2); +x_183 = lean_ctor_get(x_33, 0); +x_184 = lean_ctor_get(x_33, 1); +x_185 = lean_ctor_get(x_33, 3); +x_186 = lean_ctor_get(x_33, 4); +x_187 = lean_ctor_get(x_33, 5); +lean_inc(x_187); +lean_inc(x_186); +lean_inc(x_185); +lean_inc(x_182); +lean_inc(x_184); +lean_inc(x_183); +lean_dec(x_33); +x_188 = lean_ctor_get(x_182, 0); +lean_inc(x_188); +x_189 = lean_ctor_get(x_182, 1); +lean_inc(x_189); +x_190 = lean_ctor_get(x_182, 2); +lean_inc(x_190); +x_191 = lean_ctor_get(x_182, 3); +lean_inc(x_191); +x_192 = lean_ctor_get(x_182, 4); +lean_inc(x_192); +if (lean_is_exclusive(x_182)) { + lean_ctor_release(x_182, 0); + lean_ctor_release(x_182, 1); + lean_ctor_release(x_182, 2); + lean_ctor_release(x_182, 3); + lean_ctor_release(x_182, 4); + x_193 = x_182; +} else { + lean_dec_ref(x_182); + x_193 = lean_box(0); +} +x_229 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_193)) { x_230 = lean_alloc_ctor(0, 5, 0); } else { - x_230 = x_227; + x_230 = x_193; } -lean_ctor_set(x_230, 0, x_222); -lean_ctor_set(x_230, 1, x_223); +lean_ctor_set(x_230, 0, x_188); +lean_ctor_set(x_230, 1, x_189); lean_ctor_set(x_230, 2, x_229); -lean_ctor_set(x_230, 3, x_225); -lean_ctor_set(x_230, 4, x_226); -x_231 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_ExprDefEq_18__processConstApprox___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_37, x_230, x_221); -if (lean_obj_tag(x_231) == 0) -{ -lean_object* x_232; lean_object* x_233; lean_object* x_234; -x_232 = lean_ctor_get(x_231, 0); +lean_ctor_set(x_230, 3, x_191); +lean_ctor_set(x_230, 4, x_192); +x_231 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_231, 0, x_183); +lean_ctor_set(x_231, 1, x_184); +lean_ctor_set(x_231, 2, x_230); +lean_ctor_set(x_231, 3, x_185); +lean_ctor_set(x_231, 4, x_186); +lean_ctor_set(x_231, 5, x_187); +x_232 = lean_ctor_get(x_13, 0); lean_inc(x_232); -x_233 = lean_ctor_get(x_231, 1); +x_233 = lean_ctor_get(x_13, 1); lean_inc(x_233); -lean_dec(x_231); -x_234 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_234, 0, x_232); -x_186 = x_234; -x_187 = x_233; -goto block_218; -} -else -{ -lean_object* x_235; lean_object* x_236; lean_object* x_237; -x_235 = lean_ctor_get(x_231, 0); +x_234 = lean_ctor_get(x_13, 2); +lean_inc(x_234); +x_235 = lean_ctor_get(x_13, 3); lean_inc(x_235); -x_236 = lean_ctor_get(x_231, 1); +x_236 = lean_ctor_get(x_13, 4); lean_inc(x_236); -lean_dec(x_231); -x_237 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_237, 0, x_235); -x_186 = x_237; -x_187 = x_236; -goto block_218; +if (lean_is_exclusive(x_13)) { + lean_ctor_release(x_13, 0); + lean_ctor_release(x_13, 1); + lean_ctor_release(x_13, 2); + lean_ctor_release(x_13, 3); + lean_ctor_release(x_13, 4); + x_237 = x_13; +} else { + lean_dec_ref(x_13); + x_237 = lean_box(0); } -block_218: +x_238 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_238, 0, x_35); +lean_ctor_set(x_238, 1, x_22); +x_239 = lean_array_push(x_234, x_238); +if (lean_is_scalar(x_237)) { + x_240 = lean_alloc_ctor(0, 5, 0); +} else { + x_240 = x_237; +} +lean_ctor_set(x_240, 0, x_232); +lean_ctor_set(x_240, 1, x_233); +lean_ctor_set(x_240, 2, x_239); +lean_ctor_set(x_240, 3, x_235); +lean_ctor_set(x_240, 4, x_236); +x_241 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_ExprDefEq_18__processConstApprox___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_37, x_240, x_231); +if (lean_obj_tag(x_241) == 0) { -if (lean_obj_tag(x_186) == 0) -{ -lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; -x_188 = lean_ctor_get(x_187, 2); -lean_inc(x_188); -x_189 = lean_ctor_get(x_186, 0); -lean_inc(x_189); -lean_dec(x_186); -x_190 = lean_ctor_get(x_187, 0); -lean_inc(x_190); -x_191 = lean_ctor_get(x_187, 1); -lean_inc(x_191); -x_192 = lean_ctor_get(x_187, 3); -lean_inc(x_192); -x_193 = lean_ctor_get(x_187, 4); -lean_inc(x_193); -x_194 = lean_ctor_get(x_187, 5); -lean_inc(x_194); -if (lean_is_exclusive(x_187)) { - lean_ctor_release(x_187, 0); - lean_ctor_release(x_187, 1); - lean_ctor_release(x_187, 2); - lean_ctor_release(x_187, 3); - lean_ctor_release(x_187, 4); - lean_ctor_release(x_187, 5); - x_195 = x_187; -} else { - lean_dec_ref(x_187); - x_195 = lean_box(0); -} -x_196 = lean_ctor_get(x_188, 0); -lean_inc(x_196); -x_197 = lean_ctor_get(x_188, 1); -lean_inc(x_197); -x_198 = lean_ctor_get(x_188, 3); -lean_inc(x_198); -if (lean_is_exclusive(x_188)) { - lean_ctor_release(x_188, 0); - lean_ctor_release(x_188, 1); - lean_ctor_release(x_188, 2); - lean_ctor_release(x_188, 3); - x_199 = x_188; -} else { - lean_dec_ref(x_188); - x_199 = lean_box(0); -} -if (lean_is_scalar(x_199)) { - x_200 = lean_alloc_ctor(0, 4, 0); -} else { - x_200 = x_199; -} -lean_ctor_set(x_200, 0, x_196); -lean_ctor_set(x_200, 1, x_197); -lean_ctor_set(x_200, 2, x_183); -lean_ctor_set(x_200, 3, x_198); -if (lean_is_scalar(x_195)) { - x_201 = lean_alloc_ctor(0, 6, 0); -} else { - x_201 = x_195; -} -lean_ctor_set(x_201, 0, x_190); -lean_ctor_set(x_201, 1, x_191); -lean_ctor_set(x_201, 2, x_200); -lean_ctor_set(x_201, 3, x_192); -lean_ctor_set(x_201, 4, x_193); -lean_ctor_set(x_201, 5, x_194); -if (lean_is_scalar(x_34)) { - x_202 = lean_alloc_ctor(1, 2, 0); -} else { - x_202 = x_34; - lean_ctor_set_tag(x_202, 1); -} -lean_ctor_set(x_202, 0, x_189); -lean_ctor_set(x_202, 1, x_201); -return x_202; +lean_object* x_242; lean_object* x_243; lean_object* x_244; +x_242 = lean_ctor_get(x_241, 0); +lean_inc(x_242); +x_243 = lean_ctor_get(x_241, 1); +lean_inc(x_243); +lean_dec(x_241); +x_244 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_244, 0, x_242); +x_194 = x_244; +x_195 = x_243; +goto block_228; } else { -lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; -x_203 = lean_ctor_get(x_187, 2); -lean_inc(x_203); -x_204 = lean_ctor_get(x_186, 0); +lean_object* x_245; lean_object* x_246; lean_object* x_247; +x_245 = lean_ctor_get(x_241, 0); +lean_inc(x_245); +x_246 = lean_ctor_get(x_241, 1); +lean_inc(x_246); +lean_dec(x_241); +x_247 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_247, 0, x_245); +x_194 = x_247; +x_195 = x_246; +goto block_228; +} +block_228: +{ +if (lean_obj_tag(x_194) == 0) +{ +lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; +x_196 = lean_ctor_get(x_195, 2); +lean_inc(x_196); +x_197 = lean_ctor_get(x_194, 0); +lean_inc(x_197); +lean_dec(x_194); +x_198 = lean_ctor_get(x_195, 0); +lean_inc(x_198); +x_199 = lean_ctor_get(x_195, 1); +lean_inc(x_199); +x_200 = lean_ctor_get(x_195, 3); +lean_inc(x_200); +x_201 = lean_ctor_get(x_195, 4); +lean_inc(x_201); +x_202 = lean_ctor_get(x_195, 5); +lean_inc(x_202); +if (lean_is_exclusive(x_195)) { + lean_ctor_release(x_195, 0); + lean_ctor_release(x_195, 1); + lean_ctor_release(x_195, 2); + lean_ctor_release(x_195, 3); + lean_ctor_release(x_195, 4); + lean_ctor_release(x_195, 5); + x_203 = x_195; +} else { + lean_dec_ref(x_195); + x_203 = lean_box(0); +} +x_204 = lean_ctor_get(x_196, 0); lean_inc(x_204); -lean_dec(x_186); -x_205 = lean_ctor_get(x_187, 0); +x_205 = lean_ctor_get(x_196, 1); lean_inc(x_205); -x_206 = lean_ctor_get(x_187, 1); +x_206 = lean_ctor_get(x_196, 3); lean_inc(x_206); -x_207 = lean_ctor_get(x_187, 3); +x_207 = lean_ctor_get(x_196, 4); lean_inc(x_207); -x_208 = lean_ctor_get(x_187, 4); -lean_inc(x_208); -x_209 = lean_ctor_get(x_187, 5); -lean_inc(x_209); -if (lean_is_exclusive(x_187)) { - lean_ctor_release(x_187, 0); - lean_ctor_release(x_187, 1); - lean_ctor_release(x_187, 2); - lean_ctor_release(x_187, 3); - lean_ctor_release(x_187, 4); - lean_ctor_release(x_187, 5); - x_210 = x_187; +if (lean_is_exclusive(x_196)) { + lean_ctor_release(x_196, 0); + lean_ctor_release(x_196, 1); + lean_ctor_release(x_196, 2); + lean_ctor_release(x_196, 3); + lean_ctor_release(x_196, 4); + x_208 = x_196; } else { - lean_dec_ref(x_187); - x_210 = lean_box(0); + lean_dec_ref(x_196); + x_208 = lean_box(0); } -x_211 = lean_ctor_get(x_203, 0); -lean_inc(x_211); -x_212 = lean_ctor_get(x_203, 1); -lean_inc(x_212); -x_213 = lean_ctor_get(x_203, 3); -lean_inc(x_213); -if (lean_is_exclusive(x_203)) { - lean_ctor_release(x_203, 0); - lean_ctor_release(x_203, 1); - lean_ctor_release(x_203, 2); - lean_ctor_release(x_203, 3); - x_214 = x_203; +if (lean_is_scalar(x_208)) { + x_209 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_203); - x_214 = lean_box(0); + x_209 = x_208; } -if (lean_is_scalar(x_214)) { - x_215 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_209, 0, x_204); +lean_ctor_set(x_209, 1, x_205); +lean_ctor_set(x_209, 2, x_190); +lean_ctor_set(x_209, 3, x_206); +lean_ctor_set(x_209, 4, x_207); +if (lean_is_scalar(x_203)) { + x_210 = lean_alloc_ctor(0, 6, 0); } else { - x_215 = x_214; + x_210 = x_203; } -lean_ctor_set(x_215, 0, x_211); -lean_ctor_set(x_215, 1, x_212); -lean_ctor_set(x_215, 2, x_183); -lean_ctor_set(x_215, 3, x_213); -if (lean_is_scalar(x_210)) { - x_216 = lean_alloc_ctor(0, 6, 0); -} else { - x_216 = x_210; -} -lean_ctor_set(x_216, 0, x_205); -lean_ctor_set(x_216, 1, x_206); -lean_ctor_set(x_216, 2, x_215); -lean_ctor_set(x_216, 3, x_207); -lean_ctor_set(x_216, 4, x_208); -lean_ctor_set(x_216, 5, x_209); +lean_ctor_set(x_210, 0, x_198); +lean_ctor_set(x_210, 1, x_199); +lean_ctor_set(x_210, 2, x_209); +lean_ctor_set(x_210, 3, x_200); +lean_ctor_set(x_210, 4, x_201); +lean_ctor_set(x_210, 5, x_202); if (lean_is_scalar(x_34)) { - x_217 = lean_alloc_ctor(0, 2, 0); + x_211 = lean_alloc_ctor(1, 2, 0); } else { - x_217 = x_34; + x_211 = x_34; + lean_ctor_set_tag(x_211, 1); } -lean_ctor_set(x_217, 0, x_204); -lean_ctor_set(x_217, 1, x_216); -return x_217; +lean_ctor_set(x_211, 0, x_197); +lean_ctor_set(x_211, 1, x_210); +return x_211; +} +else +{ +lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; lean_object* x_224; lean_object* x_225; lean_object* x_226; lean_object* x_227; +x_212 = lean_ctor_get(x_195, 2); +lean_inc(x_212); +x_213 = lean_ctor_get(x_194, 0); +lean_inc(x_213); +lean_dec(x_194); +x_214 = lean_ctor_get(x_195, 0); +lean_inc(x_214); +x_215 = lean_ctor_get(x_195, 1); +lean_inc(x_215); +x_216 = lean_ctor_get(x_195, 3); +lean_inc(x_216); +x_217 = lean_ctor_get(x_195, 4); +lean_inc(x_217); +x_218 = lean_ctor_get(x_195, 5); +lean_inc(x_218); +if (lean_is_exclusive(x_195)) { + lean_ctor_release(x_195, 0); + lean_ctor_release(x_195, 1); + lean_ctor_release(x_195, 2); + lean_ctor_release(x_195, 3); + lean_ctor_release(x_195, 4); + lean_ctor_release(x_195, 5); + x_219 = x_195; +} else { + lean_dec_ref(x_195); + x_219 = lean_box(0); +} +x_220 = lean_ctor_get(x_212, 0); +lean_inc(x_220); +x_221 = lean_ctor_get(x_212, 1); +lean_inc(x_221); +x_222 = lean_ctor_get(x_212, 3); +lean_inc(x_222); +x_223 = lean_ctor_get(x_212, 4); +lean_inc(x_223); +if (lean_is_exclusive(x_212)) { + lean_ctor_release(x_212, 0); + lean_ctor_release(x_212, 1); + lean_ctor_release(x_212, 2); + lean_ctor_release(x_212, 3); + lean_ctor_release(x_212, 4); + x_224 = x_212; +} else { + lean_dec_ref(x_212); + x_224 = lean_box(0); +} +if (lean_is_scalar(x_224)) { + x_225 = lean_alloc_ctor(0, 5, 0); +} else { + x_225 = x_224; +} +lean_ctor_set(x_225, 0, x_220); +lean_ctor_set(x_225, 1, x_221); +lean_ctor_set(x_225, 2, x_190); +lean_ctor_set(x_225, 3, x_222); +lean_ctor_set(x_225, 4, x_223); +if (lean_is_scalar(x_219)) { + x_226 = lean_alloc_ctor(0, 6, 0); +} else { + x_226 = x_219; +} +lean_ctor_set(x_226, 0, x_214); +lean_ctor_set(x_226, 1, x_215); +lean_ctor_set(x_226, 2, x_225); +lean_ctor_set(x_226, 3, x_216); +lean_ctor_set(x_226, 4, x_217); +lean_ctor_set(x_226, 5, x_218); +if (lean_is_scalar(x_34)) { + x_227 = lean_alloc_ctor(0, 2, 0); +} else { + x_227 = x_34; +} +lean_ctor_set(x_227, 0, x_213); +lean_ctor_set(x_227, 1, x_226); +return x_227; } } } } default: { -lean_object* x_238; lean_object* x_239; -x_238 = lean_ctor_get(x_27, 1); -lean_inc(x_238); +lean_object* x_248; lean_object* x_249; +x_248 = lean_ctor_get(x_27, 1); +lean_inc(x_248); lean_dec(x_27); lean_inc(x_13); -x_239 = l_Lean_Meta_isClassExpensive___main(x_26, x_13, x_238); -if (lean_obj_tag(x_239) == 0) +x_249 = l_Lean_Meta_isClassExpensive___main(x_26, x_13, x_248); +if (lean_obj_tag(x_249) == 0) { -lean_object* x_240; -x_240 = lean_ctor_get(x_239, 0); -lean_inc(x_240); -if (lean_obj_tag(x_240) == 0) +lean_object* x_250; +x_250 = lean_ctor_get(x_249, 0); +lean_inc(x_250); +if (lean_obj_tag(x_250) == 0) { -lean_object* x_241; lean_object* x_242; lean_object* x_243; +lean_object* x_251; lean_object* x_252; lean_object* x_253; lean_dec(x_22); -x_241 = lean_ctor_get(x_239, 1); -lean_inc(x_241); -lean_dec(x_239); -x_242 = lean_unsigned_to_nat(1u); -x_243 = lean_nat_add(x_12, x_242); +x_251 = lean_ctor_get(x_249, 1); +lean_inc(x_251); +lean_dec(x_249); +x_252 = lean_unsigned_to_nat(1u); +x_253 = lean_nat_add(x_12, x_252); lean_dec(x_12); -x_12 = x_243; -x_14 = x_241; +x_12 = x_253; +x_14 = x_251; goto _start; } else { -lean_object* x_245; lean_object* x_246; lean_object* x_247; lean_object* x_248; lean_object* x_249; uint8_t x_250; -x_245 = lean_ctor_get(x_239, 1); -lean_inc(x_245); -if (lean_is_exclusive(x_239)) { - lean_ctor_release(x_239, 0); - lean_ctor_release(x_239, 1); - x_246 = x_239; +lean_object* x_255; lean_object* x_256; lean_object* x_257; lean_object* x_258; lean_object* x_259; uint8_t x_260; +x_255 = lean_ctor_get(x_249, 1); +lean_inc(x_255); +if (lean_is_exclusive(x_249)) { + lean_ctor_release(x_249, 0); + lean_ctor_release(x_249, 1); + x_256 = x_249; } else { - lean_dec_ref(x_239); - x_246 = lean_box(0); + lean_dec_ref(x_249); + x_256 = lean_box(0); } -x_247 = lean_ctor_get(x_240, 0); -lean_inc(x_247); -lean_dec(x_240); -x_248 = lean_unsigned_to_nat(1u); -x_249 = lean_nat_add(x_12, x_248); -lean_dec(x_12); -x_250 = !lean_is_exclusive(x_245); -if (x_250 == 0) -{ -lean_object* x_251; uint8_t x_252; -x_251 = lean_ctor_get(x_245, 2); -x_252 = !lean_is_exclusive(x_251); -if (x_252 == 0) -{ -lean_object* x_253; lean_object* x_254; lean_object* x_255; lean_object* x_305; uint8_t x_306; -x_253 = lean_ctor_get(x_251, 2); -x_305 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_251, 2, x_305); -x_306 = !lean_is_exclusive(x_13); -if (x_306 == 0) -{ -lean_object* x_307; lean_object* x_308; lean_object* x_309; lean_object* x_310; -x_307 = lean_ctor_get(x_13, 2); -x_308 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_308, 0, x_247); -lean_ctor_set(x_308, 1, x_22); -x_309 = lean_array_push(x_307, x_308); -lean_ctor_set(x_13, 2, x_309); -x_310 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_ExprDefEq_18__processConstApprox___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_249, x_13, x_245); -if (lean_obj_tag(x_310) == 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); -x_313 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_313, 0, x_311); -x_254 = x_313; -x_255 = x_312; -goto block_304; -} -else -{ -lean_object* x_314; lean_object* x_315; lean_object* x_316; -x_314 = lean_ctor_get(x_310, 0); -lean_inc(x_314); -x_315 = lean_ctor_get(x_310, 1); -lean_inc(x_315); -lean_dec(x_310); -x_316 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_316, 0, x_314); -x_254 = x_316; -x_255 = x_315; -goto block_304; -} -} -else -{ -lean_object* x_317; lean_object* x_318; lean_object* x_319; lean_object* x_320; lean_object* x_321; lean_object* x_322; lean_object* x_323; lean_object* x_324; lean_object* x_325; -x_317 = lean_ctor_get(x_13, 0); -x_318 = lean_ctor_get(x_13, 1); -x_319 = lean_ctor_get(x_13, 2); -x_320 = lean_ctor_get(x_13, 3); -x_321 = lean_ctor_get(x_13, 4); -lean_inc(x_321); -lean_inc(x_320); -lean_inc(x_319); -lean_inc(x_318); -lean_inc(x_317); -lean_dec(x_13); -x_322 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_322, 0, x_247); -lean_ctor_set(x_322, 1, x_22); -x_323 = lean_array_push(x_319, x_322); -x_324 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_324, 0, x_317); -lean_ctor_set(x_324, 1, x_318); -lean_ctor_set(x_324, 2, x_323); -lean_ctor_set(x_324, 3, x_320); -lean_ctor_set(x_324, 4, x_321); -x_325 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_ExprDefEq_18__processConstApprox___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_249, x_324, x_245); -if (lean_obj_tag(x_325) == 0) -{ -lean_object* x_326; lean_object* x_327; lean_object* x_328; -x_326 = lean_ctor_get(x_325, 0); -lean_inc(x_326); -x_327 = lean_ctor_get(x_325, 1); -lean_inc(x_327); -lean_dec(x_325); -x_328 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_328, 0, x_326); -x_254 = x_328; -x_255 = x_327; -goto block_304; -} -else -{ -lean_object* x_329; lean_object* x_330; lean_object* x_331; -x_329 = lean_ctor_get(x_325, 0); -lean_inc(x_329); -x_330 = lean_ctor_get(x_325, 1); -lean_inc(x_330); -lean_dec(x_325); -x_331 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_331, 0, x_329); -x_254 = x_331; -x_255 = x_330; -goto block_304; -} -} -block_304: -{ -if (lean_obj_tag(x_254) == 0) -{ -lean_object* x_256; lean_object* x_257; uint8_t x_258; -x_256 = lean_ctor_get(x_255, 2); -lean_inc(x_256); -x_257 = lean_ctor_get(x_254, 0); +x_257 = lean_ctor_get(x_250, 0); lean_inc(x_257); -lean_dec(x_254); -x_258 = !lean_is_exclusive(x_255); -if (x_258 == 0) -{ -lean_object* x_259; uint8_t x_260; -x_259 = lean_ctor_get(x_255, 2); -lean_dec(x_259); -x_260 = !lean_is_exclusive(x_256); +lean_dec(x_250); +x_258 = lean_unsigned_to_nat(1u); +x_259 = lean_nat_add(x_12, x_258); +lean_dec(x_12); +x_260 = !lean_is_exclusive(x_255); if (x_260 == 0) { -lean_object* x_261; lean_object* x_262; -x_261 = lean_ctor_get(x_256, 2); -lean_dec(x_261); -lean_ctor_set(x_256, 2, x_253); -if (lean_is_scalar(x_246)) { - x_262 = lean_alloc_ctor(1, 2, 0); -} else { - x_262 = x_246; - lean_ctor_set_tag(x_262, 1); -} -lean_ctor_set(x_262, 0, x_257); -lean_ctor_set(x_262, 1, x_255); -return x_262; +lean_object* x_261; uint8_t x_262; +x_261 = lean_ctor_get(x_255, 2); +x_262 = !lean_is_exclusive(x_261); +if (x_262 == 0) +{ +lean_object* x_263; lean_object* x_264; lean_object* x_265; lean_object* x_319; uint8_t x_320; +x_263 = lean_ctor_get(x_261, 2); +x_319 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_261, 2, x_319); +x_320 = !lean_is_exclusive(x_13); +if (x_320 == 0) +{ +lean_object* x_321; lean_object* x_322; lean_object* x_323; lean_object* x_324; +x_321 = lean_ctor_get(x_13, 2); +x_322 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_322, 0, x_257); +lean_ctor_set(x_322, 1, x_22); +x_323 = lean_array_push(x_321, x_322); +lean_ctor_set(x_13, 2, x_323); +x_324 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_ExprDefEq_18__processConstApprox___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_259, x_13, x_255); +if (lean_obj_tag(x_324) == 0) +{ +lean_object* x_325; lean_object* x_326; lean_object* x_327; +x_325 = lean_ctor_get(x_324, 0); +lean_inc(x_325); +x_326 = lean_ctor_get(x_324, 1); +lean_inc(x_326); +lean_dec(x_324); +x_327 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_327, 0, x_325); +x_264 = x_327; +x_265 = x_326; +goto block_318; } 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_256, 0); -x_264 = lean_ctor_get(x_256, 1); -x_265 = lean_ctor_get(x_256, 3); -lean_inc(x_265); -lean_inc(x_264); -lean_inc(x_263); -lean_dec(x_256); -x_266 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_266, 0, x_263); -lean_ctor_set(x_266, 1, x_264); -lean_ctor_set(x_266, 2, x_253); -lean_ctor_set(x_266, 3, x_265); -lean_ctor_set(x_255, 2, x_266); -if (lean_is_scalar(x_246)) { - x_267 = lean_alloc_ctor(1, 2, 0); -} else { - x_267 = x_246; - lean_ctor_set_tag(x_267, 1); -} -lean_ctor_set(x_267, 0, x_257); -lean_ctor_set(x_267, 1, x_255); -return x_267; +lean_object* x_328; lean_object* x_329; lean_object* x_330; +x_328 = lean_ctor_get(x_324, 0); +lean_inc(x_328); +x_329 = lean_ctor_get(x_324, 1); +lean_inc(x_329); +lean_dec(x_324); +x_330 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_330, 0, x_328); +x_264 = x_330; +x_265 = x_329; +goto block_318; } } else { -lean_object* x_268; lean_object* x_269; lean_object* x_270; lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_object* x_276; lean_object* x_277; lean_object* x_278; lean_object* x_279; -x_268 = lean_ctor_get(x_255, 0); -x_269 = lean_ctor_get(x_255, 1); -x_270 = lean_ctor_get(x_255, 3); -x_271 = lean_ctor_get(x_255, 4); -x_272 = lean_ctor_get(x_255, 5); -lean_inc(x_272); -lean_inc(x_271); -lean_inc(x_270); -lean_inc(x_269); -lean_inc(x_268); -lean_dec(x_255); -x_273 = lean_ctor_get(x_256, 0); -lean_inc(x_273); -x_274 = lean_ctor_get(x_256, 1); -lean_inc(x_274); -x_275 = lean_ctor_get(x_256, 3); +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; lean_object* x_339; +x_331 = lean_ctor_get(x_13, 0); +x_332 = lean_ctor_get(x_13, 1); +x_333 = lean_ctor_get(x_13, 2); +x_334 = lean_ctor_get(x_13, 3); +x_335 = lean_ctor_get(x_13, 4); +lean_inc(x_335); +lean_inc(x_334); +lean_inc(x_333); +lean_inc(x_332); +lean_inc(x_331); +lean_dec(x_13); +x_336 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_336, 0, x_257); +lean_ctor_set(x_336, 1, x_22); +x_337 = lean_array_push(x_333, x_336); +x_338 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_338, 0, x_331); +lean_ctor_set(x_338, 1, x_332); +lean_ctor_set(x_338, 2, x_337); +lean_ctor_set(x_338, 3, x_334); +lean_ctor_set(x_338, 4, x_335); +x_339 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_ExprDefEq_18__processConstApprox___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_259, x_338, x_255); +if (lean_obj_tag(x_339) == 0) +{ +lean_object* x_340; lean_object* x_341; lean_object* x_342; +x_340 = lean_ctor_get(x_339, 0); +lean_inc(x_340); +x_341 = lean_ctor_get(x_339, 1); +lean_inc(x_341); +lean_dec(x_339); +x_342 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_342, 0, x_340); +x_264 = x_342; +x_265 = x_341; +goto block_318; +} +else +{ +lean_object* x_343; lean_object* x_344; lean_object* x_345; +x_343 = lean_ctor_get(x_339, 0); +lean_inc(x_343); +x_344 = lean_ctor_get(x_339, 1); +lean_inc(x_344); +lean_dec(x_339); +x_345 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_345, 0, x_343); +x_264 = x_345; +x_265 = x_344; +goto block_318; +} +} +block_318: +{ +if (lean_obj_tag(x_264) == 0) +{ +lean_object* x_266; lean_object* x_267; uint8_t x_268; +x_266 = lean_ctor_get(x_265, 2); +lean_inc(x_266); +x_267 = lean_ctor_get(x_264, 0); +lean_inc(x_267); +lean_dec(x_264); +x_268 = !lean_is_exclusive(x_265); +if (x_268 == 0) +{ +lean_object* x_269; uint8_t x_270; +x_269 = lean_ctor_get(x_265, 2); +lean_dec(x_269); +x_270 = !lean_is_exclusive(x_266); +if (x_270 == 0) +{ +lean_object* x_271; lean_object* x_272; +x_271 = lean_ctor_get(x_266, 2); +lean_dec(x_271); +lean_ctor_set(x_266, 2, x_263); +if (lean_is_scalar(x_256)) { + x_272 = lean_alloc_ctor(1, 2, 0); +} else { + x_272 = x_256; + lean_ctor_set_tag(x_272, 1); +} +lean_ctor_set(x_272, 0, x_267); +lean_ctor_set(x_272, 1, x_265); +return x_272; +} +else +{ +lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_object* x_276; lean_object* x_277; lean_object* x_278; +x_273 = lean_ctor_get(x_266, 0); +x_274 = lean_ctor_get(x_266, 1); +x_275 = lean_ctor_get(x_266, 3); +x_276 = lean_ctor_get(x_266, 4); +lean_inc(x_276); lean_inc(x_275); -if (lean_is_exclusive(x_256)) { - lean_ctor_release(x_256, 0); - lean_ctor_release(x_256, 1); - lean_ctor_release(x_256, 2); - lean_ctor_release(x_256, 3); - x_276 = x_256; -} else { - lean_dec_ref(x_256); - x_276 = lean_box(0); -} -if (lean_is_scalar(x_276)) { - x_277 = lean_alloc_ctor(0, 4, 0); -} else { - x_277 = x_276; -} +lean_inc(x_274); +lean_inc(x_273); +lean_dec(x_266); +x_277 = lean_alloc_ctor(0, 5, 0); lean_ctor_set(x_277, 0, x_273); lean_ctor_set(x_277, 1, x_274); -lean_ctor_set(x_277, 2, x_253); +lean_ctor_set(x_277, 2, x_263); lean_ctor_set(x_277, 3, x_275); -x_278 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_278, 0, x_268); -lean_ctor_set(x_278, 1, x_269); -lean_ctor_set(x_278, 2, x_277); -lean_ctor_set(x_278, 3, x_270); -lean_ctor_set(x_278, 4, x_271); -lean_ctor_set(x_278, 5, x_272); -if (lean_is_scalar(x_246)) { - x_279 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_277, 4, x_276); +lean_ctor_set(x_265, 2, x_277); +if (lean_is_scalar(x_256)) { + x_278 = lean_alloc_ctor(1, 2, 0); } else { - x_279 = x_246; - lean_ctor_set_tag(x_279, 1); + x_278 = x_256; + lean_ctor_set_tag(x_278, 1); } -lean_ctor_set(x_279, 0, x_257); -lean_ctor_set(x_279, 1, x_278); -return x_279; +lean_ctor_set(x_278, 0, x_267); +lean_ctor_set(x_278, 1, x_265); +return x_278; } } else { -lean_object* x_280; lean_object* x_281; uint8_t x_282; -x_280 = lean_ctor_get(x_255, 2); -lean_inc(x_280); -x_281 = lean_ctor_get(x_254, 0); +lean_object* x_279; lean_object* x_280; lean_object* x_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; lean_object* x_289; lean_object* x_290; lean_object* x_291; +x_279 = lean_ctor_get(x_265, 0); +x_280 = lean_ctor_get(x_265, 1); +x_281 = lean_ctor_get(x_265, 3); +x_282 = lean_ctor_get(x_265, 4); +x_283 = lean_ctor_get(x_265, 5); +lean_inc(x_283); +lean_inc(x_282); lean_inc(x_281); -lean_dec(x_254); -x_282 = !lean_is_exclusive(x_255); -if (x_282 == 0) -{ -lean_object* x_283; uint8_t x_284; -x_283 = lean_ctor_get(x_255, 2); -lean_dec(x_283); -x_284 = !lean_is_exclusive(x_280); -if (x_284 == 0) -{ -lean_object* x_285; lean_object* x_286; -x_285 = lean_ctor_get(x_280, 2); -lean_dec(x_285); -lean_ctor_set(x_280, 2, x_253); -if (lean_is_scalar(x_246)) { - x_286 = lean_alloc_ctor(0, 2, 0); -} else { - x_286 = x_246; -} -lean_ctor_set(x_286, 0, x_281); -lean_ctor_set(x_286, 1, x_255); -return x_286; -} -else -{ -lean_object* x_287; lean_object* x_288; lean_object* x_289; lean_object* x_290; lean_object* x_291; -x_287 = lean_ctor_get(x_280, 0); -x_288 = lean_ctor_get(x_280, 1); -x_289 = lean_ctor_get(x_280, 3); -lean_inc(x_289); -lean_inc(x_288); +lean_inc(x_280); +lean_inc(x_279); +lean_dec(x_265); +x_284 = lean_ctor_get(x_266, 0); +lean_inc(x_284); +x_285 = lean_ctor_get(x_266, 1); +lean_inc(x_285); +x_286 = lean_ctor_get(x_266, 3); +lean_inc(x_286); +x_287 = lean_ctor_get(x_266, 4); lean_inc(x_287); -lean_dec(x_280); -x_290 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_290, 0, x_287); -lean_ctor_set(x_290, 1, x_288); -lean_ctor_set(x_290, 2, x_253); -lean_ctor_set(x_290, 3, x_289); -lean_ctor_set(x_255, 2, x_290); -if (lean_is_scalar(x_246)) { - x_291 = lean_alloc_ctor(0, 2, 0); +if (lean_is_exclusive(x_266)) { + lean_ctor_release(x_266, 0); + lean_ctor_release(x_266, 1); + lean_ctor_release(x_266, 2); + lean_ctor_release(x_266, 3); + lean_ctor_release(x_266, 4); + x_288 = x_266; } else { - x_291 = x_246; + lean_dec_ref(x_266); + x_288 = lean_box(0); } -lean_ctor_set(x_291, 0, x_281); -lean_ctor_set(x_291, 1, x_255); +if (lean_is_scalar(x_288)) { + x_289 = lean_alloc_ctor(0, 5, 0); +} else { + x_289 = x_288; +} +lean_ctor_set(x_289, 0, x_284); +lean_ctor_set(x_289, 1, x_285); +lean_ctor_set(x_289, 2, x_263); +lean_ctor_set(x_289, 3, x_286); +lean_ctor_set(x_289, 4, x_287); +x_290 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_290, 0, x_279); +lean_ctor_set(x_290, 1, x_280); +lean_ctor_set(x_290, 2, x_289); +lean_ctor_set(x_290, 3, x_281); +lean_ctor_set(x_290, 4, x_282); +lean_ctor_set(x_290, 5, x_283); +if (lean_is_scalar(x_256)) { + x_291 = lean_alloc_ctor(1, 2, 0); +} else { + x_291 = x_256; + lean_ctor_set_tag(x_291, 1); +} +lean_ctor_set(x_291, 0, x_267); +lean_ctor_set(x_291, 1, x_290); return x_291; } } else { -lean_object* x_292; lean_object* x_293; lean_object* x_294; lean_object* x_295; lean_object* x_296; lean_object* x_297; lean_object* x_298; lean_object* x_299; lean_object* x_300; lean_object* x_301; lean_object* x_302; lean_object* x_303; -x_292 = lean_ctor_get(x_255, 0); -x_293 = lean_ctor_get(x_255, 1); -x_294 = lean_ctor_get(x_255, 3); -x_295 = lean_ctor_get(x_255, 4); -x_296 = lean_ctor_get(x_255, 5); -lean_inc(x_296); -lean_inc(x_295); -lean_inc(x_294); -lean_inc(x_293); +lean_object* x_292; lean_object* x_293; uint8_t x_294; +x_292 = lean_ctor_get(x_265, 2); lean_inc(x_292); -lean_dec(x_255); -x_297 = lean_ctor_get(x_280, 0); -lean_inc(x_297); -x_298 = lean_ctor_get(x_280, 1); -lean_inc(x_298); -x_299 = lean_ctor_get(x_280, 3); +x_293 = lean_ctor_get(x_264, 0); +lean_inc(x_293); +lean_dec(x_264); +x_294 = !lean_is_exclusive(x_265); +if (x_294 == 0) +{ +lean_object* x_295; uint8_t x_296; +x_295 = lean_ctor_get(x_265, 2); +lean_dec(x_295); +x_296 = !lean_is_exclusive(x_292); +if (x_296 == 0) +{ +lean_object* x_297; lean_object* x_298; +x_297 = lean_ctor_get(x_292, 2); +lean_dec(x_297); +lean_ctor_set(x_292, 2, x_263); +if (lean_is_scalar(x_256)) { + x_298 = lean_alloc_ctor(0, 2, 0); +} else { + x_298 = x_256; +} +lean_ctor_set(x_298, 0, x_293); +lean_ctor_set(x_298, 1, x_265); +return x_298; +} +else +{ +lean_object* x_299; lean_object* x_300; lean_object* x_301; lean_object* x_302; lean_object* x_303; lean_object* x_304; +x_299 = lean_ctor_get(x_292, 0); +x_300 = lean_ctor_get(x_292, 1); +x_301 = lean_ctor_get(x_292, 3); +x_302 = lean_ctor_get(x_292, 4); +lean_inc(x_302); +lean_inc(x_301); +lean_inc(x_300); lean_inc(x_299); -if (lean_is_exclusive(x_280)) { - lean_ctor_release(x_280, 0); - lean_ctor_release(x_280, 1); - lean_ctor_release(x_280, 2); - lean_ctor_release(x_280, 3); - x_300 = x_280; +lean_dec(x_292); +x_303 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_303, 0, x_299); +lean_ctor_set(x_303, 1, x_300); +lean_ctor_set(x_303, 2, x_263); +lean_ctor_set(x_303, 3, x_301); +lean_ctor_set(x_303, 4, x_302); +lean_ctor_set(x_265, 2, x_303); +if (lean_is_scalar(x_256)) { + x_304 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_280); - x_300 = lean_box(0); + x_304 = x_256; } -if (lean_is_scalar(x_300)) { - x_301 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_304, 0, x_293); +lean_ctor_set(x_304, 1, x_265); +return x_304; +} +} +else +{ +lean_object* x_305; lean_object* x_306; lean_object* x_307; lean_object* x_308; lean_object* x_309; lean_object* x_310; lean_object* x_311; lean_object* x_312; lean_object* x_313; lean_object* x_314; lean_object* x_315; lean_object* x_316; lean_object* x_317; +x_305 = lean_ctor_get(x_265, 0); +x_306 = lean_ctor_get(x_265, 1); +x_307 = lean_ctor_get(x_265, 3); +x_308 = lean_ctor_get(x_265, 4); +x_309 = lean_ctor_get(x_265, 5); +lean_inc(x_309); +lean_inc(x_308); +lean_inc(x_307); +lean_inc(x_306); +lean_inc(x_305); +lean_dec(x_265); +x_310 = lean_ctor_get(x_292, 0); +lean_inc(x_310); +x_311 = lean_ctor_get(x_292, 1); +lean_inc(x_311); +x_312 = lean_ctor_get(x_292, 3); +lean_inc(x_312); +x_313 = lean_ctor_get(x_292, 4); +lean_inc(x_313); +if (lean_is_exclusive(x_292)) { + lean_ctor_release(x_292, 0); + lean_ctor_release(x_292, 1); + lean_ctor_release(x_292, 2); + lean_ctor_release(x_292, 3); + lean_ctor_release(x_292, 4); + x_314 = x_292; } else { - x_301 = x_300; + lean_dec_ref(x_292); + x_314 = lean_box(0); } -lean_ctor_set(x_301, 0, x_297); -lean_ctor_set(x_301, 1, x_298); -lean_ctor_set(x_301, 2, x_253); -lean_ctor_set(x_301, 3, x_299); -x_302 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_302, 0, x_292); -lean_ctor_set(x_302, 1, x_293); -lean_ctor_set(x_302, 2, x_301); -lean_ctor_set(x_302, 3, x_294); -lean_ctor_set(x_302, 4, x_295); -lean_ctor_set(x_302, 5, x_296); -if (lean_is_scalar(x_246)) { - x_303 = lean_alloc_ctor(0, 2, 0); +if (lean_is_scalar(x_314)) { + x_315 = lean_alloc_ctor(0, 5, 0); } else { - x_303 = x_246; + x_315 = x_314; } -lean_ctor_set(x_303, 0, x_281); -lean_ctor_set(x_303, 1, x_302); -return x_303; +lean_ctor_set(x_315, 0, x_310); +lean_ctor_set(x_315, 1, x_311); +lean_ctor_set(x_315, 2, x_263); +lean_ctor_set(x_315, 3, x_312); +lean_ctor_set(x_315, 4, x_313); +x_316 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_316, 0, x_305); +lean_ctor_set(x_316, 1, x_306); +lean_ctor_set(x_316, 2, x_315); +lean_ctor_set(x_316, 3, x_307); +lean_ctor_set(x_316, 4, x_308); +lean_ctor_set(x_316, 5, x_309); +if (lean_is_scalar(x_256)) { + x_317 = lean_alloc_ctor(0, 2, 0); +} else { + x_317 = x_256; +} +lean_ctor_set(x_317, 0, x_293); +lean_ctor_set(x_317, 1, x_316); +return x_317; } } } } else { -lean_object* x_332; lean_object* x_333; lean_object* x_334; lean_object* x_335; lean_object* x_336; lean_object* x_337; lean_object* x_369; lean_object* x_370; lean_object* x_371; lean_object* x_372; lean_object* x_373; lean_object* x_374; lean_object* x_375; lean_object* x_376; lean_object* x_377; lean_object* x_378; lean_object* x_379; lean_object* x_380; -x_332 = lean_ctor_get(x_251, 0); -x_333 = lean_ctor_get(x_251, 1); -x_334 = lean_ctor_get(x_251, 2); -x_335 = lean_ctor_get(x_251, 3); -lean_inc(x_335); -lean_inc(x_334); -lean_inc(x_333); -lean_inc(x_332); -lean_dec(x_251); -x_369 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_370 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_370, 0, x_332); -lean_ctor_set(x_370, 1, x_333); -lean_ctor_set(x_370, 2, x_369); -lean_ctor_set(x_370, 3, x_335); -lean_ctor_set(x_245, 2, x_370); -x_371 = lean_ctor_get(x_13, 0); -lean_inc(x_371); -x_372 = lean_ctor_get(x_13, 1); -lean_inc(x_372); -x_373 = lean_ctor_get(x_13, 2); -lean_inc(x_373); -x_374 = lean_ctor_get(x_13, 3); -lean_inc(x_374); -x_375 = lean_ctor_get(x_13, 4); -lean_inc(x_375); +lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; lean_object* x_350; lean_object* x_351; lean_object* x_352; lean_object* x_386; lean_object* x_387; lean_object* x_388; lean_object* x_389; lean_object* x_390; lean_object* x_391; lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; +x_346 = lean_ctor_get(x_261, 0); +x_347 = lean_ctor_get(x_261, 1); +x_348 = lean_ctor_get(x_261, 2); +x_349 = lean_ctor_get(x_261, 3); +x_350 = lean_ctor_get(x_261, 4); +lean_inc(x_350); +lean_inc(x_349); +lean_inc(x_348); +lean_inc(x_347); +lean_inc(x_346); +lean_dec(x_261); +x_386 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_387 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_387, 0, x_346); +lean_ctor_set(x_387, 1, x_347); +lean_ctor_set(x_387, 2, x_386); +lean_ctor_set(x_387, 3, x_349); +lean_ctor_set(x_387, 4, x_350); +lean_ctor_set(x_255, 2, x_387); +x_388 = lean_ctor_get(x_13, 0); +lean_inc(x_388); +x_389 = lean_ctor_get(x_13, 1); +lean_inc(x_389); +x_390 = lean_ctor_get(x_13, 2); +lean_inc(x_390); +x_391 = lean_ctor_get(x_13, 3); +lean_inc(x_391); +x_392 = lean_ctor_get(x_13, 4); +lean_inc(x_392); if (lean_is_exclusive(x_13)) { lean_ctor_release(x_13, 0); lean_ctor_release(x_13, 1); lean_ctor_release(x_13, 2); lean_ctor_release(x_13, 3); lean_ctor_release(x_13, 4); - x_376 = x_13; + x_393 = x_13; } else { lean_dec_ref(x_13); - x_376 = lean_box(0); + x_393 = lean_box(0); } -x_377 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_377, 0, x_247); -lean_ctor_set(x_377, 1, x_22); -x_378 = lean_array_push(x_373, x_377); -if (lean_is_scalar(x_376)) { - x_379 = lean_alloc_ctor(0, 5, 0); +x_394 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_394, 0, x_257); +lean_ctor_set(x_394, 1, x_22); +x_395 = lean_array_push(x_390, x_394); +if (lean_is_scalar(x_393)) { + x_396 = lean_alloc_ctor(0, 5, 0); } else { - x_379 = x_376; + x_396 = x_393; } -lean_ctor_set(x_379, 0, x_371); -lean_ctor_set(x_379, 1, x_372); -lean_ctor_set(x_379, 2, x_378); -lean_ctor_set(x_379, 3, x_374); -lean_ctor_set(x_379, 4, x_375); -x_380 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_ExprDefEq_18__processConstApprox___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_249, x_379, x_245); -if (lean_obj_tag(x_380) == 0) +lean_ctor_set(x_396, 0, x_388); +lean_ctor_set(x_396, 1, x_389); +lean_ctor_set(x_396, 2, x_395); +lean_ctor_set(x_396, 3, x_391); +lean_ctor_set(x_396, 4, x_392); +x_397 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_ExprDefEq_18__processConstApprox___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_259, x_396, x_255); +if (lean_obj_tag(x_397) == 0) { -lean_object* x_381; lean_object* x_382; lean_object* x_383; -x_381 = lean_ctor_get(x_380, 0); -lean_inc(x_381); -x_382 = lean_ctor_get(x_380, 1); -lean_inc(x_382); -lean_dec(x_380); -x_383 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_383, 0, x_381); -x_336 = x_383; -x_337 = x_382; -goto block_368; +lean_object* x_398; lean_object* x_399; lean_object* x_400; +x_398 = lean_ctor_get(x_397, 0); +lean_inc(x_398); +x_399 = lean_ctor_get(x_397, 1); +lean_inc(x_399); +lean_dec(x_397); +x_400 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_400, 0, x_398); +x_351 = x_400; +x_352 = x_399; +goto block_385; } else { -lean_object* x_384; lean_object* x_385; lean_object* x_386; -x_384 = lean_ctor_get(x_380, 0); -lean_inc(x_384); -x_385 = lean_ctor_get(x_380, 1); -lean_inc(x_385); -lean_dec(x_380); -x_386 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_386, 0, x_384); -x_336 = x_386; -x_337 = x_385; -goto block_368; +lean_object* x_401; lean_object* x_402; lean_object* x_403; +x_401 = lean_ctor_get(x_397, 0); +lean_inc(x_401); +x_402 = lean_ctor_get(x_397, 1); +lean_inc(x_402); +lean_dec(x_397); +x_403 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_403, 0, x_401); +x_351 = x_403; +x_352 = x_402; +goto block_385; } -block_368: +block_385: { -if (lean_obj_tag(x_336) == 0) +if (lean_obj_tag(x_351) == 0) { -lean_object* x_338; lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; lean_object* x_350; lean_object* x_351; lean_object* x_352; -x_338 = lean_ctor_get(x_337, 2); -lean_inc(x_338); -x_339 = lean_ctor_get(x_336, 0); -lean_inc(x_339); -lean_dec(x_336); -x_340 = lean_ctor_get(x_337, 0); -lean_inc(x_340); -x_341 = lean_ctor_get(x_337, 1); -lean_inc(x_341); -x_342 = lean_ctor_get(x_337, 3); -lean_inc(x_342); -x_343 = lean_ctor_get(x_337, 4); -lean_inc(x_343); -x_344 = lean_ctor_get(x_337, 5); -lean_inc(x_344); -if (lean_is_exclusive(x_337)) { - lean_ctor_release(x_337, 0); - lean_ctor_release(x_337, 1); - lean_ctor_release(x_337, 2); - lean_ctor_release(x_337, 3); - lean_ctor_release(x_337, 4); - lean_ctor_release(x_337, 5); - x_345 = x_337; -} else { - lean_dec_ref(x_337); - x_345 = lean_box(0); -} -x_346 = lean_ctor_get(x_338, 0); -lean_inc(x_346); -x_347 = lean_ctor_get(x_338, 1); -lean_inc(x_347); -x_348 = lean_ctor_get(x_338, 3); -lean_inc(x_348); -if (lean_is_exclusive(x_338)) { - lean_ctor_release(x_338, 0); - lean_ctor_release(x_338, 1); - lean_ctor_release(x_338, 2); - lean_ctor_release(x_338, 3); - x_349 = x_338; -} else { - lean_dec_ref(x_338); - x_349 = lean_box(0); -} -if (lean_is_scalar(x_349)) { - x_350 = lean_alloc_ctor(0, 4, 0); -} else { - x_350 = x_349; -} -lean_ctor_set(x_350, 0, x_346); -lean_ctor_set(x_350, 1, x_347); -lean_ctor_set(x_350, 2, x_334); -lean_ctor_set(x_350, 3, x_348); -if (lean_is_scalar(x_345)) { - x_351 = lean_alloc_ctor(0, 6, 0); -} else { - x_351 = x_345; -} -lean_ctor_set(x_351, 0, x_340); -lean_ctor_set(x_351, 1, x_341); -lean_ctor_set(x_351, 2, x_350); -lean_ctor_set(x_351, 3, x_342); -lean_ctor_set(x_351, 4, x_343); -lean_ctor_set(x_351, 5, x_344); -if (lean_is_scalar(x_246)) { - x_352 = lean_alloc_ctor(1, 2, 0); -} else { - x_352 = x_246; - lean_ctor_set_tag(x_352, 1); -} -lean_ctor_set(x_352, 0, x_339); -lean_ctor_set(x_352, 1, x_351); -return x_352; -} -else -{ -lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; 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; -x_353 = lean_ctor_get(x_337, 2); +lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; 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; +x_353 = lean_ctor_get(x_352, 2); lean_inc(x_353); -x_354 = lean_ctor_get(x_336, 0); +x_354 = lean_ctor_get(x_351, 0); lean_inc(x_354); -lean_dec(x_336); -x_355 = lean_ctor_get(x_337, 0); +lean_dec(x_351); +x_355 = lean_ctor_get(x_352, 0); lean_inc(x_355); -x_356 = lean_ctor_get(x_337, 1); +x_356 = lean_ctor_get(x_352, 1); lean_inc(x_356); -x_357 = lean_ctor_get(x_337, 3); +x_357 = lean_ctor_get(x_352, 3); lean_inc(x_357); -x_358 = lean_ctor_get(x_337, 4); +x_358 = lean_ctor_get(x_352, 4); lean_inc(x_358); -x_359 = lean_ctor_get(x_337, 5); +x_359 = lean_ctor_get(x_352, 5); lean_inc(x_359); -if (lean_is_exclusive(x_337)) { - lean_ctor_release(x_337, 0); - lean_ctor_release(x_337, 1); - lean_ctor_release(x_337, 2); - lean_ctor_release(x_337, 3); - lean_ctor_release(x_337, 4); - lean_ctor_release(x_337, 5); - x_360 = x_337; +if (lean_is_exclusive(x_352)) { + lean_ctor_release(x_352, 0); + lean_ctor_release(x_352, 1); + lean_ctor_release(x_352, 2); + lean_ctor_release(x_352, 3); + lean_ctor_release(x_352, 4); + lean_ctor_release(x_352, 5); + x_360 = x_352; } else { - lean_dec_ref(x_337); + lean_dec_ref(x_352); x_360 = lean_box(0); } x_361 = lean_ctor_get(x_353, 0); @@ -33609,315 +33957,411 @@ x_362 = lean_ctor_get(x_353, 1); lean_inc(x_362); x_363 = lean_ctor_get(x_353, 3); lean_inc(x_363); +x_364 = lean_ctor_get(x_353, 4); +lean_inc(x_364); if (lean_is_exclusive(x_353)) { lean_ctor_release(x_353, 0); lean_ctor_release(x_353, 1); lean_ctor_release(x_353, 2); lean_ctor_release(x_353, 3); - x_364 = x_353; + lean_ctor_release(x_353, 4); + x_365 = x_353; } else { lean_dec_ref(x_353); - x_364 = lean_box(0); + x_365 = lean_box(0); } -if (lean_is_scalar(x_364)) { - x_365 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_365)) { + x_366 = lean_alloc_ctor(0, 5, 0); } else { - x_365 = x_364; + x_366 = x_365; } -lean_ctor_set(x_365, 0, x_361); -lean_ctor_set(x_365, 1, x_362); -lean_ctor_set(x_365, 2, x_334); -lean_ctor_set(x_365, 3, x_363); +lean_ctor_set(x_366, 0, x_361); +lean_ctor_set(x_366, 1, x_362); +lean_ctor_set(x_366, 2, x_348); +lean_ctor_set(x_366, 3, x_363); +lean_ctor_set(x_366, 4, x_364); if (lean_is_scalar(x_360)) { - x_366 = lean_alloc_ctor(0, 6, 0); + x_367 = lean_alloc_ctor(0, 6, 0); } else { - x_366 = x_360; + x_367 = x_360; } -lean_ctor_set(x_366, 0, x_355); -lean_ctor_set(x_366, 1, x_356); -lean_ctor_set(x_366, 2, x_365); -lean_ctor_set(x_366, 3, x_357); -lean_ctor_set(x_366, 4, x_358); -lean_ctor_set(x_366, 5, x_359); -if (lean_is_scalar(x_246)) { - x_367 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_367, 0, x_355); +lean_ctor_set(x_367, 1, x_356); +lean_ctor_set(x_367, 2, x_366); +lean_ctor_set(x_367, 3, x_357); +lean_ctor_set(x_367, 4, x_358); +lean_ctor_set(x_367, 5, x_359); +if (lean_is_scalar(x_256)) { + x_368 = lean_alloc_ctor(1, 2, 0); } else { - x_367 = x_246; + x_368 = x_256; + lean_ctor_set_tag(x_368, 1); } -lean_ctor_set(x_367, 0, x_354); -lean_ctor_set(x_367, 1, x_366); -return x_367; +lean_ctor_set(x_368, 0, x_354); +lean_ctor_set(x_368, 1, x_367); +return x_368; +} +else +{ +lean_object* x_369; lean_object* x_370; lean_object* x_371; lean_object* x_372; lean_object* x_373; lean_object* x_374; lean_object* x_375; 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; +x_369 = lean_ctor_get(x_352, 2); +lean_inc(x_369); +x_370 = lean_ctor_get(x_351, 0); +lean_inc(x_370); +lean_dec(x_351); +x_371 = lean_ctor_get(x_352, 0); +lean_inc(x_371); +x_372 = lean_ctor_get(x_352, 1); +lean_inc(x_372); +x_373 = lean_ctor_get(x_352, 3); +lean_inc(x_373); +x_374 = lean_ctor_get(x_352, 4); +lean_inc(x_374); +x_375 = lean_ctor_get(x_352, 5); +lean_inc(x_375); +if (lean_is_exclusive(x_352)) { + lean_ctor_release(x_352, 0); + lean_ctor_release(x_352, 1); + lean_ctor_release(x_352, 2); + lean_ctor_release(x_352, 3); + lean_ctor_release(x_352, 4); + lean_ctor_release(x_352, 5); + x_376 = x_352; +} else { + lean_dec_ref(x_352); + x_376 = lean_box(0); +} +x_377 = lean_ctor_get(x_369, 0); +lean_inc(x_377); +x_378 = lean_ctor_get(x_369, 1); +lean_inc(x_378); +x_379 = lean_ctor_get(x_369, 3); +lean_inc(x_379); +x_380 = lean_ctor_get(x_369, 4); +lean_inc(x_380); +if (lean_is_exclusive(x_369)) { + lean_ctor_release(x_369, 0); + lean_ctor_release(x_369, 1); + lean_ctor_release(x_369, 2); + lean_ctor_release(x_369, 3); + lean_ctor_release(x_369, 4); + x_381 = x_369; +} else { + lean_dec_ref(x_369); + x_381 = lean_box(0); +} +if (lean_is_scalar(x_381)) { + x_382 = lean_alloc_ctor(0, 5, 0); +} else { + x_382 = x_381; +} +lean_ctor_set(x_382, 0, x_377); +lean_ctor_set(x_382, 1, x_378); +lean_ctor_set(x_382, 2, x_348); +lean_ctor_set(x_382, 3, x_379); +lean_ctor_set(x_382, 4, x_380); +if (lean_is_scalar(x_376)) { + x_383 = lean_alloc_ctor(0, 6, 0); +} else { + x_383 = x_376; +} +lean_ctor_set(x_383, 0, x_371); +lean_ctor_set(x_383, 1, x_372); +lean_ctor_set(x_383, 2, x_382); +lean_ctor_set(x_383, 3, x_373); +lean_ctor_set(x_383, 4, x_374); +lean_ctor_set(x_383, 5, x_375); +if (lean_is_scalar(x_256)) { + x_384 = lean_alloc_ctor(0, 2, 0); +} else { + x_384 = x_256; +} +lean_ctor_set(x_384, 0, x_370); +lean_ctor_set(x_384, 1, x_383); +return x_384; } } } } else { -lean_object* x_387; lean_object* x_388; lean_object* x_389; lean_object* x_390; lean_object* x_391; lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; lean_object* x_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; -x_387 = lean_ctor_get(x_245, 2); -x_388 = lean_ctor_get(x_245, 0); -x_389 = lean_ctor_get(x_245, 1); -x_390 = lean_ctor_get(x_245, 3); -x_391 = lean_ctor_get(x_245, 4); -x_392 = lean_ctor_get(x_245, 5); -lean_inc(x_392); -lean_inc(x_391); -lean_inc(x_390); -lean_inc(x_387); -lean_inc(x_389); -lean_inc(x_388); -lean_dec(x_245); -x_393 = lean_ctor_get(x_387, 0); -lean_inc(x_393); -x_394 = lean_ctor_get(x_387, 1); -lean_inc(x_394); -x_395 = lean_ctor_get(x_387, 2); -lean_inc(x_395); -x_396 = lean_ctor_get(x_387, 3); -lean_inc(x_396); -if (lean_is_exclusive(x_387)) { - lean_ctor_release(x_387, 0); - lean_ctor_release(x_387, 1); - lean_ctor_release(x_387, 2); - lean_ctor_release(x_387, 3); - x_397 = x_387; +lean_object* x_404; lean_object* x_405; lean_object* x_406; lean_object* x_407; lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_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_451; lean_object* x_452; lean_object* x_453; lean_object* x_454; lean_object* x_455; lean_object* x_456; lean_object* x_457; lean_object* x_458; lean_object* x_459; lean_object* x_460; lean_object* x_461; lean_object* x_462; lean_object* x_463; +x_404 = lean_ctor_get(x_255, 2); +x_405 = lean_ctor_get(x_255, 0); +x_406 = lean_ctor_get(x_255, 1); +x_407 = lean_ctor_get(x_255, 3); +x_408 = lean_ctor_get(x_255, 4); +x_409 = lean_ctor_get(x_255, 5); +lean_inc(x_409); +lean_inc(x_408); +lean_inc(x_407); +lean_inc(x_404); +lean_inc(x_406); +lean_inc(x_405); +lean_dec(x_255); +x_410 = lean_ctor_get(x_404, 0); +lean_inc(x_410); +x_411 = lean_ctor_get(x_404, 1); +lean_inc(x_411); +x_412 = lean_ctor_get(x_404, 2); +lean_inc(x_412); +x_413 = lean_ctor_get(x_404, 3); +lean_inc(x_413); +x_414 = lean_ctor_get(x_404, 4); +lean_inc(x_414); +if (lean_is_exclusive(x_404)) { + lean_ctor_release(x_404, 0); + lean_ctor_release(x_404, 1); + lean_ctor_release(x_404, 2); + lean_ctor_release(x_404, 3); + lean_ctor_release(x_404, 4); + x_415 = x_404; } else { - lean_dec_ref(x_387); - x_397 = lean_box(0); + lean_dec_ref(x_404); + x_415 = lean_box(0); } -x_431 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_397)) { - x_432 = lean_alloc_ctor(0, 4, 0); +x_451 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_415)) { + x_452 = lean_alloc_ctor(0, 5, 0); } else { - x_432 = x_397; + x_452 = x_415; } -lean_ctor_set(x_432, 0, x_393); -lean_ctor_set(x_432, 1, x_394); -lean_ctor_set(x_432, 2, x_431); -lean_ctor_set(x_432, 3, x_396); -x_433 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_433, 0, x_388); -lean_ctor_set(x_433, 1, x_389); -lean_ctor_set(x_433, 2, x_432); -lean_ctor_set(x_433, 3, x_390); -lean_ctor_set(x_433, 4, x_391); -lean_ctor_set(x_433, 5, x_392); -x_434 = lean_ctor_get(x_13, 0); -lean_inc(x_434); -x_435 = lean_ctor_get(x_13, 1); -lean_inc(x_435); -x_436 = lean_ctor_get(x_13, 2); -lean_inc(x_436); -x_437 = lean_ctor_get(x_13, 3); -lean_inc(x_437); -x_438 = lean_ctor_get(x_13, 4); -lean_inc(x_438); +lean_ctor_set(x_452, 0, x_410); +lean_ctor_set(x_452, 1, x_411); +lean_ctor_set(x_452, 2, x_451); +lean_ctor_set(x_452, 3, x_413); +lean_ctor_set(x_452, 4, x_414); +x_453 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_453, 0, x_405); +lean_ctor_set(x_453, 1, x_406); +lean_ctor_set(x_453, 2, x_452); +lean_ctor_set(x_453, 3, x_407); +lean_ctor_set(x_453, 4, x_408); +lean_ctor_set(x_453, 5, x_409); +x_454 = lean_ctor_get(x_13, 0); +lean_inc(x_454); +x_455 = lean_ctor_get(x_13, 1); +lean_inc(x_455); +x_456 = lean_ctor_get(x_13, 2); +lean_inc(x_456); +x_457 = lean_ctor_get(x_13, 3); +lean_inc(x_457); +x_458 = lean_ctor_get(x_13, 4); +lean_inc(x_458); if (lean_is_exclusive(x_13)) { lean_ctor_release(x_13, 0); lean_ctor_release(x_13, 1); lean_ctor_release(x_13, 2); lean_ctor_release(x_13, 3); lean_ctor_release(x_13, 4); - x_439 = x_13; + x_459 = x_13; } else { lean_dec_ref(x_13); - x_439 = lean_box(0); + x_459 = lean_box(0); } -x_440 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_440, 0, x_247); -lean_ctor_set(x_440, 1, x_22); -x_441 = lean_array_push(x_436, x_440); -if (lean_is_scalar(x_439)) { - x_442 = lean_alloc_ctor(0, 5, 0); +x_460 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_460, 0, x_257); +lean_ctor_set(x_460, 1, x_22); +x_461 = lean_array_push(x_456, x_460); +if (lean_is_scalar(x_459)) { + x_462 = lean_alloc_ctor(0, 5, 0); } else { - x_442 = x_439; + x_462 = x_459; } -lean_ctor_set(x_442, 0, x_434); -lean_ctor_set(x_442, 1, x_435); -lean_ctor_set(x_442, 2, x_441); -lean_ctor_set(x_442, 3, x_437); -lean_ctor_set(x_442, 4, x_438); -x_443 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_ExprDefEq_18__processConstApprox___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_249, x_442, x_433); -if (lean_obj_tag(x_443) == 0) +lean_ctor_set(x_462, 0, x_454); +lean_ctor_set(x_462, 1, x_455); +lean_ctor_set(x_462, 2, x_461); +lean_ctor_set(x_462, 3, x_457); +lean_ctor_set(x_462, 4, x_458); +x_463 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_ExprDefEq_18__processConstApprox___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_259, x_462, x_453); +if (lean_obj_tag(x_463) == 0) { -lean_object* x_444; lean_object* x_445; lean_object* x_446; -x_444 = lean_ctor_get(x_443, 0); -lean_inc(x_444); -x_445 = lean_ctor_get(x_443, 1); -lean_inc(x_445); -lean_dec(x_443); -x_446 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_446, 0, x_444); -x_398 = x_446; -x_399 = x_445; -goto block_430; +lean_object* x_464; lean_object* x_465; lean_object* x_466; +x_464 = lean_ctor_get(x_463, 0); +lean_inc(x_464); +x_465 = lean_ctor_get(x_463, 1); +lean_inc(x_465); +lean_dec(x_463); +x_466 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_466, 0, x_464); +x_416 = x_466; +x_417 = x_465; +goto block_450; } else { -lean_object* x_447; lean_object* x_448; lean_object* x_449; -x_447 = lean_ctor_get(x_443, 0); -lean_inc(x_447); -x_448 = lean_ctor_get(x_443, 1); -lean_inc(x_448); -lean_dec(x_443); -x_449 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_449, 0, x_447); -x_398 = x_449; -x_399 = x_448; -goto block_430; +lean_object* x_467; lean_object* x_468; lean_object* x_469; +x_467 = lean_ctor_get(x_463, 0); +lean_inc(x_467); +x_468 = lean_ctor_get(x_463, 1); +lean_inc(x_468); +lean_dec(x_463); +x_469 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_469, 0, x_467); +x_416 = x_469; +x_417 = x_468; +goto block_450; } -block_430: +block_450: { -if (lean_obj_tag(x_398) == 0) +if (lean_obj_tag(x_416) == 0) { -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; lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_object* x_412; lean_object* x_413; lean_object* x_414; -x_400 = lean_ctor_get(x_399, 2); -lean_inc(x_400); -x_401 = lean_ctor_get(x_398, 0); -lean_inc(x_401); -lean_dec(x_398); -x_402 = lean_ctor_get(x_399, 0); -lean_inc(x_402); -x_403 = lean_ctor_get(x_399, 1); -lean_inc(x_403); -x_404 = lean_ctor_get(x_399, 3); -lean_inc(x_404); -x_405 = lean_ctor_get(x_399, 4); -lean_inc(x_405); -x_406 = lean_ctor_get(x_399, 5); -lean_inc(x_406); -if (lean_is_exclusive(x_399)) { - lean_ctor_release(x_399, 0); - lean_ctor_release(x_399, 1); - lean_ctor_release(x_399, 2); - lean_ctor_release(x_399, 3); - lean_ctor_release(x_399, 4); - lean_ctor_release(x_399, 5); - x_407 = x_399; -} else { - lean_dec_ref(x_399); - x_407 = lean_box(0); -} -x_408 = lean_ctor_get(x_400, 0); -lean_inc(x_408); -x_409 = lean_ctor_get(x_400, 1); -lean_inc(x_409); -x_410 = lean_ctor_get(x_400, 3); -lean_inc(x_410); -if (lean_is_exclusive(x_400)) { - lean_ctor_release(x_400, 0); - lean_ctor_release(x_400, 1); - lean_ctor_release(x_400, 2); - lean_ctor_release(x_400, 3); - x_411 = x_400; -} else { - lean_dec_ref(x_400); - x_411 = lean_box(0); -} -if (lean_is_scalar(x_411)) { - x_412 = lean_alloc_ctor(0, 4, 0); -} else { - x_412 = x_411; -} -lean_ctor_set(x_412, 0, x_408); -lean_ctor_set(x_412, 1, x_409); -lean_ctor_set(x_412, 2, x_395); -lean_ctor_set(x_412, 3, x_410); -if (lean_is_scalar(x_407)) { - x_413 = lean_alloc_ctor(0, 6, 0); -} else { - x_413 = x_407; -} -lean_ctor_set(x_413, 0, x_402); -lean_ctor_set(x_413, 1, x_403); -lean_ctor_set(x_413, 2, x_412); -lean_ctor_set(x_413, 3, x_404); -lean_ctor_set(x_413, 4, x_405); -lean_ctor_set(x_413, 5, x_406); -if (lean_is_scalar(x_246)) { - x_414 = lean_alloc_ctor(1, 2, 0); -} else { - x_414 = x_246; - lean_ctor_set_tag(x_414, 1); -} -lean_ctor_set(x_414, 0, x_401); -lean_ctor_set(x_414, 1, x_413); -return x_414; -} -else -{ -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; lean_object* x_426; lean_object* x_427; lean_object* x_428; lean_object* x_429; -x_415 = lean_ctor_get(x_399, 2); -lean_inc(x_415); -x_416 = lean_ctor_get(x_398, 0); -lean_inc(x_416); -lean_dec(x_398); -x_417 = lean_ctor_get(x_399, 0); -lean_inc(x_417); -x_418 = lean_ctor_get(x_399, 1); +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; lean_object* x_426; lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; lean_object* x_432; lean_object* x_433; +x_418 = lean_ctor_get(x_417, 2); lean_inc(x_418); -x_419 = lean_ctor_get(x_399, 3); +x_419 = lean_ctor_get(x_416, 0); lean_inc(x_419); -x_420 = lean_ctor_get(x_399, 4); +lean_dec(x_416); +x_420 = lean_ctor_get(x_417, 0); lean_inc(x_420); -x_421 = lean_ctor_get(x_399, 5); +x_421 = lean_ctor_get(x_417, 1); lean_inc(x_421); -if (lean_is_exclusive(x_399)) { - lean_ctor_release(x_399, 0); - lean_ctor_release(x_399, 1); - lean_ctor_release(x_399, 2); - lean_ctor_release(x_399, 3); - lean_ctor_release(x_399, 4); - lean_ctor_release(x_399, 5); - x_422 = x_399; -} else { - lean_dec_ref(x_399); - x_422 = lean_box(0); -} -x_423 = lean_ctor_get(x_415, 0); +x_422 = lean_ctor_get(x_417, 3); +lean_inc(x_422); +x_423 = lean_ctor_get(x_417, 4); lean_inc(x_423); -x_424 = lean_ctor_get(x_415, 1); +x_424 = lean_ctor_get(x_417, 5); lean_inc(x_424); -x_425 = lean_ctor_get(x_415, 3); -lean_inc(x_425); -if (lean_is_exclusive(x_415)) { - lean_ctor_release(x_415, 0); - lean_ctor_release(x_415, 1); - lean_ctor_release(x_415, 2); - lean_ctor_release(x_415, 3); - x_426 = x_415; +if (lean_is_exclusive(x_417)) { + lean_ctor_release(x_417, 0); + lean_ctor_release(x_417, 1); + lean_ctor_release(x_417, 2); + lean_ctor_release(x_417, 3); + lean_ctor_release(x_417, 4); + lean_ctor_release(x_417, 5); + x_425 = x_417; } else { - lean_dec_ref(x_415); - x_426 = lean_box(0); + lean_dec_ref(x_417); + x_425 = lean_box(0); } -if (lean_is_scalar(x_426)) { - x_427 = lean_alloc_ctor(0, 4, 0); +x_426 = lean_ctor_get(x_418, 0); +lean_inc(x_426); +x_427 = lean_ctor_get(x_418, 1); +lean_inc(x_427); +x_428 = lean_ctor_get(x_418, 3); +lean_inc(x_428); +x_429 = lean_ctor_get(x_418, 4); +lean_inc(x_429); +if (lean_is_exclusive(x_418)) { + lean_ctor_release(x_418, 0); + lean_ctor_release(x_418, 1); + lean_ctor_release(x_418, 2); + lean_ctor_release(x_418, 3); + lean_ctor_release(x_418, 4); + x_430 = x_418; } else { - x_427 = x_426; + lean_dec_ref(x_418); + x_430 = lean_box(0); } -lean_ctor_set(x_427, 0, x_423); -lean_ctor_set(x_427, 1, x_424); -lean_ctor_set(x_427, 2, x_395); -lean_ctor_set(x_427, 3, x_425); -if (lean_is_scalar(x_422)) { - x_428 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_430)) { + x_431 = lean_alloc_ctor(0, 5, 0); } else { - x_428 = x_422; + x_431 = x_430; } -lean_ctor_set(x_428, 0, x_417); -lean_ctor_set(x_428, 1, x_418); -lean_ctor_set(x_428, 2, x_427); -lean_ctor_set(x_428, 3, x_419); -lean_ctor_set(x_428, 4, x_420); -lean_ctor_set(x_428, 5, x_421); -if (lean_is_scalar(x_246)) { - x_429 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_431, 0, x_426); +lean_ctor_set(x_431, 1, x_427); +lean_ctor_set(x_431, 2, x_412); +lean_ctor_set(x_431, 3, x_428); +lean_ctor_set(x_431, 4, x_429); +if (lean_is_scalar(x_425)) { + x_432 = lean_alloc_ctor(0, 6, 0); } else { - x_429 = x_246; + x_432 = x_425; } -lean_ctor_set(x_429, 0, x_416); -lean_ctor_set(x_429, 1, x_428); -return x_429; +lean_ctor_set(x_432, 0, x_420); +lean_ctor_set(x_432, 1, x_421); +lean_ctor_set(x_432, 2, x_431); +lean_ctor_set(x_432, 3, x_422); +lean_ctor_set(x_432, 4, x_423); +lean_ctor_set(x_432, 5, x_424); +if (lean_is_scalar(x_256)) { + x_433 = lean_alloc_ctor(1, 2, 0); +} else { + x_433 = x_256; + lean_ctor_set_tag(x_433, 1); +} +lean_ctor_set(x_433, 0, x_419); +lean_ctor_set(x_433, 1, x_432); +return x_433; +} +else +{ +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; lean_object* x_445; lean_object* x_446; lean_object* x_447; lean_object* x_448; lean_object* x_449; +x_434 = lean_ctor_get(x_417, 2); +lean_inc(x_434); +x_435 = lean_ctor_get(x_416, 0); +lean_inc(x_435); +lean_dec(x_416); +x_436 = lean_ctor_get(x_417, 0); +lean_inc(x_436); +x_437 = lean_ctor_get(x_417, 1); +lean_inc(x_437); +x_438 = lean_ctor_get(x_417, 3); +lean_inc(x_438); +x_439 = lean_ctor_get(x_417, 4); +lean_inc(x_439); +x_440 = lean_ctor_get(x_417, 5); +lean_inc(x_440); +if (lean_is_exclusive(x_417)) { + lean_ctor_release(x_417, 0); + lean_ctor_release(x_417, 1); + lean_ctor_release(x_417, 2); + lean_ctor_release(x_417, 3); + lean_ctor_release(x_417, 4); + lean_ctor_release(x_417, 5); + x_441 = x_417; +} else { + lean_dec_ref(x_417); + x_441 = lean_box(0); +} +x_442 = lean_ctor_get(x_434, 0); +lean_inc(x_442); +x_443 = lean_ctor_get(x_434, 1); +lean_inc(x_443); +x_444 = lean_ctor_get(x_434, 3); +lean_inc(x_444); +x_445 = lean_ctor_get(x_434, 4); +lean_inc(x_445); +if (lean_is_exclusive(x_434)) { + lean_ctor_release(x_434, 0); + lean_ctor_release(x_434, 1); + lean_ctor_release(x_434, 2); + lean_ctor_release(x_434, 3); + lean_ctor_release(x_434, 4); + x_446 = x_434; +} else { + lean_dec_ref(x_434); + x_446 = lean_box(0); +} +if (lean_is_scalar(x_446)) { + x_447 = lean_alloc_ctor(0, 5, 0); +} else { + x_447 = x_446; +} +lean_ctor_set(x_447, 0, x_442); +lean_ctor_set(x_447, 1, x_443); +lean_ctor_set(x_447, 2, x_412); +lean_ctor_set(x_447, 3, x_444); +lean_ctor_set(x_447, 4, x_445); +if (lean_is_scalar(x_441)) { + x_448 = lean_alloc_ctor(0, 6, 0); +} else { + x_448 = x_441; +} +lean_ctor_set(x_448, 0, x_436); +lean_ctor_set(x_448, 1, x_437); +lean_ctor_set(x_448, 2, x_447); +lean_ctor_set(x_448, 3, x_438); +lean_ctor_set(x_448, 4, x_439); +lean_ctor_set(x_448, 5, x_440); +if (lean_is_scalar(x_256)) { + x_449 = lean_alloc_ctor(0, 2, 0); +} else { + x_449 = x_256; +} +lean_ctor_set(x_449, 0, x_435); +lean_ctor_set(x_449, 1, x_448); +return x_449; } } } @@ -33925,7 +34369,7 @@ return x_429; } else { -uint8_t x_450; +uint8_t x_470; lean_dec(x_22); lean_dec(x_13); lean_dec(x_12); @@ -33936,23 +34380,23 @@ lean_dec(x_5); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_450 = !lean_is_exclusive(x_239); -if (x_450 == 0) +x_470 = !lean_is_exclusive(x_249); +if (x_470 == 0) { -return x_239; +return x_249; } else { -lean_object* x_451; lean_object* x_452; lean_object* x_453; -x_451 = lean_ctor_get(x_239, 0); -x_452 = lean_ctor_get(x_239, 1); -lean_inc(x_452); -lean_inc(x_451); -lean_dec(x_239); -x_453 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_453, 0, x_451); -lean_ctor_set(x_453, 1, x_452); -return x_453; +lean_object* x_471; lean_object* x_472; lean_object* x_473; +x_471 = lean_ctor_get(x_249, 0); +x_472 = lean_ctor_get(x_249, 1); +lean_inc(x_472); +lean_inc(x_471); +lean_dec(x_249); +x_473 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_473, 0, x_471); +lean_ctor_set(x_473, 1, x_472); +return x_473; } } } @@ -33960,7 +34404,7 @@ return x_453; } else { -uint8_t x_454; +uint8_t x_474; lean_dec(x_26); lean_dec(x_22); lean_dec(x_13); @@ -33972,29 +34416,29 @@ lean_dec(x_5); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_454 = !lean_is_exclusive(x_27); -if (x_454 == 0) +x_474 = !lean_is_exclusive(x_27); +if (x_474 == 0) { return x_27; } else { -lean_object* x_455; lean_object* x_456; lean_object* x_457; -x_455 = lean_ctor_get(x_27, 0); -x_456 = lean_ctor_get(x_27, 1); -lean_inc(x_456); -lean_inc(x_455); +lean_object* x_475; lean_object* x_476; lean_object* x_477; +x_475 = lean_ctor_get(x_27, 0); +x_476 = lean_ctor_get(x_27, 1); +lean_inc(x_476); +lean_inc(x_475); lean_dec(x_27); -x_457 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_457, 0, x_455); -lean_ctor_set(x_457, 1, x_456); -return x_457; +x_477 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_477, 0, x_475); +lean_ctor_set(x_477, 1, x_476); +return x_477; } } } else { -uint8_t x_458; +uint8_t x_478; lean_dec(x_22); lean_dec(x_13); lean_dec(x_12); @@ -34005,23 +34449,23 @@ lean_dec(x_5); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_458 = !lean_is_exclusive(x_23); -if (x_458 == 0) +x_478 = !lean_is_exclusive(x_23); +if (x_478 == 0) { return x_23; } else { -lean_object* x_459; lean_object* x_460; lean_object* x_461; -x_459 = lean_ctor_get(x_23, 0); -x_460 = lean_ctor_get(x_23, 1); -lean_inc(x_460); -lean_inc(x_459); +lean_object* x_479; lean_object* x_480; lean_object* x_481; +x_479 = lean_ctor_get(x_23, 0); +x_480 = lean_ctor_get(x_23, 1); +lean_inc(x_480); +lean_inc(x_479); lean_dec(x_23); -x_461 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_461, 0, x_459); -lean_ctor_set(x_461, 1, x_460); -return x_461; +x_481 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_481, 0, x_479); +lean_ctor_set(x_481, 1, x_480); +return x_481; } } } @@ -34163,105 +34607,105 @@ x_41 = lean_ctor_get(x_35, 2); x_42 = !lean_is_exclusive(x_41); if (x_42 == 0) { -lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_95; uint8_t x_96; +lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_99; uint8_t x_100; x_43 = lean_ctor_get(x_41, 2); -x_95 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_41, 2, x_95); -x_96 = !lean_is_exclusive(x_8); -if (x_96 == 0) +x_99 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_41, 2, x_99); +x_100 = !lean_is_exclusive(x_8); +if (x_100 == 0) { -lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; -x_97 = lean_ctor_get(x_8, 2); -x_98 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_98, 0, x_37); -lean_ctor_set(x_98, 1, x_24); -x_99 = lean_array_push(x_97, x_98); -lean_ctor_set(x_8, 2, x_99); -x_100 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_ExprDefEq_18__processConstApprox___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_39, x_8, x_35); -if (lean_obj_tag(x_100) == 0) +lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; +x_101 = lean_ctor_get(x_8, 2); +x_102 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_102, 0, x_37); +lean_ctor_set(x_102, 1, x_24); +x_103 = lean_array_push(x_101, x_102); +lean_ctor_set(x_8, 2, x_103); +x_104 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_ExprDefEq_18__processConstApprox___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_39, x_8, x_35); +if (lean_obj_tag(x_104) == 0) { -lean_object* x_101; lean_object* x_102; lean_object* x_103; -x_101 = lean_ctor_get(x_100, 0); -lean_inc(x_101); -x_102 = lean_ctor_get(x_100, 1); -lean_inc(x_102); -lean_dec(x_100); -x_103 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_103, 0, x_101); -x_44 = x_103; -x_45 = x_102; -goto block_94; -} -else -{ -lean_object* x_104; lean_object* x_105; lean_object* x_106; -x_104 = lean_ctor_get(x_100, 0); -lean_inc(x_104); -x_105 = lean_ctor_get(x_100, 1); +lean_object* x_105; lean_object* x_106; lean_object* x_107; +x_105 = lean_ctor_get(x_104, 0); lean_inc(x_105); -lean_dec(x_100); -x_106 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_106, 0, x_104); -x_44 = x_106; -x_45 = x_105; -goto block_94; -} +x_106 = lean_ctor_get(x_104, 1); +lean_inc(x_106); +lean_dec(x_104); +x_107 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_107, 0, x_105); +x_44 = x_107; +x_45 = x_106; +goto block_98; } else { -lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; -x_107 = lean_ctor_get(x_8, 0); -x_108 = lean_ctor_get(x_8, 1); -x_109 = lean_ctor_get(x_8, 2); -x_110 = lean_ctor_get(x_8, 3); -x_111 = lean_ctor_get(x_8, 4); -lean_inc(x_111); -lean_inc(x_110); -lean_inc(x_109); +lean_object* x_108; lean_object* x_109; lean_object* x_110; +x_108 = lean_ctor_get(x_104, 0); lean_inc(x_108); -lean_inc(x_107); -lean_dec(x_8); -x_112 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_112, 0, x_37); -lean_ctor_set(x_112, 1, x_24); -x_113 = lean_array_push(x_109, x_112); -x_114 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_114, 0, x_107); -lean_ctor_set(x_114, 1, x_108); -lean_ctor_set(x_114, 2, x_113); -lean_ctor_set(x_114, 3, x_110); -lean_ctor_set(x_114, 4, x_111); -x_115 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_ExprDefEq_18__processConstApprox___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_39, x_114, x_35); -if (lean_obj_tag(x_115) == 0) -{ -lean_object* x_116; lean_object* x_117; lean_object* x_118; -x_116 = lean_ctor_get(x_115, 0); -lean_inc(x_116); -x_117 = lean_ctor_get(x_115, 1); -lean_inc(x_117); -lean_dec(x_115); -x_118 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_118, 0, x_116); -x_44 = x_118; -x_45 = x_117; -goto block_94; +x_109 = lean_ctor_get(x_104, 1); +lean_inc(x_109); +lean_dec(x_104); +x_110 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_110, 0, x_108); +x_44 = x_110; +x_45 = x_109; +goto block_98; +} } else { -lean_object* x_119; lean_object* x_120; lean_object* x_121; -x_119 = lean_ctor_get(x_115, 0); -lean_inc(x_119); -x_120 = lean_ctor_get(x_115, 1); +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; +x_111 = lean_ctor_get(x_8, 0); +x_112 = lean_ctor_get(x_8, 1); +x_113 = lean_ctor_get(x_8, 2); +x_114 = lean_ctor_get(x_8, 3); +x_115 = lean_ctor_get(x_8, 4); +lean_inc(x_115); +lean_inc(x_114); +lean_inc(x_113); +lean_inc(x_112); +lean_inc(x_111); +lean_dec(x_8); +x_116 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_116, 0, x_37); +lean_ctor_set(x_116, 1, x_24); +x_117 = lean_array_push(x_113, x_116); +x_118 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_118, 0, x_111); +lean_ctor_set(x_118, 1, x_112); +lean_ctor_set(x_118, 2, x_117); +lean_ctor_set(x_118, 3, x_114); +lean_ctor_set(x_118, 4, x_115); +x_119 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_ExprDefEq_18__processConstApprox___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_39, x_118, x_35); +if (lean_obj_tag(x_119) == 0) +{ +lean_object* x_120; lean_object* x_121; lean_object* x_122; +x_120 = lean_ctor_get(x_119, 0); lean_inc(x_120); -lean_dec(x_115); -x_121 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_121, 0, x_119); -x_44 = x_121; -x_45 = x_120; -goto block_94; +x_121 = lean_ctor_get(x_119, 1); +lean_inc(x_121); +lean_dec(x_119); +x_122 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_122, 0, x_120); +x_44 = x_122; +x_45 = x_121; +goto block_98; +} +else +{ +lean_object* x_123; lean_object* x_124; lean_object* x_125; +x_123 = lean_ctor_get(x_119, 0); +lean_inc(x_123); +x_124 = lean_ctor_get(x_119, 1); +lean_inc(x_124); +lean_dec(x_119); +x_125 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_125, 0, x_123); +x_44 = x_125; +x_45 = x_124; +goto block_98; } } -block_94: +block_98: { if (lean_obj_tag(x_44) == 0) { @@ -34296,1284 +34740,1262 @@ 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_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; x_53 = lean_ctor_get(x_46, 0); x_54 = lean_ctor_get(x_46, 1); x_55 = lean_ctor_get(x_46, 3); +x_56 = lean_ctor_get(x_46, 4); +lean_inc(x_56); lean_inc(x_55); lean_inc(x_54); lean_inc(x_53); lean_dec(x_46); -x_56 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_56, 0, x_53); -lean_ctor_set(x_56, 1, x_54); -lean_ctor_set(x_56, 2, x_43); -lean_ctor_set(x_56, 3, x_55); -lean_ctor_set(x_45, 2, x_56); +x_57 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_57, 0, x_53); +lean_ctor_set(x_57, 1, x_54); +lean_ctor_set(x_57, 2, x_43); +lean_ctor_set(x_57, 3, x_55); +lean_ctor_set(x_57, 4, x_56); +lean_ctor_set(x_45, 2, x_57); if (lean_is_scalar(x_36)) { - x_57 = lean_alloc_ctor(1, 2, 0); + x_58 = lean_alloc_ctor(1, 2, 0); } else { - x_57 = x_36; - lean_ctor_set_tag(x_57, 1); + x_58 = x_36; + lean_ctor_set_tag(x_58, 1); } -lean_ctor_set(x_57, 0, x_47); -lean_ctor_set(x_57, 1, x_45); -return x_57; +lean_ctor_set(x_58, 0, x_47); +lean_ctor_set(x_58, 1, x_45); +return x_58; } } else { -lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; -x_58 = lean_ctor_get(x_45, 0); -x_59 = lean_ctor_get(x_45, 1); -x_60 = lean_ctor_get(x_45, 3); -x_61 = lean_ctor_get(x_45, 4); -x_62 = lean_ctor_get(x_45, 5); +lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; +x_59 = lean_ctor_get(x_45, 0); +x_60 = lean_ctor_get(x_45, 1); +x_61 = lean_ctor_get(x_45, 3); +x_62 = lean_ctor_get(x_45, 4); +x_63 = lean_ctor_get(x_45, 5); +lean_inc(x_63); lean_inc(x_62); lean_inc(x_61); lean_inc(x_60); lean_inc(x_59); -lean_inc(x_58); lean_dec(x_45); -x_63 = lean_ctor_get(x_46, 0); -lean_inc(x_63); -x_64 = lean_ctor_get(x_46, 1); +x_64 = lean_ctor_get(x_46, 0); lean_inc(x_64); -x_65 = lean_ctor_get(x_46, 3); +x_65 = lean_ctor_get(x_46, 1); lean_inc(x_65); +x_66 = lean_ctor_get(x_46, 3); +lean_inc(x_66); +x_67 = lean_ctor_get(x_46, 4); +lean_inc(x_67); if (lean_is_exclusive(x_46)) { lean_ctor_release(x_46, 0); lean_ctor_release(x_46, 1); lean_ctor_release(x_46, 2); lean_ctor_release(x_46, 3); - x_66 = x_46; + lean_ctor_release(x_46, 4); + x_68 = x_46; } else { lean_dec_ref(x_46); - x_66 = lean_box(0); + x_68 = lean_box(0); } -if (lean_is_scalar(x_66)) { - x_67 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_68)) { + x_69 = lean_alloc_ctor(0, 5, 0); } else { - x_67 = x_66; + x_69 = x_68; } -lean_ctor_set(x_67, 0, x_63); -lean_ctor_set(x_67, 1, x_64); -lean_ctor_set(x_67, 2, x_43); -lean_ctor_set(x_67, 3, x_65); -x_68 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_68, 0, x_58); -lean_ctor_set(x_68, 1, x_59); -lean_ctor_set(x_68, 2, x_67); -lean_ctor_set(x_68, 3, x_60); -lean_ctor_set(x_68, 4, x_61); -lean_ctor_set(x_68, 5, x_62); +lean_ctor_set(x_69, 0, x_64); +lean_ctor_set(x_69, 1, x_65); +lean_ctor_set(x_69, 2, x_43); +lean_ctor_set(x_69, 3, x_66); +lean_ctor_set(x_69, 4, x_67); +x_70 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_70, 0, x_59); +lean_ctor_set(x_70, 1, x_60); +lean_ctor_set(x_70, 2, x_69); +lean_ctor_set(x_70, 3, x_61); +lean_ctor_set(x_70, 4, x_62); +lean_ctor_set(x_70, 5, x_63); if (lean_is_scalar(x_36)) { - x_69 = lean_alloc_ctor(1, 2, 0); + x_71 = lean_alloc_ctor(1, 2, 0); } else { - x_69 = x_36; - lean_ctor_set_tag(x_69, 1); + x_71 = x_36; + lean_ctor_set_tag(x_71, 1); } -lean_ctor_set(x_69, 0, x_47); -lean_ctor_set(x_69, 1, x_68); -return x_69; +lean_ctor_set(x_71, 0, x_47); +lean_ctor_set(x_71, 1, x_70); +return x_71; } } else { -lean_object* x_70; lean_object* x_71; uint8_t x_72; -x_70 = lean_ctor_get(x_45, 2); -lean_inc(x_70); -x_71 = lean_ctor_get(x_44, 0); -lean_inc(x_71); +lean_object* x_72; lean_object* x_73; uint8_t x_74; +x_72 = lean_ctor_get(x_45, 2); +lean_inc(x_72); +x_73 = lean_ctor_get(x_44, 0); +lean_inc(x_73); lean_dec(x_44); -x_72 = !lean_is_exclusive(x_45); -if (x_72 == 0) -{ -lean_object* x_73; uint8_t x_74; -x_73 = lean_ctor_get(x_45, 2); -lean_dec(x_73); -x_74 = !lean_is_exclusive(x_70); +x_74 = !lean_is_exclusive(x_45); if (x_74 == 0) { -lean_object* x_75; lean_object* x_76; -x_75 = lean_ctor_get(x_70, 2); +lean_object* x_75; uint8_t x_76; +x_75 = lean_ctor_get(x_45, 2); lean_dec(x_75); -lean_ctor_set(x_70, 2, x_43); +x_76 = !lean_is_exclusive(x_72); +if (x_76 == 0) +{ +lean_object* x_77; lean_object* x_78; +x_77 = lean_ctor_get(x_72, 2); +lean_dec(x_77); +lean_ctor_set(x_72, 2, x_43); if (lean_is_scalar(x_36)) { - x_76 = lean_alloc_ctor(0, 2, 0); + x_78 = lean_alloc_ctor(0, 2, 0); } else { - x_76 = x_36; + x_78 = x_36; } -lean_ctor_set(x_76, 0, x_71); -lean_ctor_set(x_76, 1, x_45); -return x_76; +lean_ctor_set(x_78, 0, x_73); +lean_ctor_set(x_78, 1, x_45); +return x_78; } else { -lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; -x_77 = lean_ctor_get(x_70, 0); -x_78 = lean_ctor_get(x_70, 1); -x_79 = lean_ctor_get(x_70, 3); +lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; +x_79 = lean_ctor_get(x_72, 0); +x_80 = lean_ctor_get(x_72, 1); +x_81 = lean_ctor_get(x_72, 3); +x_82 = lean_ctor_get(x_72, 4); +lean_inc(x_82); +lean_inc(x_81); +lean_inc(x_80); lean_inc(x_79); -lean_inc(x_78); -lean_inc(x_77); -lean_dec(x_70); -x_80 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_80, 0, x_77); -lean_ctor_set(x_80, 1, x_78); -lean_ctor_set(x_80, 2, x_43); -lean_ctor_set(x_80, 3, x_79); -lean_ctor_set(x_45, 2, x_80); +lean_dec(x_72); +x_83 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_83, 0, x_79); +lean_ctor_set(x_83, 1, x_80); +lean_ctor_set(x_83, 2, x_43); +lean_ctor_set(x_83, 3, x_81); +lean_ctor_set(x_83, 4, x_82); +lean_ctor_set(x_45, 2, x_83); if (lean_is_scalar(x_36)) { - x_81 = lean_alloc_ctor(0, 2, 0); + x_84 = lean_alloc_ctor(0, 2, 0); } else { - x_81 = x_36; + x_84 = x_36; } -lean_ctor_set(x_81, 0, x_71); -lean_ctor_set(x_81, 1, x_45); -return x_81; +lean_ctor_set(x_84, 0, x_73); +lean_ctor_set(x_84, 1, x_45); +return x_84; } } else { -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; -x_82 = lean_ctor_get(x_45, 0); -x_83 = lean_ctor_get(x_45, 1); -x_84 = lean_ctor_get(x_45, 3); -x_85 = lean_ctor_get(x_45, 4); -x_86 = lean_ctor_get(x_45, 5); +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; +x_85 = lean_ctor_get(x_45, 0); +x_86 = lean_ctor_get(x_45, 1); +x_87 = lean_ctor_get(x_45, 3); +x_88 = lean_ctor_get(x_45, 4); +x_89 = lean_ctor_get(x_45, 5); +lean_inc(x_89); +lean_inc(x_88); +lean_inc(x_87); lean_inc(x_86); lean_inc(x_85); -lean_inc(x_84); -lean_inc(x_83); -lean_inc(x_82); lean_dec(x_45); -x_87 = lean_ctor_get(x_70, 0); -lean_inc(x_87); -x_88 = lean_ctor_get(x_70, 1); -lean_inc(x_88); -x_89 = lean_ctor_get(x_70, 3); -lean_inc(x_89); -if (lean_is_exclusive(x_70)) { - lean_ctor_release(x_70, 0); - lean_ctor_release(x_70, 1); - lean_ctor_release(x_70, 2); - lean_ctor_release(x_70, 3); - x_90 = x_70; +x_90 = lean_ctor_get(x_72, 0); +lean_inc(x_90); +x_91 = lean_ctor_get(x_72, 1); +lean_inc(x_91); +x_92 = lean_ctor_get(x_72, 3); +lean_inc(x_92); +x_93 = lean_ctor_get(x_72, 4); +lean_inc(x_93); +if (lean_is_exclusive(x_72)) { + lean_ctor_release(x_72, 0); + lean_ctor_release(x_72, 1); + lean_ctor_release(x_72, 2); + lean_ctor_release(x_72, 3); + lean_ctor_release(x_72, 4); + x_94 = x_72; } else { - lean_dec_ref(x_70); - x_90 = lean_box(0); + lean_dec_ref(x_72); + x_94 = lean_box(0); } -if (lean_is_scalar(x_90)) { - x_91 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_94)) { + x_95 = lean_alloc_ctor(0, 5, 0); } else { - x_91 = x_90; + x_95 = x_94; } -lean_ctor_set(x_91, 0, x_87); -lean_ctor_set(x_91, 1, x_88); -lean_ctor_set(x_91, 2, x_43); -lean_ctor_set(x_91, 3, x_89); -x_92 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_92, 0, x_82); -lean_ctor_set(x_92, 1, x_83); -lean_ctor_set(x_92, 2, x_91); -lean_ctor_set(x_92, 3, x_84); -lean_ctor_set(x_92, 4, x_85); -lean_ctor_set(x_92, 5, x_86); +lean_ctor_set(x_95, 0, x_90); +lean_ctor_set(x_95, 1, x_91); +lean_ctor_set(x_95, 2, x_43); +lean_ctor_set(x_95, 3, x_92); +lean_ctor_set(x_95, 4, x_93); +x_96 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_96, 0, x_85); +lean_ctor_set(x_96, 1, x_86); +lean_ctor_set(x_96, 2, x_95); +lean_ctor_set(x_96, 3, x_87); +lean_ctor_set(x_96, 4, x_88); +lean_ctor_set(x_96, 5, x_89); if (lean_is_scalar(x_36)) { - x_93 = lean_alloc_ctor(0, 2, 0); + x_97 = lean_alloc_ctor(0, 2, 0); } else { - x_93 = x_36; + x_97 = x_36; } -lean_ctor_set(x_93, 0, x_71); -lean_ctor_set(x_93, 1, x_92); -return x_93; +lean_ctor_set(x_97, 0, x_73); +lean_ctor_set(x_97, 1, x_96); +return x_97; } } } } else { -lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; -x_122 = lean_ctor_get(x_41, 0); -x_123 = lean_ctor_get(x_41, 1); -x_124 = lean_ctor_get(x_41, 2); -x_125 = lean_ctor_get(x_41, 3); -lean_inc(x_125); -lean_inc(x_124); -lean_inc(x_123); -lean_inc(x_122); -lean_dec(x_41); -x_159 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_160 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_160, 0, x_122); -lean_ctor_set(x_160, 1, x_123); -lean_ctor_set(x_160, 2, x_159); -lean_ctor_set(x_160, 3, x_125); -lean_ctor_set(x_35, 2, x_160); -x_161 = lean_ctor_get(x_8, 0); -lean_inc(x_161); -x_162 = lean_ctor_get(x_8, 1); -lean_inc(x_162); -x_163 = lean_ctor_get(x_8, 2); -lean_inc(x_163); -x_164 = lean_ctor_get(x_8, 3); -lean_inc(x_164); -x_165 = lean_ctor_get(x_8, 4); -lean_inc(x_165); -if (lean_is_exclusive(x_8)) { - lean_ctor_release(x_8, 0); - lean_ctor_release(x_8, 1); - lean_ctor_release(x_8, 2); - lean_ctor_release(x_8, 3); - lean_ctor_release(x_8, 4); - x_166 = x_8; -} else { - lean_dec_ref(x_8); - x_166 = lean_box(0); -} -x_167 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_167, 0, x_37); -lean_ctor_set(x_167, 1, x_24); -x_168 = lean_array_push(x_163, x_167); -if (lean_is_scalar(x_166)) { - x_169 = lean_alloc_ctor(0, 5, 0); -} else { - x_169 = x_166; -} -lean_ctor_set(x_169, 0, x_161); -lean_ctor_set(x_169, 1, x_162); -lean_ctor_set(x_169, 2, x_168); -lean_ctor_set(x_169, 3, x_164); -lean_ctor_set(x_169, 4, x_165); -x_170 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_ExprDefEq_18__processConstApprox___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_39, x_169, x_35); -if (lean_obj_tag(x_170) == 0) -{ -lean_object* x_171; lean_object* x_172; lean_object* x_173; -x_171 = lean_ctor_get(x_170, 0); -lean_inc(x_171); -x_172 = lean_ctor_get(x_170, 1); -lean_inc(x_172); -lean_dec(x_170); -x_173 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_173, 0, x_171); -x_126 = x_173; -x_127 = x_172; -goto block_158; -} -else -{ -lean_object* x_174; lean_object* x_175; lean_object* x_176; -x_174 = lean_ctor_get(x_170, 0); -lean_inc(x_174); -x_175 = lean_ctor_get(x_170, 1); -lean_inc(x_175); -lean_dec(x_170); -x_176 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_176, 0, x_174); -x_126 = x_176; -x_127 = x_175; -goto block_158; -} -block_158: -{ -if (lean_obj_tag(x_126) == 0) -{ -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; -x_128 = lean_ctor_get(x_127, 2); -lean_inc(x_128); -x_129 = lean_ctor_get(x_126, 0); -lean_inc(x_129); -lean_dec(x_126); -x_130 = lean_ctor_get(x_127, 0); +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_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; +x_126 = lean_ctor_get(x_41, 0); +x_127 = lean_ctor_get(x_41, 1); +x_128 = lean_ctor_get(x_41, 2); +x_129 = lean_ctor_get(x_41, 3); +x_130 = lean_ctor_get(x_41, 4); lean_inc(x_130); -x_131 = lean_ctor_get(x_127, 1); -lean_inc(x_131); -x_132 = lean_ctor_get(x_127, 3); -lean_inc(x_132); -x_133 = lean_ctor_get(x_127, 4); -lean_inc(x_133); -x_134 = lean_ctor_get(x_127, 5); -lean_inc(x_134); -if (lean_is_exclusive(x_127)) { - lean_ctor_release(x_127, 0); - lean_ctor_release(x_127, 1); - lean_ctor_release(x_127, 2); - lean_ctor_release(x_127, 3); - lean_ctor_release(x_127, 4); - lean_ctor_release(x_127, 5); - x_135 = x_127; -} else { - lean_dec_ref(x_127); - x_135 = lean_box(0); -} -x_136 = lean_ctor_get(x_128, 0); -lean_inc(x_136); -x_137 = lean_ctor_get(x_128, 1); -lean_inc(x_137); -x_138 = lean_ctor_get(x_128, 3); -lean_inc(x_138); -if (lean_is_exclusive(x_128)) { - lean_ctor_release(x_128, 0); - lean_ctor_release(x_128, 1); - lean_ctor_release(x_128, 2); - lean_ctor_release(x_128, 3); - x_139 = x_128; -} else { - lean_dec_ref(x_128); - x_139 = lean_box(0); -} -if (lean_is_scalar(x_139)) { - x_140 = lean_alloc_ctor(0, 4, 0); -} else { - x_140 = x_139; -} -lean_ctor_set(x_140, 0, x_136); -lean_ctor_set(x_140, 1, x_137); -lean_ctor_set(x_140, 2, x_124); -lean_ctor_set(x_140, 3, x_138); -if (lean_is_scalar(x_135)) { - x_141 = lean_alloc_ctor(0, 6, 0); -} else { - x_141 = x_135; -} -lean_ctor_set(x_141, 0, x_130); -lean_ctor_set(x_141, 1, x_131); -lean_ctor_set(x_141, 2, x_140); -lean_ctor_set(x_141, 3, x_132); -lean_ctor_set(x_141, 4, x_133); -lean_ctor_set(x_141, 5, x_134); -if (lean_is_scalar(x_36)) { - x_142 = lean_alloc_ctor(1, 2, 0); -} else { - x_142 = x_36; - lean_ctor_set_tag(x_142, 1); -} -lean_ctor_set(x_142, 0, x_129); -lean_ctor_set(x_142, 1, x_141); -return x_142; -} -else -{ -lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; 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; -x_143 = lean_ctor_get(x_127, 2); -lean_inc(x_143); -x_144 = lean_ctor_get(x_126, 0); -lean_inc(x_144); -lean_dec(x_126); -x_145 = lean_ctor_get(x_127, 0); -lean_inc(x_145); -x_146 = lean_ctor_get(x_127, 1); -lean_inc(x_146); -x_147 = lean_ctor_get(x_127, 3); -lean_inc(x_147); -x_148 = lean_ctor_get(x_127, 4); -lean_inc(x_148); -x_149 = lean_ctor_get(x_127, 5); -lean_inc(x_149); -if (lean_is_exclusive(x_127)) { - lean_ctor_release(x_127, 0); - lean_ctor_release(x_127, 1); - lean_ctor_release(x_127, 2); - lean_ctor_release(x_127, 3); - lean_ctor_release(x_127, 4); - lean_ctor_release(x_127, 5); - x_150 = x_127; -} else { - lean_dec_ref(x_127); - x_150 = lean_box(0); -} -x_151 = lean_ctor_get(x_143, 0); -lean_inc(x_151); -x_152 = lean_ctor_get(x_143, 1); -lean_inc(x_152); -x_153 = lean_ctor_get(x_143, 3); -lean_inc(x_153); -if (lean_is_exclusive(x_143)) { - lean_ctor_release(x_143, 0); - lean_ctor_release(x_143, 1); - lean_ctor_release(x_143, 2); - lean_ctor_release(x_143, 3); - x_154 = x_143; -} else { - lean_dec_ref(x_143); - x_154 = lean_box(0); -} -if (lean_is_scalar(x_154)) { - x_155 = lean_alloc_ctor(0, 4, 0); -} else { - x_155 = x_154; -} -lean_ctor_set(x_155, 0, x_151); -lean_ctor_set(x_155, 1, x_152); -lean_ctor_set(x_155, 2, x_124); -lean_ctor_set(x_155, 3, x_153); -if (lean_is_scalar(x_150)) { - x_156 = lean_alloc_ctor(0, 6, 0); -} else { - x_156 = x_150; -} -lean_ctor_set(x_156, 0, x_145); -lean_ctor_set(x_156, 1, x_146); -lean_ctor_set(x_156, 2, x_155); -lean_ctor_set(x_156, 3, x_147); -lean_ctor_set(x_156, 4, x_148); -lean_ctor_set(x_156, 5, x_149); -if (lean_is_scalar(x_36)) { - x_157 = lean_alloc_ctor(0, 2, 0); -} else { - x_157 = x_36; -} -lean_ctor_set(x_157, 0, x_144); -lean_ctor_set(x_157, 1, x_156); -return x_157; -} -} -} -} -else -{ -lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; 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_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; lean_object* x_231; lean_object* x_232; lean_object* x_233; -x_177 = lean_ctor_get(x_35, 2); -x_178 = lean_ctor_get(x_35, 0); -x_179 = lean_ctor_get(x_35, 1); -x_180 = lean_ctor_get(x_35, 3); -x_181 = lean_ctor_get(x_35, 4); -x_182 = lean_ctor_get(x_35, 5); -lean_inc(x_182); -lean_inc(x_181); -lean_inc(x_180); -lean_inc(x_177); -lean_inc(x_179); -lean_inc(x_178); -lean_dec(x_35); -x_183 = lean_ctor_get(x_177, 0); -lean_inc(x_183); -x_184 = lean_ctor_get(x_177, 1); -lean_inc(x_184); -x_185 = lean_ctor_get(x_177, 2); -lean_inc(x_185); -x_186 = lean_ctor_get(x_177, 3); -lean_inc(x_186); -if (lean_is_exclusive(x_177)) { - lean_ctor_release(x_177, 0); - lean_ctor_release(x_177, 1); - lean_ctor_release(x_177, 2); - lean_ctor_release(x_177, 3); - x_187 = x_177; -} else { - lean_dec_ref(x_177); - x_187 = lean_box(0); -} -x_221 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_187)) { - x_222 = lean_alloc_ctor(0, 4, 0); -} else { - x_222 = x_187; -} -lean_ctor_set(x_222, 0, x_183); -lean_ctor_set(x_222, 1, x_184); -lean_ctor_set(x_222, 2, x_221); -lean_ctor_set(x_222, 3, x_186); -x_223 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_223, 0, x_178); -lean_ctor_set(x_223, 1, x_179); -lean_ctor_set(x_223, 2, x_222); -lean_ctor_set(x_223, 3, x_180); -lean_ctor_set(x_223, 4, x_181); -lean_ctor_set(x_223, 5, x_182); -x_224 = lean_ctor_get(x_8, 0); -lean_inc(x_224); -x_225 = lean_ctor_get(x_8, 1); -lean_inc(x_225); -x_226 = lean_ctor_get(x_8, 2); -lean_inc(x_226); -x_227 = lean_ctor_get(x_8, 3); -lean_inc(x_227); -x_228 = lean_ctor_get(x_8, 4); -lean_inc(x_228); +lean_inc(x_129); +lean_inc(x_128); +lean_inc(x_127); +lean_inc(x_126); +lean_dec(x_41); +x_166 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_167 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_167, 0, x_126); +lean_ctor_set(x_167, 1, x_127); +lean_ctor_set(x_167, 2, x_166); +lean_ctor_set(x_167, 3, x_129); +lean_ctor_set(x_167, 4, x_130); +lean_ctor_set(x_35, 2, x_167); +x_168 = lean_ctor_get(x_8, 0); +lean_inc(x_168); +x_169 = lean_ctor_get(x_8, 1); +lean_inc(x_169); +x_170 = lean_ctor_get(x_8, 2); +lean_inc(x_170); +x_171 = lean_ctor_get(x_8, 3); +lean_inc(x_171); +x_172 = lean_ctor_get(x_8, 4); +lean_inc(x_172); if (lean_is_exclusive(x_8)) { lean_ctor_release(x_8, 0); lean_ctor_release(x_8, 1); lean_ctor_release(x_8, 2); lean_ctor_release(x_8, 3); lean_ctor_release(x_8, 4); - x_229 = x_8; + x_173 = x_8; } else { lean_dec_ref(x_8); - x_229 = lean_box(0); + x_173 = lean_box(0); } -x_230 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_230, 0, x_37); -lean_ctor_set(x_230, 1, x_24); -x_231 = lean_array_push(x_226, x_230); -if (lean_is_scalar(x_229)) { +x_174 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_174, 0, x_37); +lean_ctor_set(x_174, 1, x_24); +x_175 = lean_array_push(x_170, x_174); +if (lean_is_scalar(x_173)) { + x_176 = lean_alloc_ctor(0, 5, 0); +} else { + x_176 = x_173; +} +lean_ctor_set(x_176, 0, x_168); +lean_ctor_set(x_176, 1, x_169); +lean_ctor_set(x_176, 2, x_175); +lean_ctor_set(x_176, 3, x_171); +lean_ctor_set(x_176, 4, x_172); +x_177 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_ExprDefEq_18__processConstApprox___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_39, x_176, x_35); +if (lean_obj_tag(x_177) == 0) +{ +lean_object* x_178; lean_object* x_179; lean_object* x_180; +x_178 = lean_ctor_get(x_177, 0); +lean_inc(x_178); +x_179 = lean_ctor_get(x_177, 1); +lean_inc(x_179); +lean_dec(x_177); +x_180 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_180, 0, x_178); +x_131 = x_180; +x_132 = x_179; +goto block_165; +} +else +{ +lean_object* x_181; lean_object* x_182; lean_object* x_183; +x_181 = lean_ctor_get(x_177, 0); +lean_inc(x_181); +x_182 = lean_ctor_get(x_177, 1); +lean_inc(x_182); +lean_dec(x_177); +x_183 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_183, 0, x_181); +x_131 = x_183; +x_132 = x_182; +goto block_165; +} +block_165: +{ +if (lean_obj_tag(x_131) == 0) +{ +lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; +x_133 = lean_ctor_get(x_132, 2); +lean_inc(x_133); +x_134 = lean_ctor_get(x_131, 0); +lean_inc(x_134); +lean_dec(x_131); +x_135 = lean_ctor_get(x_132, 0); +lean_inc(x_135); +x_136 = lean_ctor_get(x_132, 1); +lean_inc(x_136); +x_137 = lean_ctor_get(x_132, 3); +lean_inc(x_137); +x_138 = lean_ctor_get(x_132, 4); +lean_inc(x_138); +x_139 = lean_ctor_get(x_132, 5); +lean_inc(x_139); +if (lean_is_exclusive(x_132)) { + lean_ctor_release(x_132, 0); + lean_ctor_release(x_132, 1); + lean_ctor_release(x_132, 2); + lean_ctor_release(x_132, 3); + lean_ctor_release(x_132, 4); + lean_ctor_release(x_132, 5); + x_140 = x_132; +} else { + lean_dec_ref(x_132); + x_140 = lean_box(0); +} +x_141 = lean_ctor_get(x_133, 0); +lean_inc(x_141); +x_142 = lean_ctor_get(x_133, 1); +lean_inc(x_142); +x_143 = lean_ctor_get(x_133, 3); +lean_inc(x_143); +x_144 = lean_ctor_get(x_133, 4); +lean_inc(x_144); +if (lean_is_exclusive(x_133)) { + lean_ctor_release(x_133, 0); + lean_ctor_release(x_133, 1); + lean_ctor_release(x_133, 2); + lean_ctor_release(x_133, 3); + lean_ctor_release(x_133, 4); + x_145 = x_133; +} else { + lean_dec_ref(x_133); + x_145 = lean_box(0); +} +if (lean_is_scalar(x_145)) { + x_146 = lean_alloc_ctor(0, 5, 0); +} else { + x_146 = x_145; +} +lean_ctor_set(x_146, 0, x_141); +lean_ctor_set(x_146, 1, x_142); +lean_ctor_set(x_146, 2, x_128); +lean_ctor_set(x_146, 3, x_143); +lean_ctor_set(x_146, 4, x_144); +if (lean_is_scalar(x_140)) { + x_147 = lean_alloc_ctor(0, 6, 0); +} else { + x_147 = x_140; +} +lean_ctor_set(x_147, 0, x_135); +lean_ctor_set(x_147, 1, x_136); +lean_ctor_set(x_147, 2, x_146); +lean_ctor_set(x_147, 3, x_137); +lean_ctor_set(x_147, 4, x_138); +lean_ctor_set(x_147, 5, x_139); +if (lean_is_scalar(x_36)) { + x_148 = lean_alloc_ctor(1, 2, 0); +} else { + x_148 = x_36; + lean_ctor_set_tag(x_148, 1); +} +lean_ctor_set(x_148, 0, x_134); +lean_ctor_set(x_148, 1, x_147); +return x_148; +} +else +{ +lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; +x_149 = lean_ctor_get(x_132, 2); +lean_inc(x_149); +x_150 = lean_ctor_get(x_131, 0); +lean_inc(x_150); +lean_dec(x_131); +x_151 = lean_ctor_get(x_132, 0); +lean_inc(x_151); +x_152 = lean_ctor_get(x_132, 1); +lean_inc(x_152); +x_153 = lean_ctor_get(x_132, 3); +lean_inc(x_153); +x_154 = lean_ctor_get(x_132, 4); +lean_inc(x_154); +x_155 = lean_ctor_get(x_132, 5); +lean_inc(x_155); +if (lean_is_exclusive(x_132)) { + lean_ctor_release(x_132, 0); + lean_ctor_release(x_132, 1); + lean_ctor_release(x_132, 2); + lean_ctor_release(x_132, 3); + lean_ctor_release(x_132, 4); + lean_ctor_release(x_132, 5); + x_156 = x_132; +} else { + lean_dec_ref(x_132); + x_156 = lean_box(0); +} +x_157 = lean_ctor_get(x_149, 0); +lean_inc(x_157); +x_158 = lean_ctor_get(x_149, 1); +lean_inc(x_158); +x_159 = lean_ctor_get(x_149, 3); +lean_inc(x_159); +x_160 = lean_ctor_get(x_149, 4); +lean_inc(x_160); +if (lean_is_exclusive(x_149)) { + lean_ctor_release(x_149, 0); + lean_ctor_release(x_149, 1); + lean_ctor_release(x_149, 2); + lean_ctor_release(x_149, 3); + lean_ctor_release(x_149, 4); + x_161 = x_149; +} else { + lean_dec_ref(x_149); + x_161 = lean_box(0); +} +if (lean_is_scalar(x_161)) { + x_162 = lean_alloc_ctor(0, 5, 0); +} else { + x_162 = x_161; +} +lean_ctor_set(x_162, 0, x_157); +lean_ctor_set(x_162, 1, x_158); +lean_ctor_set(x_162, 2, x_128); +lean_ctor_set(x_162, 3, x_159); +lean_ctor_set(x_162, 4, x_160); +if (lean_is_scalar(x_156)) { + x_163 = lean_alloc_ctor(0, 6, 0); +} else { + x_163 = x_156; +} +lean_ctor_set(x_163, 0, x_151); +lean_ctor_set(x_163, 1, x_152); +lean_ctor_set(x_163, 2, x_162); +lean_ctor_set(x_163, 3, x_153); +lean_ctor_set(x_163, 4, x_154); +lean_ctor_set(x_163, 5, x_155); +if (lean_is_scalar(x_36)) { + x_164 = lean_alloc_ctor(0, 2, 0); +} else { + x_164 = x_36; +} +lean_ctor_set(x_164, 0, x_150); +lean_ctor_set(x_164, 1, x_163); +return x_164; +} +} +} +} +else +{ +lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_231; lean_object* x_232; lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_object* x_236; lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; lean_object* x_242; lean_object* x_243; +x_184 = lean_ctor_get(x_35, 2); +x_185 = lean_ctor_get(x_35, 0); +x_186 = lean_ctor_get(x_35, 1); +x_187 = lean_ctor_get(x_35, 3); +x_188 = lean_ctor_get(x_35, 4); +x_189 = lean_ctor_get(x_35, 5); +lean_inc(x_189); +lean_inc(x_188); +lean_inc(x_187); +lean_inc(x_184); +lean_inc(x_186); +lean_inc(x_185); +lean_dec(x_35); +x_190 = lean_ctor_get(x_184, 0); +lean_inc(x_190); +x_191 = lean_ctor_get(x_184, 1); +lean_inc(x_191); +x_192 = lean_ctor_get(x_184, 2); +lean_inc(x_192); +x_193 = lean_ctor_get(x_184, 3); +lean_inc(x_193); +x_194 = lean_ctor_get(x_184, 4); +lean_inc(x_194); +if (lean_is_exclusive(x_184)) { + lean_ctor_release(x_184, 0); + lean_ctor_release(x_184, 1); + lean_ctor_release(x_184, 2); + lean_ctor_release(x_184, 3); + lean_ctor_release(x_184, 4); + x_195 = x_184; +} else { + lean_dec_ref(x_184); + x_195 = lean_box(0); +} +x_231 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_195)) { x_232 = lean_alloc_ctor(0, 5, 0); } else { - x_232 = x_229; + x_232 = x_195; } -lean_ctor_set(x_232, 0, x_224); -lean_ctor_set(x_232, 1, x_225); +lean_ctor_set(x_232, 0, x_190); +lean_ctor_set(x_232, 1, x_191); lean_ctor_set(x_232, 2, x_231); -lean_ctor_set(x_232, 3, x_227); -lean_ctor_set(x_232, 4, x_228); -x_233 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_ExprDefEq_18__processConstApprox___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_39, x_232, x_223); -if (lean_obj_tag(x_233) == 0) -{ -lean_object* x_234; lean_object* x_235; lean_object* x_236; -x_234 = lean_ctor_get(x_233, 0); +lean_ctor_set(x_232, 3, x_193); +lean_ctor_set(x_232, 4, x_194); +x_233 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_233, 0, x_185); +lean_ctor_set(x_233, 1, x_186); +lean_ctor_set(x_233, 2, x_232); +lean_ctor_set(x_233, 3, x_187); +lean_ctor_set(x_233, 4, x_188); +lean_ctor_set(x_233, 5, x_189); +x_234 = lean_ctor_get(x_8, 0); lean_inc(x_234); -x_235 = lean_ctor_get(x_233, 1); +x_235 = lean_ctor_get(x_8, 1); lean_inc(x_235); -lean_dec(x_233); -x_236 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_236, 0, x_234); -x_188 = x_236; -x_189 = x_235; -goto block_220; -} -else -{ -lean_object* x_237; lean_object* x_238; lean_object* x_239; -x_237 = lean_ctor_get(x_233, 0); +x_236 = lean_ctor_get(x_8, 2); +lean_inc(x_236); +x_237 = lean_ctor_get(x_8, 3); lean_inc(x_237); -x_238 = lean_ctor_get(x_233, 1); +x_238 = lean_ctor_get(x_8, 4); lean_inc(x_238); -lean_dec(x_233); -x_239 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_239, 0, x_237); -x_188 = x_239; -x_189 = x_238; -goto block_220; +if (lean_is_exclusive(x_8)) { + lean_ctor_release(x_8, 0); + lean_ctor_release(x_8, 1); + lean_ctor_release(x_8, 2); + lean_ctor_release(x_8, 3); + lean_ctor_release(x_8, 4); + x_239 = x_8; +} else { + lean_dec_ref(x_8); + x_239 = lean_box(0); } -block_220: +x_240 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_240, 0, x_37); +lean_ctor_set(x_240, 1, x_24); +x_241 = lean_array_push(x_236, x_240); +if (lean_is_scalar(x_239)) { + x_242 = lean_alloc_ctor(0, 5, 0); +} else { + x_242 = x_239; +} +lean_ctor_set(x_242, 0, x_234); +lean_ctor_set(x_242, 1, x_235); +lean_ctor_set(x_242, 2, x_241); +lean_ctor_set(x_242, 3, x_237); +lean_ctor_set(x_242, 4, x_238); +x_243 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_ExprDefEq_18__processConstApprox___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_39, x_242, x_233); +if (lean_obj_tag(x_243) == 0) { -if (lean_obj_tag(x_188) == 0) -{ -lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; -x_190 = lean_ctor_get(x_189, 2); -lean_inc(x_190); -x_191 = lean_ctor_get(x_188, 0); -lean_inc(x_191); -lean_dec(x_188); -x_192 = lean_ctor_get(x_189, 0); -lean_inc(x_192); -x_193 = lean_ctor_get(x_189, 1); -lean_inc(x_193); -x_194 = lean_ctor_get(x_189, 3); -lean_inc(x_194); -x_195 = lean_ctor_get(x_189, 4); -lean_inc(x_195); -x_196 = lean_ctor_get(x_189, 5); -lean_inc(x_196); -if (lean_is_exclusive(x_189)) { - lean_ctor_release(x_189, 0); - lean_ctor_release(x_189, 1); - lean_ctor_release(x_189, 2); - lean_ctor_release(x_189, 3); - lean_ctor_release(x_189, 4); - lean_ctor_release(x_189, 5); - x_197 = x_189; -} else { - lean_dec_ref(x_189); - x_197 = lean_box(0); -} -x_198 = lean_ctor_get(x_190, 0); -lean_inc(x_198); -x_199 = lean_ctor_get(x_190, 1); -lean_inc(x_199); -x_200 = lean_ctor_get(x_190, 3); -lean_inc(x_200); -if (lean_is_exclusive(x_190)) { - lean_ctor_release(x_190, 0); - lean_ctor_release(x_190, 1); - lean_ctor_release(x_190, 2); - lean_ctor_release(x_190, 3); - x_201 = x_190; -} else { - lean_dec_ref(x_190); - x_201 = lean_box(0); -} -if (lean_is_scalar(x_201)) { - x_202 = lean_alloc_ctor(0, 4, 0); -} else { - x_202 = x_201; -} -lean_ctor_set(x_202, 0, x_198); -lean_ctor_set(x_202, 1, x_199); -lean_ctor_set(x_202, 2, x_185); -lean_ctor_set(x_202, 3, x_200); -if (lean_is_scalar(x_197)) { - x_203 = lean_alloc_ctor(0, 6, 0); -} else { - x_203 = x_197; -} -lean_ctor_set(x_203, 0, x_192); -lean_ctor_set(x_203, 1, x_193); -lean_ctor_set(x_203, 2, x_202); -lean_ctor_set(x_203, 3, x_194); -lean_ctor_set(x_203, 4, x_195); -lean_ctor_set(x_203, 5, x_196); -if (lean_is_scalar(x_36)) { - x_204 = lean_alloc_ctor(1, 2, 0); -} else { - x_204 = x_36; - lean_ctor_set_tag(x_204, 1); -} -lean_ctor_set(x_204, 0, x_191); -lean_ctor_set(x_204, 1, x_203); -return x_204; +lean_object* x_244; lean_object* x_245; lean_object* x_246; +x_244 = lean_ctor_get(x_243, 0); +lean_inc(x_244); +x_245 = lean_ctor_get(x_243, 1); +lean_inc(x_245); +lean_dec(x_243); +x_246 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_246, 0, x_244); +x_196 = x_246; +x_197 = x_245; +goto block_230; } else { -lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; -x_205 = lean_ctor_get(x_189, 2); -lean_inc(x_205); -x_206 = lean_ctor_get(x_188, 0); +lean_object* x_247; lean_object* x_248; lean_object* x_249; +x_247 = lean_ctor_get(x_243, 0); +lean_inc(x_247); +x_248 = lean_ctor_get(x_243, 1); +lean_inc(x_248); +lean_dec(x_243); +x_249 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_249, 0, x_247); +x_196 = x_249; +x_197 = x_248; +goto block_230; +} +block_230: +{ +if (lean_obj_tag(x_196) == 0) +{ +lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; +x_198 = lean_ctor_get(x_197, 2); +lean_inc(x_198); +x_199 = lean_ctor_get(x_196, 0); +lean_inc(x_199); +lean_dec(x_196); +x_200 = lean_ctor_get(x_197, 0); +lean_inc(x_200); +x_201 = lean_ctor_get(x_197, 1); +lean_inc(x_201); +x_202 = lean_ctor_get(x_197, 3); +lean_inc(x_202); +x_203 = lean_ctor_get(x_197, 4); +lean_inc(x_203); +x_204 = lean_ctor_get(x_197, 5); +lean_inc(x_204); +if (lean_is_exclusive(x_197)) { + lean_ctor_release(x_197, 0); + lean_ctor_release(x_197, 1); + lean_ctor_release(x_197, 2); + lean_ctor_release(x_197, 3); + lean_ctor_release(x_197, 4); + lean_ctor_release(x_197, 5); + x_205 = x_197; +} else { + lean_dec_ref(x_197); + x_205 = lean_box(0); +} +x_206 = lean_ctor_get(x_198, 0); lean_inc(x_206); -lean_dec(x_188); -x_207 = lean_ctor_get(x_189, 0); +x_207 = lean_ctor_get(x_198, 1); lean_inc(x_207); -x_208 = lean_ctor_get(x_189, 1); +x_208 = lean_ctor_get(x_198, 3); lean_inc(x_208); -x_209 = lean_ctor_get(x_189, 3); +x_209 = lean_ctor_get(x_198, 4); lean_inc(x_209); -x_210 = lean_ctor_get(x_189, 4); -lean_inc(x_210); -x_211 = lean_ctor_get(x_189, 5); -lean_inc(x_211); -if (lean_is_exclusive(x_189)) { - lean_ctor_release(x_189, 0); - lean_ctor_release(x_189, 1); - lean_ctor_release(x_189, 2); - lean_ctor_release(x_189, 3); - lean_ctor_release(x_189, 4); - lean_ctor_release(x_189, 5); - x_212 = x_189; +if (lean_is_exclusive(x_198)) { + lean_ctor_release(x_198, 0); + lean_ctor_release(x_198, 1); + lean_ctor_release(x_198, 2); + lean_ctor_release(x_198, 3); + lean_ctor_release(x_198, 4); + x_210 = x_198; } else { - lean_dec_ref(x_189); - x_212 = lean_box(0); + lean_dec_ref(x_198); + x_210 = lean_box(0); } -x_213 = lean_ctor_get(x_205, 0); -lean_inc(x_213); -x_214 = lean_ctor_get(x_205, 1); -lean_inc(x_214); -x_215 = lean_ctor_get(x_205, 3); -lean_inc(x_215); -if (lean_is_exclusive(x_205)) { - lean_ctor_release(x_205, 0); - lean_ctor_release(x_205, 1); - lean_ctor_release(x_205, 2); - lean_ctor_release(x_205, 3); - x_216 = x_205; +if (lean_is_scalar(x_210)) { + x_211 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_205); - x_216 = lean_box(0); + x_211 = x_210; } -if (lean_is_scalar(x_216)) { - x_217 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_211, 0, x_206); +lean_ctor_set(x_211, 1, x_207); +lean_ctor_set(x_211, 2, x_192); +lean_ctor_set(x_211, 3, x_208); +lean_ctor_set(x_211, 4, x_209); +if (lean_is_scalar(x_205)) { + x_212 = lean_alloc_ctor(0, 6, 0); } else { - x_217 = x_216; + x_212 = x_205; } -lean_ctor_set(x_217, 0, x_213); -lean_ctor_set(x_217, 1, x_214); -lean_ctor_set(x_217, 2, x_185); -lean_ctor_set(x_217, 3, x_215); -if (lean_is_scalar(x_212)) { - x_218 = lean_alloc_ctor(0, 6, 0); -} else { - x_218 = x_212; -} -lean_ctor_set(x_218, 0, x_207); -lean_ctor_set(x_218, 1, x_208); -lean_ctor_set(x_218, 2, x_217); -lean_ctor_set(x_218, 3, x_209); -lean_ctor_set(x_218, 4, x_210); -lean_ctor_set(x_218, 5, x_211); +lean_ctor_set(x_212, 0, x_200); +lean_ctor_set(x_212, 1, x_201); +lean_ctor_set(x_212, 2, x_211); +lean_ctor_set(x_212, 3, x_202); +lean_ctor_set(x_212, 4, x_203); +lean_ctor_set(x_212, 5, x_204); if (lean_is_scalar(x_36)) { - x_219 = lean_alloc_ctor(0, 2, 0); + x_213 = lean_alloc_ctor(1, 2, 0); } else { - x_219 = x_36; + x_213 = x_36; + lean_ctor_set_tag(x_213, 1); } -lean_ctor_set(x_219, 0, x_206); -lean_ctor_set(x_219, 1, x_218); -return x_219; +lean_ctor_set(x_213, 0, x_199); +lean_ctor_set(x_213, 1, x_212); +return x_213; +} +else +{ +lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; 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; +x_214 = lean_ctor_get(x_197, 2); +lean_inc(x_214); +x_215 = lean_ctor_get(x_196, 0); +lean_inc(x_215); +lean_dec(x_196); +x_216 = lean_ctor_get(x_197, 0); +lean_inc(x_216); +x_217 = lean_ctor_get(x_197, 1); +lean_inc(x_217); +x_218 = lean_ctor_get(x_197, 3); +lean_inc(x_218); +x_219 = lean_ctor_get(x_197, 4); +lean_inc(x_219); +x_220 = lean_ctor_get(x_197, 5); +lean_inc(x_220); +if (lean_is_exclusive(x_197)) { + lean_ctor_release(x_197, 0); + lean_ctor_release(x_197, 1); + lean_ctor_release(x_197, 2); + lean_ctor_release(x_197, 3); + lean_ctor_release(x_197, 4); + lean_ctor_release(x_197, 5); + x_221 = x_197; +} else { + lean_dec_ref(x_197); + x_221 = lean_box(0); +} +x_222 = lean_ctor_get(x_214, 0); +lean_inc(x_222); +x_223 = lean_ctor_get(x_214, 1); +lean_inc(x_223); +x_224 = lean_ctor_get(x_214, 3); +lean_inc(x_224); +x_225 = lean_ctor_get(x_214, 4); +lean_inc(x_225); +if (lean_is_exclusive(x_214)) { + lean_ctor_release(x_214, 0); + lean_ctor_release(x_214, 1); + lean_ctor_release(x_214, 2); + lean_ctor_release(x_214, 3); + lean_ctor_release(x_214, 4); + x_226 = x_214; +} else { + lean_dec_ref(x_214); + x_226 = lean_box(0); +} +if (lean_is_scalar(x_226)) { + x_227 = lean_alloc_ctor(0, 5, 0); +} else { + x_227 = x_226; +} +lean_ctor_set(x_227, 0, x_222); +lean_ctor_set(x_227, 1, x_223); +lean_ctor_set(x_227, 2, x_192); +lean_ctor_set(x_227, 3, x_224); +lean_ctor_set(x_227, 4, x_225); +if (lean_is_scalar(x_221)) { + x_228 = lean_alloc_ctor(0, 6, 0); +} else { + x_228 = x_221; +} +lean_ctor_set(x_228, 0, x_216); +lean_ctor_set(x_228, 1, x_217); +lean_ctor_set(x_228, 2, x_227); +lean_ctor_set(x_228, 3, x_218); +lean_ctor_set(x_228, 4, x_219); +lean_ctor_set(x_228, 5, x_220); +if (lean_is_scalar(x_36)) { + x_229 = lean_alloc_ctor(0, 2, 0); +} else { + x_229 = x_36; +} +lean_ctor_set(x_229, 0, x_215); +lean_ctor_set(x_229, 1, x_228); +return x_229; } } } } default: { -lean_object* x_240; lean_object* x_241; -x_240 = lean_ctor_get(x_29, 1); -lean_inc(x_240); +lean_object* x_250; lean_object* x_251; +x_250 = lean_ctor_get(x_29, 1); +lean_inc(x_250); lean_dec(x_29); lean_inc(x_8); -x_241 = l_Lean_Meta_isClassExpensive___main(x_28, x_8, x_240); -if (lean_obj_tag(x_241) == 0) +x_251 = l_Lean_Meta_isClassExpensive___main(x_28, x_8, x_250); +if (lean_obj_tag(x_251) == 0) { -lean_object* x_242; -x_242 = lean_ctor_get(x_241, 0); -lean_inc(x_242); -if (lean_obj_tag(x_242) == 0) +lean_object* x_252; +x_252 = lean_ctor_get(x_251, 0); +lean_inc(x_252); +if (lean_obj_tag(x_252) == 0) { -lean_object* x_243; lean_object* x_244; lean_object* x_245; +lean_object* x_253; lean_object* x_254; lean_object* x_255; lean_dec(x_24); -x_243 = lean_ctor_get(x_241, 1); -lean_inc(x_243); -lean_dec(x_241); -x_244 = lean_unsigned_to_nat(1u); -x_245 = lean_nat_add(x_7, x_244); +x_253 = lean_ctor_get(x_251, 1); +lean_inc(x_253); +lean_dec(x_251); +x_254 = lean_unsigned_to_nat(1u); +x_255 = lean_nat_add(x_7, x_254); lean_dec(x_7); -x_7 = x_245; -x_9 = x_243; +x_7 = x_255; +x_9 = x_253; goto _start; } else { -lean_object* x_247; lean_object* x_248; lean_object* x_249; lean_object* x_250; lean_object* x_251; uint8_t x_252; -x_247 = lean_ctor_get(x_241, 1); -lean_inc(x_247); -if (lean_is_exclusive(x_241)) { - lean_ctor_release(x_241, 0); - lean_ctor_release(x_241, 1); - x_248 = x_241; +lean_object* x_257; lean_object* x_258; lean_object* x_259; lean_object* x_260; lean_object* x_261; uint8_t x_262; +x_257 = lean_ctor_get(x_251, 1); +lean_inc(x_257); +if (lean_is_exclusive(x_251)) { + lean_ctor_release(x_251, 0); + lean_ctor_release(x_251, 1); + x_258 = x_251; } else { - lean_dec_ref(x_241); - x_248 = lean_box(0); + lean_dec_ref(x_251); + x_258 = lean_box(0); } -x_249 = lean_ctor_get(x_242, 0); -lean_inc(x_249); -lean_dec(x_242); -x_250 = lean_unsigned_to_nat(1u); -x_251 = lean_nat_add(x_7, x_250); -lean_dec(x_7); -x_252 = !lean_is_exclusive(x_247); -if (x_252 == 0) -{ -lean_object* x_253; uint8_t x_254; -x_253 = lean_ctor_get(x_247, 2); -x_254 = !lean_is_exclusive(x_253); -if (x_254 == 0) -{ -lean_object* x_255; lean_object* x_256; lean_object* x_257; lean_object* x_307; uint8_t x_308; -x_255 = lean_ctor_get(x_253, 2); -x_307 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_253, 2, x_307); -x_308 = !lean_is_exclusive(x_8); -if (x_308 == 0) -{ -lean_object* x_309; lean_object* x_310; lean_object* x_311; lean_object* x_312; -x_309 = lean_ctor_get(x_8, 2); -x_310 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_310, 0, x_249); -lean_ctor_set(x_310, 1, x_24); -x_311 = lean_array_push(x_309, x_310); -lean_ctor_set(x_8, 2, x_311); -x_312 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_ExprDefEq_18__processConstApprox___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_251, x_8, x_247); -if (lean_obj_tag(x_312) == 0) -{ -lean_object* x_313; lean_object* x_314; lean_object* x_315; -x_313 = lean_ctor_get(x_312, 0); -lean_inc(x_313); -x_314 = lean_ctor_get(x_312, 1); -lean_inc(x_314); -lean_dec(x_312); -x_315 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_315, 0, x_313); -x_256 = x_315; -x_257 = x_314; -goto block_306; -} -else -{ -lean_object* x_316; lean_object* x_317; lean_object* x_318; -x_316 = lean_ctor_get(x_312, 0); -lean_inc(x_316); -x_317 = lean_ctor_get(x_312, 1); -lean_inc(x_317); -lean_dec(x_312); -x_318 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_318, 0, x_316); -x_256 = x_318; -x_257 = x_317; -goto block_306; -} -} -else -{ -lean_object* x_319; lean_object* x_320; lean_object* x_321; lean_object* x_322; lean_object* x_323; lean_object* x_324; lean_object* x_325; lean_object* x_326; lean_object* x_327; -x_319 = lean_ctor_get(x_8, 0); -x_320 = lean_ctor_get(x_8, 1); -x_321 = lean_ctor_get(x_8, 2); -x_322 = lean_ctor_get(x_8, 3); -x_323 = lean_ctor_get(x_8, 4); -lean_inc(x_323); -lean_inc(x_322); -lean_inc(x_321); -lean_inc(x_320); -lean_inc(x_319); -lean_dec(x_8); -x_324 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_324, 0, x_249); -lean_ctor_set(x_324, 1, x_24); -x_325 = lean_array_push(x_321, x_324); -x_326 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_326, 0, x_319); -lean_ctor_set(x_326, 1, x_320); -lean_ctor_set(x_326, 2, x_325); -lean_ctor_set(x_326, 3, x_322); -lean_ctor_set(x_326, 4, x_323); -x_327 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_ExprDefEq_18__processConstApprox___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_251, x_326, x_247); -if (lean_obj_tag(x_327) == 0) -{ -lean_object* x_328; lean_object* x_329; lean_object* x_330; -x_328 = lean_ctor_get(x_327, 0); -lean_inc(x_328); -x_329 = lean_ctor_get(x_327, 1); -lean_inc(x_329); -lean_dec(x_327); -x_330 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_330, 0, x_328); -x_256 = x_330; -x_257 = x_329; -goto block_306; -} -else -{ -lean_object* x_331; lean_object* x_332; lean_object* x_333; -x_331 = lean_ctor_get(x_327, 0); -lean_inc(x_331); -x_332 = lean_ctor_get(x_327, 1); -lean_inc(x_332); -lean_dec(x_327); -x_333 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_333, 0, x_331); -x_256 = x_333; -x_257 = x_332; -goto block_306; -} -} -block_306: -{ -if (lean_obj_tag(x_256) == 0) -{ -lean_object* x_258; lean_object* x_259; uint8_t x_260; -x_258 = lean_ctor_get(x_257, 2); -lean_inc(x_258); -x_259 = lean_ctor_get(x_256, 0); +x_259 = lean_ctor_get(x_252, 0); lean_inc(x_259); -lean_dec(x_256); -x_260 = !lean_is_exclusive(x_257); -if (x_260 == 0) -{ -lean_object* x_261; uint8_t x_262; -x_261 = lean_ctor_get(x_257, 2); -lean_dec(x_261); -x_262 = !lean_is_exclusive(x_258); +lean_dec(x_252); +x_260 = lean_unsigned_to_nat(1u); +x_261 = lean_nat_add(x_7, x_260); +lean_dec(x_7); +x_262 = !lean_is_exclusive(x_257); if (x_262 == 0) { -lean_object* x_263; lean_object* x_264; -x_263 = lean_ctor_get(x_258, 2); -lean_dec(x_263); -lean_ctor_set(x_258, 2, x_255); -if (lean_is_scalar(x_248)) { - x_264 = lean_alloc_ctor(1, 2, 0); -} else { - x_264 = x_248; - lean_ctor_set_tag(x_264, 1); -} -lean_ctor_set(x_264, 0, x_259); -lean_ctor_set(x_264, 1, x_257); -return x_264; +lean_object* x_263; uint8_t x_264; +x_263 = lean_ctor_get(x_257, 2); +x_264 = !lean_is_exclusive(x_263); +if (x_264 == 0) +{ +lean_object* x_265; lean_object* x_266; lean_object* x_267; lean_object* x_321; uint8_t x_322; +x_265 = lean_ctor_get(x_263, 2); +x_321 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_263, 2, x_321); +x_322 = !lean_is_exclusive(x_8); +if (x_322 == 0) +{ +lean_object* x_323; lean_object* x_324; lean_object* x_325; lean_object* x_326; +x_323 = lean_ctor_get(x_8, 2); +x_324 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_324, 0, x_259); +lean_ctor_set(x_324, 1, x_24); +x_325 = lean_array_push(x_323, x_324); +lean_ctor_set(x_8, 2, x_325); +x_326 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_ExprDefEq_18__processConstApprox___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_261, x_8, x_257); +if (lean_obj_tag(x_326) == 0) +{ +lean_object* x_327; lean_object* x_328; lean_object* x_329; +x_327 = lean_ctor_get(x_326, 0); +lean_inc(x_327); +x_328 = lean_ctor_get(x_326, 1); +lean_inc(x_328); +lean_dec(x_326); +x_329 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_329, 0, x_327); +x_266 = x_329; +x_267 = x_328; +goto block_320; } else { -lean_object* x_265; lean_object* x_266; lean_object* x_267; lean_object* x_268; lean_object* x_269; -x_265 = lean_ctor_get(x_258, 0); -x_266 = lean_ctor_get(x_258, 1); -x_267 = lean_ctor_get(x_258, 3); -lean_inc(x_267); -lean_inc(x_266); -lean_inc(x_265); -lean_dec(x_258); -x_268 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_268, 0, x_265); -lean_ctor_set(x_268, 1, x_266); -lean_ctor_set(x_268, 2, x_255); -lean_ctor_set(x_268, 3, x_267); -lean_ctor_set(x_257, 2, x_268); -if (lean_is_scalar(x_248)) { - x_269 = lean_alloc_ctor(1, 2, 0); -} else { - x_269 = x_248; - lean_ctor_set_tag(x_269, 1); -} -lean_ctor_set(x_269, 0, x_259); -lean_ctor_set(x_269, 1, x_257); -return x_269; +lean_object* x_330; lean_object* x_331; lean_object* x_332; +x_330 = lean_ctor_get(x_326, 0); +lean_inc(x_330); +x_331 = lean_ctor_get(x_326, 1); +lean_inc(x_331); +lean_dec(x_326); +x_332 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_332, 0, x_330); +x_266 = x_332; +x_267 = x_331; +goto block_320; } } else { -lean_object* x_270; lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_object* x_276; lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; lean_object* x_281; -x_270 = lean_ctor_get(x_257, 0); -x_271 = lean_ctor_get(x_257, 1); -x_272 = lean_ctor_get(x_257, 3); -x_273 = lean_ctor_get(x_257, 4); -x_274 = lean_ctor_get(x_257, 5); -lean_inc(x_274); -lean_inc(x_273); -lean_inc(x_272); -lean_inc(x_271); -lean_inc(x_270); -lean_dec(x_257); -x_275 = lean_ctor_get(x_258, 0); -lean_inc(x_275); -x_276 = lean_ctor_get(x_258, 1); -lean_inc(x_276); -x_277 = lean_ctor_get(x_258, 3); +lean_object* x_333; lean_object* x_334; lean_object* x_335; lean_object* x_336; lean_object* x_337; lean_object* x_338; lean_object* x_339; lean_object* x_340; lean_object* x_341; +x_333 = lean_ctor_get(x_8, 0); +x_334 = lean_ctor_get(x_8, 1); +x_335 = lean_ctor_get(x_8, 2); +x_336 = lean_ctor_get(x_8, 3); +x_337 = lean_ctor_get(x_8, 4); +lean_inc(x_337); +lean_inc(x_336); +lean_inc(x_335); +lean_inc(x_334); +lean_inc(x_333); +lean_dec(x_8); +x_338 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_338, 0, x_259); +lean_ctor_set(x_338, 1, x_24); +x_339 = lean_array_push(x_335, x_338); +x_340 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_340, 0, x_333); +lean_ctor_set(x_340, 1, x_334); +lean_ctor_set(x_340, 2, x_339); +lean_ctor_set(x_340, 3, x_336); +lean_ctor_set(x_340, 4, x_337); +x_341 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_ExprDefEq_18__processConstApprox___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_261, x_340, x_257); +if (lean_obj_tag(x_341) == 0) +{ +lean_object* x_342; lean_object* x_343; lean_object* x_344; +x_342 = lean_ctor_get(x_341, 0); +lean_inc(x_342); +x_343 = lean_ctor_get(x_341, 1); +lean_inc(x_343); +lean_dec(x_341); +x_344 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_344, 0, x_342); +x_266 = x_344; +x_267 = x_343; +goto block_320; +} +else +{ +lean_object* x_345; lean_object* x_346; lean_object* x_347; +x_345 = lean_ctor_get(x_341, 0); +lean_inc(x_345); +x_346 = lean_ctor_get(x_341, 1); +lean_inc(x_346); +lean_dec(x_341); +x_347 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_347, 0, x_345); +x_266 = x_347; +x_267 = x_346; +goto block_320; +} +} +block_320: +{ +if (lean_obj_tag(x_266) == 0) +{ +lean_object* x_268; lean_object* x_269; uint8_t x_270; +x_268 = lean_ctor_get(x_267, 2); +lean_inc(x_268); +x_269 = lean_ctor_get(x_266, 0); +lean_inc(x_269); +lean_dec(x_266); +x_270 = !lean_is_exclusive(x_267); +if (x_270 == 0) +{ +lean_object* x_271; uint8_t x_272; +x_271 = lean_ctor_get(x_267, 2); +lean_dec(x_271); +x_272 = !lean_is_exclusive(x_268); +if (x_272 == 0) +{ +lean_object* x_273; lean_object* x_274; +x_273 = lean_ctor_get(x_268, 2); +lean_dec(x_273); +lean_ctor_set(x_268, 2, x_265); +if (lean_is_scalar(x_258)) { + x_274 = lean_alloc_ctor(1, 2, 0); +} else { + x_274 = x_258; + lean_ctor_set_tag(x_274, 1); +} +lean_ctor_set(x_274, 0, x_269); +lean_ctor_set(x_274, 1, x_267); +return x_274; +} +else +{ +lean_object* x_275; lean_object* x_276; lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; +x_275 = lean_ctor_get(x_268, 0); +x_276 = lean_ctor_get(x_268, 1); +x_277 = lean_ctor_get(x_268, 3); +x_278 = lean_ctor_get(x_268, 4); +lean_inc(x_278); lean_inc(x_277); -if (lean_is_exclusive(x_258)) { - lean_ctor_release(x_258, 0); - lean_ctor_release(x_258, 1); - lean_ctor_release(x_258, 2); - lean_ctor_release(x_258, 3); - x_278 = x_258; -} else { - lean_dec_ref(x_258); - x_278 = lean_box(0); -} -if (lean_is_scalar(x_278)) { - x_279 = lean_alloc_ctor(0, 4, 0); -} else { - x_279 = x_278; -} +lean_inc(x_276); +lean_inc(x_275); +lean_dec(x_268); +x_279 = lean_alloc_ctor(0, 5, 0); lean_ctor_set(x_279, 0, x_275); lean_ctor_set(x_279, 1, x_276); -lean_ctor_set(x_279, 2, x_255); +lean_ctor_set(x_279, 2, x_265); lean_ctor_set(x_279, 3, x_277); -x_280 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_280, 0, x_270); -lean_ctor_set(x_280, 1, x_271); -lean_ctor_set(x_280, 2, x_279); -lean_ctor_set(x_280, 3, x_272); -lean_ctor_set(x_280, 4, x_273); -lean_ctor_set(x_280, 5, x_274); -if (lean_is_scalar(x_248)) { - x_281 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_279, 4, x_278); +lean_ctor_set(x_267, 2, x_279); +if (lean_is_scalar(x_258)) { + x_280 = lean_alloc_ctor(1, 2, 0); } else { - x_281 = x_248; - lean_ctor_set_tag(x_281, 1); + x_280 = x_258; + lean_ctor_set_tag(x_280, 1); } -lean_ctor_set(x_281, 0, x_259); -lean_ctor_set(x_281, 1, x_280); -return x_281; +lean_ctor_set(x_280, 0, x_269); +lean_ctor_set(x_280, 1, x_267); +return x_280; } } else { -lean_object* x_282; lean_object* x_283; uint8_t x_284; -x_282 = lean_ctor_get(x_257, 2); -lean_inc(x_282); -x_283 = lean_ctor_get(x_256, 0); +lean_object* x_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; lean_object* x_289; lean_object* x_290; lean_object* x_291; lean_object* x_292; lean_object* x_293; +x_281 = lean_ctor_get(x_267, 0); +x_282 = lean_ctor_get(x_267, 1); +x_283 = lean_ctor_get(x_267, 3); +x_284 = lean_ctor_get(x_267, 4); +x_285 = lean_ctor_get(x_267, 5); +lean_inc(x_285); +lean_inc(x_284); lean_inc(x_283); -lean_dec(x_256); -x_284 = !lean_is_exclusive(x_257); -if (x_284 == 0) -{ -lean_object* x_285; uint8_t x_286; -x_285 = lean_ctor_get(x_257, 2); -lean_dec(x_285); -x_286 = !lean_is_exclusive(x_282); -if (x_286 == 0) -{ -lean_object* x_287; lean_object* x_288; -x_287 = lean_ctor_get(x_282, 2); -lean_dec(x_287); -lean_ctor_set(x_282, 2, x_255); -if (lean_is_scalar(x_248)) { - x_288 = lean_alloc_ctor(0, 2, 0); -} else { - x_288 = x_248; -} -lean_ctor_set(x_288, 0, x_283); -lean_ctor_set(x_288, 1, x_257); -return x_288; -} -else -{ -lean_object* x_289; lean_object* x_290; lean_object* x_291; lean_object* x_292; lean_object* x_293; -x_289 = lean_ctor_get(x_282, 0); -x_290 = lean_ctor_get(x_282, 1); -x_291 = lean_ctor_get(x_282, 3); -lean_inc(x_291); -lean_inc(x_290); +lean_inc(x_282); +lean_inc(x_281); +lean_dec(x_267); +x_286 = lean_ctor_get(x_268, 0); +lean_inc(x_286); +x_287 = lean_ctor_get(x_268, 1); +lean_inc(x_287); +x_288 = lean_ctor_get(x_268, 3); +lean_inc(x_288); +x_289 = lean_ctor_get(x_268, 4); lean_inc(x_289); -lean_dec(x_282); -x_292 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_292, 0, x_289); -lean_ctor_set(x_292, 1, x_290); -lean_ctor_set(x_292, 2, x_255); -lean_ctor_set(x_292, 3, x_291); -lean_ctor_set(x_257, 2, x_292); -if (lean_is_scalar(x_248)) { - x_293 = lean_alloc_ctor(0, 2, 0); +if (lean_is_exclusive(x_268)) { + lean_ctor_release(x_268, 0); + lean_ctor_release(x_268, 1); + lean_ctor_release(x_268, 2); + lean_ctor_release(x_268, 3); + lean_ctor_release(x_268, 4); + x_290 = x_268; } else { - x_293 = x_248; + lean_dec_ref(x_268); + x_290 = lean_box(0); } -lean_ctor_set(x_293, 0, x_283); -lean_ctor_set(x_293, 1, x_257); +if (lean_is_scalar(x_290)) { + x_291 = lean_alloc_ctor(0, 5, 0); +} else { + x_291 = x_290; +} +lean_ctor_set(x_291, 0, x_286); +lean_ctor_set(x_291, 1, x_287); +lean_ctor_set(x_291, 2, x_265); +lean_ctor_set(x_291, 3, x_288); +lean_ctor_set(x_291, 4, x_289); +x_292 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_292, 0, x_281); +lean_ctor_set(x_292, 1, x_282); +lean_ctor_set(x_292, 2, x_291); +lean_ctor_set(x_292, 3, x_283); +lean_ctor_set(x_292, 4, x_284); +lean_ctor_set(x_292, 5, x_285); +if (lean_is_scalar(x_258)) { + x_293 = lean_alloc_ctor(1, 2, 0); +} else { + x_293 = x_258; + lean_ctor_set_tag(x_293, 1); +} +lean_ctor_set(x_293, 0, x_269); +lean_ctor_set(x_293, 1, x_292); return x_293; } } else { -lean_object* x_294; lean_object* x_295; lean_object* x_296; lean_object* x_297; lean_object* x_298; lean_object* x_299; lean_object* x_300; lean_object* x_301; lean_object* x_302; lean_object* x_303; lean_object* x_304; lean_object* x_305; -x_294 = lean_ctor_get(x_257, 0); -x_295 = lean_ctor_get(x_257, 1); -x_296 = lean_ctor_get(x_257, 3); -x_297 = lean_ctor_get(x_257, 4); -x_298 = lean_ctor_get(x_257, 5); -lean_inc(x_298); -lean_inc(x_297); -lean_inc(x_296); -lean_inc(x_295); +lean_object* x_294; lean_object* x_295; uint8_t x_296; +x_294 = lean_ctor_get(x_267, 2); lean_inc(x_294); -lean_dec(x_257); -x_299 = lean_ctor_get(x_282, 0); -lean_inc(x_299); -x_300 = lean_ctor_get(x_282, 1); -lean_inc(x_300); -x_301 = lean_ctor_get(x_282, 3); +x_295 = lean_ctor_get(x_266, 0); +lean_inc(x_295); +lean_dec(x_266); +x_296 = !lean_is_exclusive(x_267); +if (x_296 == 0) +{ +lean_object* x_297; uint8_t x_298; +x_297 = lean_ctor_get(x_267, 2); +lean_dec(x_297); +x_298 = !lean_is_exclusive(x_294); +if (x_298 == 0) +{ +lean_object* x_299; lean_object* x_300; +x_299 = lean_ctor_get(x_294, 2); +lean_dec(x_299); +lean_ctor_set(x_294, 2, x_265); +if (lean_is_scalar(x_258)) { + x_300 = lean_alloc_ctor(0, 2, 0); +} else { + x_300 = x_258; +} +lean_ctor_set(x_300, 0, x_295); +lean_ctor_set(x_300, 1, x_267); +return x_300; +} +else +{ +lean_object* x_301; lean_object* x_302; lean_object* x_303; lean_object* x_304; lean_object* x_305; lean_object* x_306; +x_301 = lean_ctor_get(x_294, 0); +x_302 = lean_ctor_get(x_294, 1); +x_303 = lean_ctor_get(x_294, 3); +x_304 = lean_ctor_get(x_294, 4); +lean_inc(x_304); +lean_inc(x_303); +lean_inc(x_302); lean_inc(x_301); -if (lean_is_exclusive(x_282)) { - lean_ctor_release(x_282, 0); - lean_ctor_release(x_282, 1); - lean_ctor_release(x_282, 2); - lean_ctor_release(x_282, 3); - x_302 = x_282; +lean_dec(x_294); +x_305 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_305, 0, x_301); +lean_ctor_set(x_305, 1, x_302); +lean_ctor_set(x_305, 2, x_265); +lean_ctor_set(x_305, 3, x_303); +lean_ctor_set(x_305, 4, x_304); +lean_ctor_set(x_267, 2, x_305); +if (lean_is_scalar(x_258)) { + x_306 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_282); - x_302 = lean_box(0); + x_306 = x_258; } -if (lean_is_scalar(x_302)) { - x_303 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_306, 0, x_295); +lean_ctor_set(x_306, 1, x_267); +return x_306; +} +} +else +{ +lean_object* x_307; lean_object* x_308; lean_object* x_309; lean_object* x_310; lean_object* x_311; lean_object* x_312; lean_object* x_313; lean_object* x_314; lean_object* x_315; lean_object* x_316; lean_object* x_317; lean_object* x_318; lean_object* x_319; +x_307 = lean_ctor_get(x_267, 0); +x_308 = lean_ctor_get(x_267, 1); +x_309 = lean_ctor_get(x_267, 3); +x_310 = lean_ctor_get(x_267, 4); +x_311 = lean_ctor_get(x_267, 5); +lean_inc(x_311); +lean_inc(x_310); +lean_inc(x_309); +lean_inc(x_308); +lean_inc(x_307); +lean_dec(x_267); +x_312 = lean_ctor_get(x_294, 0); +lean_inc(x_312); +x_313 = lean_ctor_get(x_294, 1); +lean_inc(x_313); +x_314 = lean_ctor_get(x_294, 3); +lean_inc(x_314); +x_315 = lean_ctor_get(x_294, 4); +lean_inc(x_315); +if (lean_is_exclusive(x_294)) { + lean_ctor_release(x_294, 0); + lean_ctor_release(x_294, 1); + lean_ctor_release(x_294, 2); + lean_ctor_release(x_294, 3); + lean_ctor_release(x_294, 4); + x_316 = x_294; } else { - x_303 = x_302; + lean_dec_ref(x_294); + x_316 = lean_box(0); } -lean_ctor_set(x_303, 0, x_299); -lean_ctor_set(x_303, 1, x_300); -lean_ctor_set(x_303, 2, x_255); -lean_ctor_set(x_303, 3, x_301); -x_304 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_304, 0, x_294); -lean_ctor_set(x_304, 1, x_295); -lean_ctor_set(x_304, 2, x_303); -lean_ctor_set(x_304, 3, x_296); -lean_ctor_set(x_304, 4, x_297); -lean_ctor_set(x_304, 5, x_298); -if (lean_is_scalar(x_248)) { - x_305 = lean_alloc_ctor(0, 2, 0); +if (lean_is_scalar(x_316)) { + x_317 = lean_alloc_ctor(0, 5, 0); } else { - x_305 = x_248; + x_317 = x_316; } -lean_ctor_set(x_305, 0, x_283); -lean_ctor_set(x_305, 1, x_304); -return x_305; +lean_ctor_set(x_317, 0, x_312); +lean_ctor_set(x_317, 1, x_313); +lean_ctor_set(x_317, 2, x_265); +lean_ctor_set(x_317, 3, x_314); +lean_ctor_set(x_317, 4, x_315); +x_318 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_318, 0, x_307); +lean_ctor_set(x_318, 1, x_308); +lean_ctor_set(x_318, 2, x_317); +lean_ctor_set(x_318, 3, x_309); +lean_ctor_set(x_318, 4, x_310); +lean_ctor_set(x_318, 5, x_311); +if (lean_is_scalar(x_258)) { + x_319 = lean_alloc_ctor(0, 2, 0); +} else { + x_319 = x_258; +} +lean_ctor_set(x_319, 0, x_295); +lean_ctor_set(x_319, 1, x_318); +return x_319; } } } } else { -lean_object* x_334; lean_object* x_335; lean_object* x_336; lean_object* x_337; lean_object* x_338; lean_object* x_339; lean_object* x_371; lean_object* x_372; lean_object* x_373; lean_object* x_374; lean_object* x_375; 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; -x_334 = lean_ctor_get(x_253, 0); -x_335 = lean_ctor_get(x_253, 1); -x_336 = lean_ctor_get(x_253, 2); -x_337 = lean_ctor_get(x_253, 3); -lean_inc(x_337); -lean_inc(x_336); -lean_inc(x_335); -lean_inc(x_334); -lean_dec(x_253); -x_371 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_372 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_372, 0, x_334); -lean_ctor_set(x_372, 1, x_335); -lean_ctor_set(x_372, 2, x_371); -lean_ctor_set(x_372, 3, x_337); -lean_ctor_set(x_247, 2, x_372); -x_373 = lean_ctor_get(x_8, 0); -lean_inc(x_373); -x_374 = lean_ctor_get(x_8, 1); -lean_inc(x_374); -x_375 = lean_ctor_get(x_8, 2); -lean_inc(x_375); -x_376 = lean_ctor_get(x_8, 3); -lean_inc(x_376); -x_377 = lean_ctor_get(x_8, 4); -lean_inc(x_377); +lean_object* x_348; lean_object* x_349; lean_object* x_350; lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_388; lean_object* x_389; lean_object* x_390; lean_object* x_391; lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; +x_348 = lean_ctor_get(x_263, 0); +x_349 = lean_ctor_get(x_263, 1); +x_350 = lean_ctor_get(x_263, 2); +x_351 = lean_ctor_get(x_263, 3); +x_352 = lean_ctor_get(x_263, 4); +lean_inc(x_352); +lean_inc(x_351); +lean_inc(x_350); +lean_inc(x_349); +lean_inc(x_348); +lean_dec(x_263); +x_388 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_389 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_389, 0, x_348); +lean_ctor_set(x_389, 1, x_349); +lean_ctor_set(x_389, 2, x_388); +lean_ctor_set(x_389, 3, x_351); +lean_ctor_set(x_389, 4, x_352); +lean_ctor_set(x_257, 2, x_389); +x_390 = lean_ctor_get(x_8, 0); +lean_inc(x_390); +x_391 = lean_ctor_get(x_8, 1); +lean_inc(x_391); +x_392 = lean_ctor_get(x_8, 2); +lean_inc(x_392); +x_393 = lean_ctor_get(x_8, 3); +lean_inc(x_393); +x_394 = lean_ctor_get(x_8, 4); +lean_inc(x_394); if (lean_is_exclusive(x_8)) { lean_ctor_release(x_8, 0); lean_ctor_release(x_8, 1); lean_ctor_release(x_8, 2); lean_ctor_release(x_8, 3); lean_ctor_release(x_8, 4); - x_378 = x_8; + x_395 = x_8; } else { lean_dec_ref(x_8); - x_378 = lean_box(0); + x_395 = lean_box(0); } -x_379 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_379, 0, x_249); -lean_ctor_set(x_379, 1, x_24); -x_380 = lean_array_push(x_375, x_379); -if (lean_is_scalar(x_378)) { - x_381 = lean_alloc_ctor(0, 5, 0); +x_396 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_396, 0, x_259); +lean_ctor_set(x_396, 1, x_24); +x_397 = lean_array_push(x_392, x_396); +if (lean_is_scalar(x_395)) { + x_398 = lean_alloc_ctor(0, 5, 0); } else { - x_381 = x_378; + x_398 = x_395; } -lean_ctor_set(x_381, 0, x_373); -lean_ctor_set(x_381, 1, x_374); -lean_ctor_set(x_381, 2, x_380); -lean_ctor_set(x_381, 3, x_376); -lean_ctor_set(x_381, 4, x_377); -x_382 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_ExprDefEq_18__processConstApprox___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_251, x_381, x_247); -if (lean_obj_tag(x_382) == 0) +lean_ctor_set(x_398, 0, x_390); +lean_ctor_set(x_398, 1, x_391); +lean_ctor_set(x_398, 2, x_397); +lean_ctor_set(x_398, 3, x_393); +lean_ctor_set(x_398, 4, x_394); +x_399 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_ExprDefEq_18__processConstApprox___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_261, x_398, x_257); +if (lean_obj_tag(x_399) == 0) { -lean_object* x_383; lean_object* x_384; lean_object* x_385; -x_383 = lean_ctor_get(x_382, 0); -lean_inc(x_383); -x_384 = lean_ctor_get(x_382, 1); -lean_inc(x_384); -lean_dec(x_382); -x_385 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_385, 0, x_383); -x_338 = x_385; -x_339 = x_384; -goto block_370; +lean_object* x_400; lean_object* x_401; lean_object* x_402; +x_400 = lean_ctor_get(x_399, 0); +lean_inc(x_400); +x_401 = lean_ctor_get(x_399, 1); +lean_inc(x_401); +lean_dec(x_399); +x_402 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_402, 0, x_400); +x_353 = x_402; +x_354 = x_401; +goto block_387; } else { -lean_object* x_386; lean_object* x_387; lean_object* x_388; -x_386 = lean_ctor_get(x_382, 0); -lean_inc(x_386); -x_387 = lean_ctor_get(x_382, 1); -lean_inc(x_387); -lean_dec(x_382); -x_388 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_388, 0, x_386); -x_338 = x_388; -x_339 = x_387; -goto block_370; +lean_object* x_403; lean_object* x_404; lean_object* x_405; +x_403 = lean_ctor_get(x_399, 0); +lean_inc(x_403); +x_404 = lean_ctor_get(x_399, 1); +lean_inc(x_404); +lean_dec(x_399); +x_405 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_405, 0, x_403); +x_353 = x_405; +x_354 = x_404; +goto block_387; } -block_370: +block_387: { -if (lean_obj_tag(x_338) == 0) +if (lean_obj_tag(x_353) == 0) { -lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; lean_object* x_350; lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; -x_340 = lean_ctor_get(x_339, 2); -lean_inc(x_340); -x_341 = lean_ctor_get(x_338, 0); -lean_inc(x_341); -lean_dec(x_338); -x_342 = lean_ctor_get(x_339, 0); -lean_inc(x_342); -x_343 = lean_ctor_get(x_339, 1); -lean_inc(x_343); -x_344 = lean_ctor_get(x_339, 3); -lean_inc(x_344); -x_345 = lean_ctor_get(x_339, 4); -lean_inc(x_345); -x_346 = lean_ctor_get(x_339, 5); -lean_inc(x_346); -if (lean_is_exclusive(x_339)) { - lean_ctor_release(x_339, 0); - lean_ctor_release(x_339, 1); - lean_ctor_release(x_339, 2); - lean_ctor_release(x_339, 3); - lean_ctor_release(x_339, 4); - lean_ctor_release(x_339, 5); - x_347 = x_339; -} else { - lean_dec_ref(x_339); - x_347 = lean_box(0); -} -x_348 = lean_ctor_get(x_340, 0); -lean_inc(x_348); -x_349 = lean_ctor_get(x_340, 1); -lean_inc(x_349); -x_350 = lean_ctor_get(x_340, 3); -lean_inc(x_350); -if (lean_is_exclusive(x_340)) { - lean_ctor_release(x_340, 0); - lean_ctor_release(x_340, 1); - lean_ctor_release(x_340, 2); - lean_ctor_release(x_340, 3); - x_351 = x_340; -} else { - lean_dec_ref(x_340); - x_351 = lean_box(0); -} -if (lean_is_scalar(x_351)) { - x_352 = lean_alloc_ctor(0, 4, 0); -} else { - x_352 = x_351; -} -lean_ctor_set(x_352, 0, x_348); -lean_ctor_set(x_352, 1, x_349); -lean_ctor_set(x_352, 2, x_336); -lean_ctor_set(x_352, 3, x_350); -if (lean_is_scalar(x_347)) { - x_353 = lean_alloc_ctor(0, 6, 0); -} else { - x_353 = x_347; -} -lean_ctor_set(x_353, 0, x_342); -lean_ctor_set(x_353, 1, x_343); -lean_ctor_set(x_353, 2, x_352); -lean_ctor_set(x_353, 3, x_344); -lean_ctor_set(x_353, 4, x_345); -lean_ctor_set(x_353, 5, x_346); -if (lean_is_scalar(x_248)) { - x_354 = lean_alloc_ctor(1, 2, 0); -} else { - x_354 = x_248; - lean_ctor_set_tag(x_354, 1); -} -lean_ctor_set(x_354, 0, x_341); -lean_ctor_set(x_354, 1, x_353); -return x_354; -} -else -{ -lean_object* x_355; lean_object* x_356; lean_object* x_357; 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; -x_355 = lean_ctor_get(x_339, 2); +lean_object* x_355; lean_object* x_356; lean_object* x_357; 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; +x_355 = lean_ctor_get(x_354, 2); lean_inc(x_355); -x_356 = lean_ctor_get(x_338, 0); +x_356 = lean_ctor_get(x_353, 0); lean_inc(x_356); -lean_dec(x_338); -x_357 = lean_ctor_get(x_339, 0); +lean_dec(x_353); +x_357 = lean_ctor_get(x_354, 0); lean_inc(x_357); -x_358 = lean_ctor_get(x_339, 1); +x_358 = lean_ctor_get(x_354, 1); lean_inc(x_358); -x_359 = lean_ctor_get(x_339, 3); +x_359 = lean_ctor_get(x_354, 3); lean_inc(x_359); -x_360 = lean_ctor_get(x_339, 4); +x_360 = lean_ctor_get(x_354, 4); lean_inc(x_360); -x_361 = lean_ctor_get(x_339, 5); +x_361 = lean_ctor_get(x_354, 5); lean_inc(x_361); -if (lean_is_exclusive(x_339)) { - lean_ctor_release(x_339, 0); - lean_ctor_release(x_339, 1); - lean_ctor_release(x_339, 2); - lean_ctor_release(x_339, 3); - lean_ctor_release(x_339, 4); - lean_ctor_release(x_339, 5); - x_362 = x_339; +if (lean_is_exclusive(x_354)) { + lean_ctor_release(x_354, 0); + lean_ctor_release(x_354, 1); + lean_ctor_release(x_354, 2); + lean_ctor_release(x_354, 3); + lean_ctor_release(x_354, 4); + lean_ctor_release(x_354, 5); + x_362 = x_354; } else { - lean_dec_ref(x_339); + lean_dec_ref(x_354); x_362 = lean_box(0); } x_363 = lean_ctor_get(x_355, 0); @@ -35582,315 +36004,411 @@ x_364 = lean_ctor_get(x_355, 1); lean_inc(x_364); x_365 = lean_ctor_get(x_355, 3); lean_inc(x_365); +x_366 = lean_ctor_get(x_355, 4); +lean_inc(x_366); if (lean_is_exclusive(x_355)) { lean_ctor_release(x_355, 0); lean_ctor_release(x_355, 1); lean_ctor_release(x_355, 2); lean_ctor_release(x_355, 3); - x_366 = x_355; + lean_ctor_release(x_355, 4); + x_367 = x_355; } else { lean_dec_ref(x_355); - x_366 = lean_box(0); + x_367 = lean_box(0); } -if (lean_is_scalar(x_366)) { - x_367 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_367)) { + x_368 = lean_alloc_ctor(0, 5, 0); } else { - x_367 = x_366; + x_368 = x_367; } -lean_ctor_set(x_367, 0, x_363); -lean_ctor_set(x_367, 1, x_364); -lean_ctor_set(x_367, 2, x_336); -lean_ctor_set(x_367, 3, x_365); +lean_ctor_set(x_368, 0, x_363); +lean_ctor_set(x_368, 1, x_364); +lean_ctor_set(x_368, 2, x_350); +lean_ctor_set(x_368, 3, x_365); +lean_ctor_set(x_368, 4, x_366); if (lean_is_scalar(x_362)) { - x_368 = lean_alloc_ctor(0, 6, 0); + x_369 = lean_alloc_ctor(0, 6, 0); } else { - x_368 = x_362; + x_369 = x_362; } -lean_ctor_set(x_368, 0, x_357); -lean_ctor_set(x_368, 1, x_358); -lean_ctor_set(x_368, 2, x_367); -lean_ctor_set(x_368, 3, x_359); -lean_ctor_set(x_368, 4, x_360); -lean_ctor_set(x_368, 5, x_361); -if (lean_is_scalar(x_248)) { - x_369 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_369, 0, x_357); +lean_ctor_set(x_369, 1, x_358); +lean_ctor_set(x_369, 2, x_368); +lean_ctor_set(x_369, 3, x_359); +lean_ctor_set(x_369, 4, x_360); +lean_ctor_set(x_369, 5, x_361); +if (lean_is_scalar(x_258)) { + x_370 = lean_alloc_ctor(1, 2, 0); } else { - x_369 = x_248; + x_370 = x_258; + lean_ctor_set_tag(x_370, 1); } -lean_ctor_set(x_369, 0, x_356); -lean_ctor_set(x_369, 1, x_368); -return x_369; +lean_ctor_set(x_370, 0, x_356); +lean_ctor_set(x_370, 1, x_369); +return x_370; +} +else +{ +lean_object* x_371; lean_object* x_372; lean_object* x_373; lean_object* x_374; lean_object* x_375; 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; +x_371 = lean_ctor_get(x_354, 2); +lean_inc(x_371); +x_372 = lean_ctor_get(x_353, 0); +lean_inc(x_372); +lean_dec(x_353); +x_373 = lean_ctor_get(x_354, 0); +lean_inc(x_373); +x_374 = lean_ctor_get(x_354, 1); +lean_inc(x_374); +x_375 = lean_ctor_get(x_354, 3); +lean_inc(x_375); +x_376 = lean_ctor_get(x_354, 4); +lean_inc(x_376); +x_377 = lean_ctor_get(x_354, 5); +lean_inc(x_377); +if (lean_is_exclusive(x_354)) { + lean_ctor_release(x_354, 0); + lean_ctor_release(x_354, 1); + lean_ctor_release(x_354, 2); + lean_ctor_release(x_354, 3); + lean_ctor_release(x_354, 4); + lean_ctor_release(x_354, 5); + x_378 = x_354; +} else { + lean_dec_ref(x_354); + x_378 = lean_box(0); +} +x_379 = lean_ctor_get(x_371, 0); +lean_inc(x_379); +x_380 = lean_ctor_get(x_371, 1); +lean_inc(x_380); +x_381 = lean_ctor_get(x_371, 3); +lean_inc(x_381); +x_382 = lean_ctor_get(x_371, 4); +lean_inc(x_382); +if (lean_is_exclusive(x_371)) { + lean_ctor_release(x_371, 0); + lean_ctor_release(x_371, 1); + lean_ctor_release(x_371, 2); + lean_ctor_release(x_371, 3); + lean_ctor_release(x_371, 4); + x_383 = x_371; +} else { + lean_dec_ref(x_371); + x_383 = lean_box(0); +} +if (lean_is_scalar(x_383)) { + x_384 = lean_alloc_ctor(0, 5, 0); +} else { + x_384 = x_383; +} +lean_ctor_set(x_384, 0, x_379); +lean_ctor_set(x_384, 1, x_380); +lean_ctor_set(x_384, 2, x_350); +lean_ctor_set(x_384, 3, x_381); +lean_ctor_set(x_384, 4, x_382); +if (lean_is_scalar(x_378)) { + x_385 = lean_alloc_ctor(0, 6, 0); +} else { + x_385 = x_378; +} +lean_ctor_set(x_385, 0, x_373); +lean_ctor_set(x_385, 1, x_374); +lean_ctor_set(x_385, 2, x_384); +lean_ctor_set(x_385, 3, x_375); +lean_ctor_set(x_385, 4, x_376); +lean_ctor_set(x_385, 5, x_377); +if (lean_is_scalar(x_258)) { + x_386 = lean_alloc_ctor(0, 2, 0); +} else { + x_386 = x_258; +} +lean_ctor_set(x_386, 0, x_372); +lean_ctor_set(x_386, 1, x_385); +return x_386; } } } } else { -lean_object* x_389; lean_object* x_390; lean_object* x_391; lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; lean_object* x_400; lean_object* x_401; 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; lean_object* x_445; -x_389 = lean_ctor_get(x_247, 2); -x_390 = lean_ctor_get(x_247, 0); -x_391 = lean_ctor_get(x_247, 1); -x_392 = lean_ctor_get(x_247, 3); -x_393 = lean_ctor_get(x_247, 4); -x_394 = lean_ctor_get(x_247, 5); -lean_inc(x_394); -lean_inc(x_393); -lean_inc(x_392); -lean_inc(x_389); -lean_inc(x_391); -lean_inc(x_390); -lean_dec(x_247); -x_395 = lean_ctor_get(x_389, 0); -lean_inc(x_395); -x_396 = lean_ctor_get(x_389, 1); -lean_inc(x_396); -x_397 = lean_ctor_get(x_389, 2); -lean_inc(x_397); -x_398 = lean_ctor_get(x_389, 3); -lean_inc(x_398); -if (lean_is_exclusive(x_389)) { - lean_ctor_release(x_389, 0); - lean_ctor_release(x_389, 1); - lean_ctor_release(x_389, 2); - lean_ctor_release(x_389, 3); - x_399 = x_389; +lean_object* x_406; lean_object* x_407; lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_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_453; lean_object* x_454; lean_object* x_455; lean_object* x_456; lean_object* x_457; lean_object* x_458; lean_object* x_459; lean_object* x_460; lean_object* x_461; lean_object* x_462; lean_object* x_463; lean_object* x_464; lean_object* x_465; +x_406 = lean_ctor_get(x_257, 2); +x_407 = lean_ctor_get(x_257, 0); +x_408 = lean_ctor_get(x_257, 1); +x_409 = lean_ctor_get(x_257, 3); +x_410 = lean_ctor_get(x_257, 4); +x_411 = lean_ctor_get(x_257, 5); +lean_inc(x_411); +lean_inc(x_410); +lean_inc(x_409); +lean_inc(x_406); +lean_inc(x_408); +lean_inc(x_407); +lean_dec(x_257); +x_412 = lean_ctor_get(x_406, 0); +lean_inc(x_412); +x_413 = lean_ctor_get(x_406, 1); +lean_inc(x_413); +x_414 = lean_ctor_get(x_406, 2); +lean_inc(x_414); +x_415 = lean_ctor_get(x_406, 3); +lean_inc(x_415); +x_416 = lean_ctor_get(x_406, 4); +lean_inc(x_416); +if (lean_is_exclusive(x_406)) { + lean_ctor_release(x_406, 0); + lean_ctor_release(x_406, 1); + lean_ctor_release(x_406, 2); + lean_ctor_release(x_406, 3); + lean_ctor_release(x_406, 4); + x_417 = x_406; } else { - lean_dec_ref(x_389); - x_399 = lean_box(0); + lean_dec_ref(x_406); + x_417 = lean_box(0); } -x_433 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_399)) { - x_434 = lean_alloc_ctor(0, 4, 0); +x_453 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_417)) { + x_454 = lean_alloc_ctor(0, 5, 0); } else { - x_434 = x_399; + x_454 = x_417; } -lean_ctor_set(x_434, 0, x_395); -lean_ctor_set(x_434, 1, x_396); -lean_ctor_set(x_434, 2, x_433); -lean_ctor_set(x_434, 3, x_398); -x_435 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_435, 0, x_390); -lean_ctor_set(x_435, 1, x_391); -lean_ctor_set(x_435, 2, x_434); -lean_ctor_set(x_435, 3, x_392); -lean_ctor_set(x_435, 4, x_393); -lean_ctor_set(x_435, 5, x_394); -x_436 = lean_ctor_get(x_8, 0); -lean_inc(x_436); -x_437 = lean_ctor_get(x_8, 1); -lean_inc(x_437); -x_438 = lean_ctor_get(x_8, 2); -lean_inc(x_438); -x_439 = lean_ctor_get(x_8, 3); -lean_inc(x_439); -x_440 = lean_ctor_get(x_8, 4); -lean_inc(x_440); +lean_ctor_set(x_454, 0, x_412); +lean_ctor_set(x_454, 1, x_413); +lean_ctor_set(x_454, 2, x_453); +lean_ctor_set(x_454, 3, x_415); +lean_ctor_set(x_454, 4, x_416); +x_455 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_455, 0, x_407); +lean_ctor_set(x_455, 1, x_408); +lean_ctor_set(x_455, 2, x_454); +lean_ctor_set(x_455, 3, x_409); +lean_ctor_set(x_455, 4, x_410); +lean_ctor_set(x_455, 5, x_411); +x_456 = lean_ctor_get(x_8, 0); +lean_inc(x_456); +x_457 = lean_ctor_get(x_8, 1); +lean_inc(x_457); +x_458 = lean_ctor_get(x_8, 2); +lean_inc(x_458); +x_459 = lean_ctor_get(x_8, 3); +lean_inc(x_459); +x_460 = lean_ctor_get(x_8, 4); +lean_inc(x_460); if (lean_is_exclusive(x_8)) { lean_ctor_release(x_8, 0); lean_ctor_release(x_8, 1); lean_ctor_release(x_8, 2); lean_ctor_release(x_8, 3); lean_ctor_release(x_8, 4); - x_441 = x_8; + x_461 = x_8; } else { lean_dec_ref(x_8); - x_441 = lean_box(0); + x_461 = lean_box(0); } -x_442 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_442, 0, x_249); -lean_ctor_set(x_442, 1, x_24); -x_443 = lean_array_push(x_438, x_442); -if (lean_is_scalar(x_441)) { - x_444 = lean_alloc_ctor(0, 5, 0); +x_462 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_462, 0, x_259); +lean_ctor_set(x_462, 1, x_24); +x_463 = lean_array_push(x_458, x_462); +if (lean_is_scalar(x_461)) { + x_464 = lean_alloc_ctor(0, 5, 0); } else { - x_444 = x_441; + x_464 = x_461; } -lean_ctor_set(x_444, 0, x_436); -lean_ctor_set(x_444, 1, x_437); -lean_ctor_set(x_444, 2, x_443); -lean_ctor_set(x_444, 3, x_439); -lean_ctor_set(x_444, 4, x_440); -x_445 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_ExprDefEq_18__processConstApprox___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_251, x_444, x_435); -if (lean_obj_tag(x_445) == 0) +lean_ctor_set(x_464, 0, x_456); +lean_ctor_set(x_464, 1, x_457); +lean_ctor_set(x_464, 2, x_463); +lean_ctor_set(x_464, 3, x_459); +lean_ctor_set(x_464, 4, x_460); +x_465 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_ExprDefEq_18__processConstApprox___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_261, x_464, x_455); +if (lean_obj_tag(x_465) == 0) { -lean_object* x_446; lean_object* x_447; lean_object* x_448; -x_446 = lean_ctor_get(x_445, 0); -lean_inc(x_446); -x_447 = lean_ctor_get(x_445, 1); -lean_inc(x_447); -lean_dec(x_445); -x_448 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_448, 0, x_446); -x_400 = x_448; -x_401 = x_447; -goto block_432; +lean_object* x_466; lean_object* x_467; lean_object* x_468; +x_466 = lean_ctor_get(x_465, 0); +lean_inc(x_466); +x_467 = lean_ctor_get(x_465, 1); +lean_inc(x_467); +lean_dec(x_465); +x_468 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_468, 0, x_466); +x_418 = x_468; +x_419 = x_467; +goto block_452; } else { -lean_object* x_449; lean_object* x_450; lean_object* x_451; -x_449 = lean_ctor_get(x_445, 0); -lean_inc(x_449); -x_450 = lean_ctor_get(x_445, 1); -lean_inc(x_450); -lean_dec(x_445); -x_451 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_451, 0, x_449); -x_400 = x_451; -x_401 = x_450; -goto block_432; +lean_object* x_469; lean_object* x_470; lean_object* x_471; +x_469 = lean_ctor_get(x_465, 0); +lean_inc(x_469); +x_470 = lean_ctor_get(x_465, 1); +lean_inc(x_470); +lean_dec(x_465); +x_471 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_471, 0, x_469); +x_418 = x_471; +x_419 = x_470; +goto block_452; } -block_432: +block_452: { -if (lean_obj_tag(x_400) == 0) +if (lean_obj_tag(x_418) == 0) { -lean_object* x_402; lean_object* x_403; lean_object* x_404; lean_object* x_405; lean_object* x_406; lean_object* x_407; lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_object* x_412; lean_object* x_413; lean_object* x_414; lean_object* x_415; lean_object* x_416; -x_402 = lean_ctor_get(x_401, 2); -lean_inc(x_402); -x_403 = lean_ctor_get(x_400, 0); -lean_inc(x_403); -lean_dec(x_400); -x_404 = lean_ctor_get(x_401, 0); -lean_inc(x_404); -x_405 = lean_ctor_get(x_401, 1); -lean_inc(x_405); -x_406 = lean_ctor_get(x_401, 3); -lean_inc(x_406); -x_407 = lean_ctor_get(x_401, 4); -lean_inc(x_407); -x_408 = lean_ctor_get(x_401, 5); -lean_inc(x_408); -if (lean_is_exclusive(x_401)) { - lean_ctor_release(x_401, 0); - lean_ctor_release(x_401, 1); - lean_ctor_release(x_401, 2); - lean_ctor_release(x_401, 3); - lean_ctor_release(x_401, 4); - lean_ctor_release(x_401, 5); - x_409 = x_401; -} else { - lean_dec_ref(x_401); - x_409 = lean_box(0); -} -x_410 = lean_ctor_get(x_402, 0); -lean_inc(x_410); -x_411 = lean_ctor_get(x_402, 1); -lean_inc(x_411); -x_412 = lean_ctor_get(x_402, 3); -lean_inc(x_412); -if (lean_is_exclusive(x_402)) { - lean_ctor_release(x_402, 0); - lean_ctor_release(x_402, 1); - lean_ctor_release(x_402, 2); - lean_ctor_release(x_402, 3); - x_413 = x_402; -} else { - lean_dec_ref(x_402); - x_413 = lean_box(0); -} -if (lean_is_scalar(x_413)) { - x_414 = lean_alloc_ctor(0, 4, 0); -} else { - x_414 = x_413; -} -lean_ctor_set(x_414, 0, x_410); -lean_ctor_set(x_414, 1, x_411); -lean_ctor_set(x_414, 2, x_397); -lean_ctor_set(x_414, 3, x_412); -if (lean_is_scalar(x_409)) { - x_415 = lean_alloc_ctor(0, 6, 0); -} else { - x_415 = x_409; -} -lean_ctor_set(x_415, 0, x_404); -lean_ctor_set(x_415, 1, x_405); -lean_ctor_set(x_415, 2, x_414); -lean_ctor_set(x_415, 3, x_406); -lean_ctor_set(x_415, 4, x_407); -lean_ctor_set(x_415, 5, x_408); -if (lean_is_scalar(x_248)) { - x_416 = lean_alloc_ctor(1, 2, 0); -} else { - x_416 = x_248; - lean_ctor_set_tag(x_416, 1); -} -lean_ctor_set(x_416, 0, x_403); -lean_ctor_set(x_416, 1, x_415); -return x_416; -} -else -{ -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; lean_object* x_426; lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; -x_417 = lean_ctor_get(x_401, 2); -lean_inc(x_417); -x_418 = lean_ctor_get(x_400, 0); -lean_inc(x_418); -lean_dec(x_400); -x_419 = lean_ctor_get(x_401, 0); -lean_inc(x_419); -x_420 = lean_ctor_get(x_401, 1); +lean_object* x_420; lean_object* x_421; lean_object* x_422; lean_object* x_423; lean_object* x_424; lean_object* x_425; lean_object* x_426; lean_object* x_427; 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; +x_420 = lean_ctor_get(x_419, 2); lean_inc(x_420); -x_421 = lean_ctor_get(x_401, 3); +x_421 = lean_ctor_get(x_418, 0); lean_inc(x_421); -x_422 = lean_ctor_get(x_401, 4); +lean_dec(x_418); +x_422 = lean_ctor_get(x_419, 0); lean_inc(x_422); -x_423 = lean_ctor_get(x_401, 5); +x_423 = lean_ctor_get(x_419, 1); lean_inc(x_423); -if (lean_is_exclusive(x_401)) { - lean_ctor_release(x_401, 0); - lean_ctor_release(x_401, 1); - lean_ctor_release(x_401, 2); - lean_ctor_release(x_401, 3); - lean_ctor_release(x_401, 4); - lean_ctor_release(x_401, 5); - x_424 = x_401; -} else { - lean_dec_ref(x_401); - x_424 = lean_box(0); -} -x_425 = lean_ctor_get(x_417, 0); +x_424 = lean_ctor_get(x_419, 3); +lean_inc(x_424); +x_425 = lean_ctor_get(x_419, 4); lean_inc(x_425); -x_426 = lean_ctor_get(x_417, 1); +x_426 = lean_ctor_get(x_419, 5); lean_inc(x_426); -x_427 = lean_ctor_get(x_417, 3); -lean_inc(x_427); -if (lean_is_exclusive(x_417)) { - lean_ctor_release(x_417, 0); - lean_ctor_release(x_417, 1); - lean_ctor_release(x_417, 2); - lean_ctor_release(x_417, 3); - x_428 = x_417; +if (lean_is_exclusive(x_419)) { + lean_ctor_release(x_419, 0); + lean_ctor_release(x_419, 1); + lean_ctor_release(x_419, 2); + lean_ctor_release(x_419, 3); + lean_ctor_release(x_419, 4); + lean_ctor_release(x_419, 5); + x_427 = x_419; } else { - lean_dec_ref(x_417); - x_428 = lean_box(0); + lean_dec_ref(x_419); + x_427 = lean_box(0); } -if (lean_is_scalar(x_428)) { - x_429 = lean_alloc_ctor(0, 4, 0); +x_428 = lean_ctor_get(x_420, 0); +lean_inc(x_428); +x_429 = lean_ctor_get(x_420, 1); +lean_inc(x_429); +x_430 = lean_ctor_get(x_420, 3); +lean_inc(x_430); +x_431 = lean_ctor_get(x_420, 4); +lean_inc(x_431); +if (lean_is_exclusive(x_420)) { + lean_ctor_release(x_420, 0); + lean_ctor_release(x_420, 1); + lean_ctor_release(x_420, 2); + lean_ctor_release(x_420, 3); + lean_ctor_release(x_420, 4); + x_432 = x_420; } else { - x_429 = x_428; + lean_dec_ref(x_420); + x_432 = lean_box(0); } -lean_ctor_set(x_429, 0, x_425); -lean_ctor_set(x_429, 1, x_426); -lean_ctor_set(x_429, 2, x_397); -lean_ctor_set(x_429, 3, x_427); -if (lean_is_scalar(x_424)) { - x_430 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_432)) { + x_433 = lean_alloc_ctor(0, 5, 0); } else { - x_430 = x_424; + x_433 = x_432; } -lean_ctor_set(x_430, 0, x_419); -lean_ctor_set(x_430, 1, x_420); -lean_ctor_set(x_430, 2, x_429); -lean_ctor_set(x_430, 3, x_421); -lean_ctor_set(x_430, 4, x_422); -lean_ctor_set(x_430, 5, x_423); -if (lean_is_scalar(x_248)) { - x_431 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_433, 0, x_428); +lean_ctor_set(x_433, 1, x_429); +lean_ctor_set(x_433, 2, x_414); +lean_ctor_set(x_433, 3, x_430); +lean_ctor_set(x_433, 4, x_431); +if (lean_is_scalar(x_427)) { + x_434 = lean_alloc_ctor(0, 6, 0); } else { - x_431 = x_248; + x_434 = x_427; } -lean_ctor_set(x_431, 0, x_418); -lean_ctor_set(x_431, 1, x_430); -return x_431; +lean_ctor_set(x_434, 0, x_422); +lean_ctor_set(x_434, 1, x_423); +lean_ctor_set(x_434, 2, x_433); +lean_ctor_set(x_434, 3, x_424); +lean_ctor_set(x_434, 4, x_425); +lean_ctor_set(x_434, 5, x_426); +if (lean_is_scalar(x_258)) { + x_435 = lean_alloc_ctor(1, 2, 0); +} else { + x_435 = x_258; + lean_ctor_set_tag(x_435, 1); +} +lean_ctor_set(x_435, 0, x_421); +lean_ctor_set(x_435, 1, x_434); +return x_435; +} +else +{ +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; lean_object* x_445; lean_object* x_446; lean_object* x_447; lean_object* x_448; lean_object* x_449; lean_object* x_450; lean_object* x_451; +x_436 = lean_ctor_get(x_419, 2); +lean_inc(x_436); +x_437 = lean_ctor_get(x_418, 0); +lean_inc(x_437); +lean_dec(x_418); +x_438 = lean_ctor_get(x_419, 0); +lean_inc(x_438); +x_439 = lean_ctor_get(x_419, 1); +lean_inc(x_439); +x_440 = lean_ctor_get(x_419, 3); +lean_inc(x_440); +x_441 = lean_ctor_get(x_419, 4); +lean_inc(x_441); +x_442 = lean_ctor_get(x_419, 5); +lean_inc(x_442); +if (lean_is_exclusive(x_419)) { + lean_ctor_release(x_419, 0); + lean_ctor_release(x_419, 1); + lean_ctor_release(x_419, 2); + lean_ctor_release(x_419, 3); + lean_ctor_release(x_419, 4); + lean_ctor_release(x_419, 5); + x_443 = x_419; +} else { + lean_dec_ref(x_419); + x_443 = lean_box(0); +} +x_444 = lean_ctor_get(x_436, 0); +lean_inc(x_444); +x_445 = lean_ctor_get(x_436, 1); +lean_inc(x_445); +x_446 = lean_ctor_get(x_436, 3); +lean_inc(x_446); +x_447 = lean_ctor_get(x_436, 4); +lean_inc(x_447); +if (lean_is_exclusive(x_436)) { + lean_ctor_release(x_436, 0); + lean_ctor_release(x_436, 1); + lean_ctor_release(x_436, 2); + lean_ctor_release(x_436, 3); + lean_ctor_release(x_436, 4); + x_448 = x_436; +} else { + lean_dec_ref(x_436); + x_448 = lean_box(0); +} +if (lean_is_scalar(x_448)) { + x_449 = lean_alloc_ctor(0, 5, 0); +} else { + x_449 = x_448; +} +lean_ctor_set(x_449, 0, x_444); +lean_ctor_set(x_449, 1, x_445); +lean_ctor_set(x_449, 2, x_414); +lean_ctor_set(x_449, 3, x_446); +lean_ctor_set(x_449, 4, x_447); +if (lean_is_scalar(x_443)) { + x_450 = lean_alloc_ctor(0, 6, 0); +} else { + x_450 = x_443; +} +lean_ctor_set(x_450, 0, x_438); +lean_ctor_set(x_450, 1, x_439); +lean_ctor_set(x_450, 2, x_449); +lean_ctor_set(x_450, 3, x_440); +lean_ctor_set(x_450, 4, x_441); +lean_ctor_set(x_450, 5, x_442); +if (lean_is_scalar(x_258)) { + x_451 = lean_alloc_ctor(0, 2, 0); +} else { + x_451 = x_258; +} +lean_ctor_set(x_451, 0, x_437); +lean_ctor_set(x_451, 1, x_450); +return x_451; } } } @@ -35898,30 +36416,30 @@ return x_431; } else { -uint8_t x_452; +uint8_t x_472; lean_dec(x_24); lean_dec(x_8); lean_dec(x_7); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_452 = !lean_is_exclusive(x_241); -if (x_452 == 0) +x_472 = !lean_is_exclusive(x_251); +if (x_472 == 0) { -return x_241; +return x_251; } else { -lean_object* x_453; lean_object* x_454; lean_object* x_455; -x_453 = lean_ctor_get(x_241, 0); -x_454 = lean_ctor_get(x_241, 1); -lean_inc(x_454); -lean_inc(x_453); -lean_dec(x_241); -x_455 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_455, 0, x_453); -lean_ctor_set(x_455, 1, x_454); -return x_455; +lean_object* x_473; lean_object* x_474; lean_object* x_475; +x_473 = lean_ctor_get(x_251, 0); +x_474 = lean_ctor_get(x_251, 1); +lean_inc(x_474); +lean_inc(x_473); +lean_dec(x_251); +x_475 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_475, 0, x_473); +lean_ctor_set(x_475, 1, x_474); +return x_475; } } } @@ -35929,7 +36447,7 @@ return x_455; } else { -uint8_t x_456; +uint8_t x_476; lean_dec(x_28); lean_dec(x_24); lean_dec(x_8); @@ -35937,52 +36455,52 @@ lean_dec(x_7); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_456 = !lean_is_exclusive(x_29); -if (x_456 == 0) +x_476 = !lean_is_exclusive(x_29); +if (x_476 == 0) { return x_29; } else { -lean_object* x_457; lean_object* x_458; lean_object* x_459; -x_457 = lean_ctor_get(x_29, 0); -x_458 = lean_ctor_get(x_29, 1); -lean_inc(x_458); -lean_inc(x_457); +lean_object* x_477; lean_object* x_478; lean_object* x_479; +x_477 = lean_ctor_get(x_29, 0); +x_478 = lean_ctor_get(x_29, 1); +lean_inc(x_478); +lean_inc(x_477); lean_dec(x_29); -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_479 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_479, 0, x_477); +lean_ctor_set(x_479, 1, x_478); +return x_479; } } } else { -uint8_t x_460; +uint8_t x_480; lean_dec(x_24); lean_dec(x_8); lean_dec(x_7); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_460 = !lean_is_exclusive(x_25); -if (x_460 == 0) +x_480 = !lean_is_exclusive(x_25); +if (x_480 == 0) { return x_25; } else { -lean_object* x_461; lean_object* x_462; lean_object* x_463; -x_461 = lean_ctor_get(x_25, 0); -x_462 = lean_ctor_get(x_25, 1); -lean_inc(x_462); -lean_inc(x_461); +lean_object* x_481; lean_object* x_482; lean_object* x_483; +x_481 = lean_ctor_get(x_25, 0); +x_482 = lean_ctor_get(x_25, 1); +lean_inc(x_482); +lean_inc(x_481); lean_dec(x_25); -x_463 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_463, 0, x_461); -lean_ctor_set(x_463, 1, x_462); -return x_463; +x_483 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_483, 0, x_481); +lean_ctor_set(x_483, 1, x_482); +return x_483; } } } diff --git a/stage0/stdlib/Lean/Meta/FunInfo.c b/stage0/stdlib/Lean/Meta/FunInfo.c index 5c159f7a35..d37ff06147 100644 --- a/stage0/stdlib/Lean/Meta/FunInfo.c +++ b/stage0/stdlib/Lean/Meta/FunInfo.c @@ -1610,97 +1610,104 @@ return x_12; } else { -lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; +lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; x_23 = lean_ctor_get(x_14, 0); x_24 = lean_ctor_get(x_14, 1); x_25 = lean_ctor_get(x_14, 2); x_26 = lean_ctor_get(x_14, 3); +x_27 = lean_ctor_get(x_14, 4); +lean_inc(x_27); lean_inc(x_26); lean_inc(x_25); lean_inc(x_24); lean_inc(x_23); lean_dec(x_14); lean_inc(x_16); -x_27 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4(x_24, x_10, x_16); -x_28 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_28, 0, x_23); -lean_ctor_set(x_28, 1, x_27); -lean_ctor_set(x_28, 2, x_25); -lean_ctor_set(x_28, 3, x_26); -lean_ctor_set(x_13, 2, x_28); +x_28 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4(x_24, x_10, x_16); +x_29 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_29, 0, x_23); +lean_ctor_set(x_29, 1, x_28); +lean_ctor_set(x_29, 2, x_25); +lean_ctor_set(x_29, 3, x_26); +lean_ctor_set(x_29, 4, x_27); +lean_ctor_set(x_13, 2, x_29); return x_12; } } else { -lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; -x_29 = lean_ctor_get(x_13, 0); -x_30 = lean_ctor_get(x_13, 1); -x_31 = lean_ctor_get(x_13, 3); -x_32 = lean_ctor_get(x_13, 4); -x_33 = lean_ctor_get(x_13, 5); +lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; +x_30 = lean_ctor_get(x_13, 0); +x_31 = lean_ctor_get(x_13, 1); +x_32 = lean_ctor_get(x_13, 3); +x_33 = lean_ctor_get(x_13, 4); +x_34 = lean_ctor_get(x_13, 5); +lean_inc(x_34); lean_inc(x_33); lean_inc(x_32); lean_inc(x_31); lean_inc(x_30); -lean_inc(x_29); lean_dec(x_13); -x_34 = lean_ctor_get(x_14, 0); -lean_inc(x_34); -x_35 = lean_ctor_get(x_14, 1); +x_35 = lean_ctor_get(x_14, 0); lean_inc(x_35); -x_36 = lean_ctor_get(x_14, 2); +x_36 = lean_ctor_get(x_14, 1); lean_inc(x_36); -x_37 = lean_ctor_get(x_14, 3); +x_37 = lean_ctor_get(x_14, 2); lean_inc(x_37); +x_38 = lean_ctor_get(x_14, 3); +lean_inc(x_38); +x_39 = lean_ctor_get(x_14, 4); +lean_inc(x_39); if (lean_is_exclusive(x_14)) { lean_ctor_release(x_14, 0); lean_ctor_release(x_14, 1); lean_ctor_release(x_14, 2); lean_ctor_release(x_14, 3); - x_38 = x_14; + lean_ctor_release(x_14, 4); + x_40 = x_14; } else { lean_dec_ref(x_14); - x_38 = lean_box(0); + x_40 = lean_box(0); } lean_inc(x_16); -x_39 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4(x_35, x_10, x_16); -if (lean_is_scalar(x_38)) { - x_40 = lean_alloc_ctor(0, 4, 0); +x_41 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4(x_36, x_10, x_16); +if (lean_is_scalar(x_40)) { + x_42 = lean_alloc_ctor(0, 5, 0); } else { - x_40 = x_38; + x_42 = x_40; } -lean_ctor_set(x_40, 0, x_34); -lean_ctor_set(x_40, 1, x_39); -lean_ctor_set(x_40, 2, x_36); -lean_ctor_set(x_40, 3, x_37); -x_41 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_41, 0, x_29); -lean_ctor_set(x_41, 1, x_30); -lean_ctor_set(x_41, 2, x_40); -lean_ctor_set(x_41, 3, x_31); -lean_ctor_set(x_41, 4, x_32); -lean_ctor_set(x_41, 5, x_33); -lean_ctor_set(x_12, 1, x_41); +lean_ctor_set(x_42, 0, x_35); +lean_ctor_set(x_42, 1, x_41); +lean_ctor_set(x_42, 2, x_37); +lean_ctor_set(x_42, 3, x_38); +lean_ctor_set(x_42, 4, x_39); +x_43 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_43, 0, x_30); +lean_ctor_set(x_43, 1, x_31); +lean_ctor_set(x_43, 2, x_42); +lean_ctor_set(x_43, 3, x_32); +lean_ctor_set(x_43, 4, x_33); +lean_ctor_set(x_43, 5, x_34); +lean_ctor_set(x_12, 1, x_43); return x_12; } } else { -lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; -x_42 = lean_ctor_get(x_12, 0); -lean_inc(x_42); -lean_dec(x_12); -x_43 = lean_ctor_get(x_13, 0); -lean_inc(x_43); -x_44 = lean_ctor_get(x_13, 1); +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; lean_object* x_60; +x_44 = lean_ctor_get(x_12, 0); lean_inc(x_44); -x_45 = lean_ctor_get(x_13, 3); +lean_dec(x_12); +x_45 = lean_ctor_get(x_13, 0); lean_inc(x_45); -x_46 = lean_ctor_get(x_13, 4); +x_46 = lean_ctor_get(x_13, 1); lean_inc(x_46); -x_47 = lean_ctor_get(x_13, 5); +x_47 = lean_ctor_get(x_13, 3); lean_inc(x_47); +x_48 = lean_ctor_get(x_13, 4); +lean_inc(x_48); +x_49 = lean_ctor_get(x_13, 5); +lean_inc(x_49); if (lean_is_exclusive(x_13)) { lean_ctor_release(x_13, 0); lean_ctor_release(x_13, 1); @@ -1708,94 +1715,98 @@ if (lean_is_exclusive(x_13)) { lean_ctor_release(x_13, 3); lean_ctor_release(x_13, 4); lean_ctor_release(x_13, 5); - x_48 = x_13; + x_50 = x_13; } else { lean_dec_ref(x_13); - x_48 = lean_box(0); + x_50 = lean_box(0); } -x_49 = lean_ctor_get(x_14, 0); -lean_inc(x_49); -x_50 = lean_ctor_get(x_14, 1); -lean_inc(x_50); -x_51 = lean_ctor_get(x_14, 2); +x_51 = lean_ctor_get(x_14, 0); lean_inc(x_51); -x_52 = lean_ctor_get(x_14, 3); +x_52 = lean_ctor_get(x_14, 1); lean_inc(x_52); +x_53 = lean_ctor_get(x_14, 2); +lean_inc(x_53); +x_54 = lean_ctor_get(x_14, 3); +lean_inc(x_54); +x_55 = lean_ctor_get(x_14, 4); +lean_inc(x_55); if (lean_is_exclusive(x_14)) { lean_ctor_release(x_14, 0); lean_ctor_release(x_14, 1); lean_ctor_release(x_14, 2); lean_ctor_release(x_14, 3); - x_53 = x_14; + lean_ctor_release(x_14, 4); + x_56 = x_14; } else { lean_dec_ref(x_14); - x_53 = lean_box(0); + x_56 = lean_box(0); } -lean_inc(x_42); -x_54 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4(x_50, x_10, x_42); -if (lean_is_scalar(x_53)) { - x_55 = lean_alloc_ctor(0, 4, 0); +lean_inc(x_44); +x_57 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4(x_52, x_10, x_44); +if (lean_is_scalar(x_56)) { + x_58 = lean_alloc_ctor(0, 5, 0); } else { - x_55 = x_53; + x_58 = x_56; } -lean_ctor_set(x_55, 0, x_49); -lean_ctor_set(x_55, 1, x_54); -lean_ctor_set(x_55, 2, x_51); -lean_ctor_set(x_55, 3, x_52); -if (lean_is_scalar(x_48)) { - x_56 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_58, 0, x_51); +lean_ctor_set(x_58, 1, x_57); +lean_ctor_set(x_58, 2, x_53); +lean_ctor_set(x_58, 3, x_54); +lean_ctor_set(x_58, 4, x_55); +if (lean_is_scalar(x_50)) { + x_59 = lean_alloc_ctor(0, 6, 0); } else { - x_56 = x_48; + x_59 = x_50; } -lean_ctor_set(x_56, 0, x_43); -lean_ctor_set(x_56, 1, x_44); -lean_ctor_set(x_56, 2, x_55); -lean_ctor_set(x_56, 3, x_45); -lean_ctor_set(x_56, 4, x_46); -lean_ctor_set(x_56, 5, x_47); -x_57 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_57, 0, x_42); -lean_ctor_set(x_57, 1, x_56); -return x_57; +lean_ctor_set(x_59, 0, x_45); +lean_ctor_set(x_59, 1, x_46); +lean_ctor_set(x_59, 2, x_58); +lean_ctor_set(x_59, 3, x_47); +lean_ctor_set(x_59, 4, x_48); +lean_ctor_set(x_59, 5, x_49); +x_60 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_60, 0, x_44); +lean_ctor_set(x_60, 1, x_59); +return x_60; } } else { -uint8_t x_58; +uint8_t x_61; lean_dec(x_10); -x_58 = !lean_is_exclusive(x_12); -if (x_58 == 0) +x_61 = !lean_is_exclusive(x_12); +if (x_61 == 0) { return x_12; } else { -lean_object* x_59; lean_object* x_60; lean_object* x_61; -x_59 = lean_ctor_get(x_12, 0); -x_60 = lean_ctor_get(x_12, 1); -lean_inc(x_60); -lean_inc(x_59); +lean_object* x_62; lean_object* x_63; lean_object* x_64; +x_62 = lean_ctor_get(x_12, 0); +x_63 = lean_ctor_get(x_12, 1); +lean_inc(x_63); +lean_inc(x_62); lean_dec(x_12); -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; +x_64 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_64, 0, x_62); +lean_ctor_set(x_64, 1, x_63); +return x_64; } } } else { -lean_object* x_62; lean_object* x_63; +lean_object* x_65; lean_object* x_66; lean_dec(x_10); lean_dec(x_4); lean_dec(x_3); -x_62 = lean_ctor_get(x_11, 0); -lean_inc(x_62); +x_65 = lean_ctor_get(x_11, 0); +lean_inc(x_65); lean_dec(x_11); -x_63 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_63, 0, x_62); -lean_ctor_set(x_63, 1, x_5); -return x_63; +x_66 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_66, 0, x_65); +lean_ctor_set(x_66, 1, x_5); +return x_66; } } } @@ -2763,105 +2774,105 @@ x_44 = lean_ctor_get(x_38, 2); x_45 = !lean_is_exclusive(x_44); if (x_45 == 0) { -lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_98; uint8_t x_99; +lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_102; uint8_t x_103; x_46 = lean_ctor_get(x_44, 2); -x_98 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_44, 2, x_98); -x_99 = !lean_is_exclusive(x_6); -if (x_99 == 0) +x_102 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_44, 2, x_102); +x_103 = !lean_is_exclusive(x_6); +if (x_103 == 0) { -lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; -x_100 = lean_ctor_get(x_6, 2); -x_101 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_101, 0, x_40); -lean_ctor_set(x_101, 1, x_27); -x_102 = lean_array_push(x_100, x_101); -lean_ctor_set(x_6, 2, x_102); -x_103 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__4(x_1, x_2, x_3, x_4, x_42, x_6, x_38); -if (lean_obj_tag(x_103) == 0) +lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; +x_104 = lean_ctor_get(x_6, 2); +x_105 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_105, 0, x_40); +lean_ctor_set(x_105, 1, x_27); +x_106 = lean_array_push(x_104, x_105); +lean_ctor_set(x_6, 2, x_106); +x_107 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__4(x_1, x_2, x_3, x_4, x_42, x_6, x_38); +if (lean_obj_tag(x_107) == 0) { -lean_object* x_104; lean_object* x_105; lean_object* x_106; -x_104 = lean_ctor_get(x_103, 0); -lean_inc(x_104); -x_105 = lean_ctor_get(x_103, 1); -lean_inc(x_105); -lean_dec(x_103); -x_106 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_106, 0, x_104); -x_47 = x_106; -x_48 = x_105; -goto block_97; -} -else -{ -lean_object* x_107; lean_object* x_108; lean_object* x_109; -x_107 = lean_ctor_get(x_103, 0); -lean_inc(x_107); -x_108 = lean_ctor_get(x_103, 1); +lean_object* x_108; lean_object* x_109; lean_object* x_110; +x_108 = lean_ctor_get(x_107, 0); lean_inc(x_108); -lean_dec(x_103); -x_109 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_109, 0, x_107); -x_47 = x_109; -x_48 = x_108; -goto block_97; -} +x_109 = lean_ctor_get(x_107, 1); +lean_inc(x_109); +lean_dec(x_107); +x_110 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_110, 0, x_108); +x_47 = x_110; +x_48 = x_109; +goto block_101; } else { -lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; -x_110 = lean_ctor_get(x_6, 0); -x_111 = lean_ctor_get(x_6, 1); -x_112 = lean_ctor_get(x_6, 2); -x_113 = lean_ctor_get(x_6, 3); -x_114 = lean_ctor_get(x_6, 4); -lean_inc(x_114); -lean_inc(x_113); -lean_inc(x_112); +lean_object* x_111; lean_object* x_112; lean_object* x_113; +x_111 = lean_ctor_get(x_107, 0); lean_inc(x_111); -lean_inc(x_110); -lean_dec(x_6); -x_115 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_115, 0, x_40); -lean_ctor_set(x_115, 1, x_27); -x_116 = lean_array_push(x_112, x_115); -x_117 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_117, 0, x_110); -lean_ctor_set(x_117, 1, x_111); -lean_ctor_set(x_117, 2, x_116); -lean_ctor_set(x_117, 3, x_113); -lean_ctor_set(x_117, 4, x_114); -x_118 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__4(x_1, x_2, x_3, x_4, x_42, x_117, x_38); -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); -x_121 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_121, 0, x_119); -x_47 = x_121; -x_48 = x_120; -goto block_97; +x_112 = lean_ctor_get(x_107, 1); +lean_inc(x_112); +lean_dec(x_107); +x_113 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_113, 0, x_111); +x_47 = x_113; +x_48 = x_112; +goto block_101; +} } else { -lean_object* x_122; lean_object* x_123; lean_object* x_124; -x_122 = lean_ctor_get(x_118, 0); -lean_inc(x_122); -x_123 = lean_ctor_get(x_118, 1); +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; +x_114 = lean_ctor_get(x_6, 0); +x_115 = lean_ctor_get(x_6, 1); +x_116 = lean_ctor_get(x_6, 2); +x_117 = lean_ctor_get(x_6, 3); +x_118 = lean_ctor_get(x_6, 4); +lean_inc(x_118); +lean_inc(x_117); +lean_inc(x_116); +lean_inc(x_115); +lean_inc(x_114); +lean_dec(x_6); +x_119 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_119, 0, x_40); +lean_ctor_set(x_119, 1, x_27); +x_120 = lean_array_push(x_116, x_119); +x_121 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_121, 0, x_114); +lean_ctor_set(x_121, 1, x_115); +lean_ctor_set(x_121, 2, x_120); +lean_ctor_set(x_121, 3, x_117); +lean_ctor_set(x_121, 4, x_118); +x_122 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__4(x_1, x_2, x_3, x_4, x_42, x_121, x_38); +if (lean_obj_tag(x_122) == 0) +{ +lean_object* x_123; lean_object* x_124; lean_object* x_125; +x_123 = lean_ctor_get(x_122, 0); lean_inc(x_123); -lean_dec(x_118); -x_124 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_124, 0, x_122); -x_47 = x_124; -x_48 = x_123; -goto block_97; +x_124 = lean_ctor_get(x_122, 1); +lean_inc(x_124); +lean_dec(x_122); +x_125 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_125, 0, x_123); +x_47 = x_125; +x_48 = x_124; +goto block_101; +} +else +{ +lean_object* x_126; lean_object* x_127; lean_object* x_128; +x_126 = lean_ctor_get(x_122, 0); +lean_inc(x_126); +x_127 = lean_ctor_get(x_122, 1); +lean_inc(x_127); +lean_dec(x_122); +x_128 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_128, 0, x_126); +x_47 = x_128; +x_48 = x_127; +goto block_101; } } -block_97: +block_101: { if (lean_obj_tag(x_47) == 0) { @@ -2896,1284 +2907,1262 @@ return x_55; } else { -lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; +lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; x_56 = lean_ctor_get(x_49, 0); x_57 = lean_ctor_get(x_49, 1); x_58 = lean_ctor_get(x_49, 3); +x_59 = lean_ctor_get(x_49, 4); +lean_inc(x_59); lean_inc(x_58); lean_inc(x_57); lean_inc(x_56); lean_dec(x_49); -x_59 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_59, 0, x_56); -lean_ctor_set(x_59, 1, x_57); -lean_ctor_set(x_59, 2, x_46); -lean_ctor_set(x_59, 3, x_58); -lean_ctor_set(x_48, 2, x_59); +x_60 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_60, 0, x_56); +lean_ctor_set(x_60, 1, x_57); +lean_ctor_set(x_60, 2, x_46); +lean_ctor_set(x_60, 3, x_58); +lean_ctor_set(x_60, 4, x_59); +lean_ctor_set(x_48, 2, x_60); if (lean_is_scalar(x_39)) { - x_60 = lean_alloc_ctor(1, 2, 0); + x_61 = lean_alloc_ctor(1, 2, 0); } else { - x_60 = x_39; - lean_ctor_set_tag(x_60, 1); + x_61 = x_39; + lean_ctor_set_tag(x_61, 1); } -lean_ctor_set(x_60, 0, x_50); -lean_ctor_set(x_60, 1, x_48); -return x_60; +lean_ctor_set(x_61, 0, x_50); +lean_ctor_set(x_61, 1, x_48); +return x_61; } } else { -lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; -x_61 = lean_ctor_get(x_48, 0); -x_62 = lean_ctor_get(x_48, 1); -x_63 = lean_ctor_get(x_48, 3); -x_64 = lean_ctor_get(x_48, 4); -x_65 = lean_ctor_get(x_48, 5); +lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; +x_62 = lean_ctor_get(x_48, 0); +x_63 = lean_ctor_get(x_48, 1); +x_64 = lean_ctor_get(x_48, 3); +x_65 = lean_ctor_get(x_48, 4); +x_66 = lean_ctor_get(x_48, 5); +lean_inc(x_66); lean_inc(x_65); lean_inc(x_64); lean_inc(x_63); lean_inc(x_62); -lean_inc(x_61); lean_dec(x_48); -x_66 = lean_ctor_get(x_49, 0); -lean_inc(x_66); -x_67 = lean_ctor_get(x_49, 1); +x_67 = lean_ctor_get(x_49, 0); lean_inc(x_67); -x_68 = lean_ctor_get(x_49, 3); +x_68 = lean_ctor_get(x_49, 1); lean_inc(x_68); +x_69 = lean_ctor_get(x_49, 3); +lean_inc(x_69); +x_70 = lean_ctor_get(x_49, 4); +lean_inc(x_70); if (lean_is_exclusive(x_49)) { lean_ctor_release(x_49, 0); lean_ctor_release(x_49, 1); lean_ctor_release(x_49, 2); lean_ctor_release(x_49, 3); - x_69 = x_49; + lean_ctor_release(x_49, 4); + x_71 = x_49; } else { lean_dec_ref(x_49); - x_69 = lean_box(0); + x_71 = lean_box(0); } -if (lean_is_scalar(x_69)) { - x_70 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_71)) { + x_72 = lean_alloc_ctor(0, 5, 0); } else { - x_70 = x_69; + x_72 = x_71; } -lean_ctor_set(x_70, 0, x_66); -lean_ctor_set(x_70, 1, x_67); -lean_ctor_set(x_70, 2, x_46); -lean_ctor_set(x_70, 3, x_68); -x_71 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_71, 0, x_61); -lean_ctor_set(x_71, 1, x_62); -lean_ctor_set(x_71, 2, x_70); -lean_ctor_set(x_71, 3, x_63); -lean_ctor_set(x_71, 4, x_64); -lean_ctor_set(x_71, 5, x_65); +lean_ctor_set(x_72, 0, x_67); +lean_ctor_set(x_72, 1, x_68); +lean_ctor_set(x_72, 2, x_46); +lean_ctor_set(x_72, 3, x_69); +lean_ctor_set(x_72, 4, x_70); +x_73 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_73, 0, x_62); +lean_ctor_set(x_73, 1, x_63); +lean_ctor_set(x_73, 2, x_72); +lean_ctor_set(x_73, 3, x_64); +lean_ctor_set(x_73, 4, x_65); +lean_ctor_set(x_73, 5, x_66); if (lean_is_scalar(x_39)) { - x_72 = lean_alloc_ctor(1, 2, 0); + x_74 = lean_alloc_ctor(1, 2, 0); } else { - x_72 = x_39; - lean_ctor_set_tag(x_72, 1); + x_74 = x_39; + lean_ctor_set_tag(x_74, 1); } -lean_ctor_set(x_72, 0, x_50); -lean_ctor_set(x_72, 1, x_71); -return x_72; +lean_ctor_set(x_74, 0, x_50); +lean_ctor_set(x_74, 1, x_73); +return x_74; } } else { -lean_object* x_73; lean_object* x_74; uint8_t x_75; -x_73 = lean_ctor_get(x_48, 2); -lean_inc(x_73); -x_74 = lean_ctor_get(x_47, 0); -lean_inc(x_74); +lean_object* x_75; lean_object* x_76; uint8_t x_77; +x_75 = lean_ctor_get(x_48, 2); +lean_inc(x_75); +x_76 = lean_ctor_get(x_47, 0); +lean_inc(x_76); lean_dec(x_47); -x_75 = !lean_is_exclusive(x_48); -if (x_75 == 0) -{ -lean_object* x_76; uint8_t x_77; -x_76 = lean_ctor_get(x_48, 2); -lean_dec(x_76); -x_77 = !lean_is_exclusive(x_73); +x_77 = !lean_is_exclusive(x_48); if (x_77 == 0) { -lean_object* x_78; lean_object* x_79; -x_78 = lean_ctor_get(x_73, 2); +lean_object* x_78; uint8_t x_79; +x_78 = lean_ctor_get(x_48, 2); lean_dec(x_78); -lean_ctor_set(x_73, 2, x_46); +x_79 = !lean_is_exclusive(x_75); +if (x_79 == 0) +{ +lean_object* x_80; lean_object* x_81; +x_80 = lean_ctor_get(x_75, 2); +lean_dec(x_80); +lean_ctor_set(x_75, 2, x_46); if (lean_is_scalar(x_39)) { - x_79 = lean_alloc_ctor(0, 2, 0); + x_81 = lean_alloc_ctor(0, 2, 0); } else { - x_79 = x_39; + x_81 = x_39; } -lean_ctor_set(x_79, 0, x_74); -lean_ctor_set(x_79, 1, x_48); -return x_79; +lean_ctor_set(x_81, 0, x_76); +lean_ctor_set(x_81, 1, x_48); +return x_81; } else { -lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; -x_80 = lean_ctor_get(x_73, 0); -x_81 = lean_ctor_get(x_73, 1); -x_82 = lean_ctor_get(x_73, 3); +lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; +x_82 = lean_ctor_get(x_75, 0); +x_83 = lean_ctor_get(x_75, 1); +x_84 = lean_ctor_get(x_75, 3); +x_85 = lean_ctor_get(x_75, 4); +lean_inc(x_85); +lean_inc(x_84); +lean_inc(x_83); lean_inc(x_82); -lean_inc(x_81); -lean_inc(x_80); -lean_dec(x_73); -x_83 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_83, 0, x_80); -lean_ctor_set(x_83, 1, x_81); -lean_ctor_set(x_83, 2, x_46); -lean_ctor_set(x_83, 3, x_82); -lean_ctor_set(x_48, 2, x_83); +lean_dec(x_75); +x_86 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_86, 0, x_82); +lean_ctor_set(x_86, 1, x_83); +lean_ctor_set(x_86, 2, x_46); +lean_ctor_set(x_86, 3, x_84); +lean_ctor_set(x_86, 4, x_85); +lean_ctor_set(x_48, 2, x_86); if (lean_is_scalar(x_39)) { - x_84 = lean_alloc_ctor(0, 2, 0); + x_87 = lean_alloc_ctor(0, 2, 0); } else { - x_84 = x_39; + x_87 = x_39; } -lean_ctor_set(x_84, 0, x_74); -lean_ctor_set(x_84, 1, x_48); -return x_84; +lean_ctor_set(x_87, 0, x_76); +lean_ctor_set(x_87, 1, x_48); +return x_87; } } else { -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; -x_85 = lean_ctor_get(x_48, 0); -x_86 = lean_ctor_get(x_48, 1); -x_87 = lean_ctor_get(x_48, 3); -x_88 = lean_ctor_get(x_48, 4); -x_89 = lean_ctor_get(x_48, 5); +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; +x_88 = lean_ctor_get(x_48, 0); +x_89 = lean_ctor_get(x_48, 1); +x_90 = lean_ctor_get(x_48, 3); +x_91 = lean_ctor_get(x_48, 4); +x_92 = lean_ctor_get(x_48, 5); +lean_inc(x_92); +lean_inc(x_91); +lean_inc(x_90); lean_inc(x_89); lean_inc(x_88); -lean_inc(x_87); -lean_inc(x_86); -lean_inc(x_85); lean_dec(x_48); -x_90 = lean_ctor_get(x_73, 0); -lean_inc(x_90); -x_91 = lean_ctor_get(x_73, 1); -lean_inc(x_91); -x_92 = lean_ctor_get(x_73, 3); -lean_inc(x_92); -if (lean_is_exclusive(x_73)) { - lean_ctor_release(x_73, 0); - lean_ctor_release(x_73, 1); - lean_ctor_release(x_73, 2); - lean_ctor_release(x_73, 3); - x_93 = x_73; +x_93 = lean_ctor_get(x_75, 0); +lean_inc(x_93); +x_94 = lean_ctor_get(x_75, 1); +lean_inc(x_94); +x_95 = lean_ctor_get(x_75, 3); +lean_inc(x_95); +x_96 = lean_ctor_get(x_75, 4); +lean_inc(x_96); +if (lean_is_exclusive(x_75)) { + lean_ctor_release(x_75, 0); + lean_ctor_release(x_75, 1); + lean_ctor_release(x_75, 2); + lean_ctor_release(x_75, 3); + lean_ctor_release(x_75, 4); + x_97 = x_75; } else { - lean_dec_ref(x_73); - x_93 = lean_box(0); + lean_dec_ref(x_75); + x_97 = lean_box(0); } -if (lean_is_scalar(x_93)) { - x_94 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_97)) { + x_98 = lean_alloc_ctor(0, 5, 0); } else { - x_94 = x_93; + x_98 = x_97; } -lean_ctor_set(x_94, 0, x_90); -lean_ctor_set(x_94, 1, x_91); -lean_ctor_set(x_94, 2, x_46); -lean_ctor_set(x_94, 3, x_92); -x_95 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_95, 0, x_85); -lean_ctor_set(x_95, 1, x_86); -lean_ctor_set(x_95, 2, x_94); -lean_ctor_set(x_95, 3, x_87); -lean_ctor_set(x_95, 4, x_88); -lean_ctor_set(x_95, 5, x_89); +lean_ctor_set(x_98, 0, x_93); +lean_ctor_set(x_98, 1, x_94); +lean_ctor_set(x_98, 2, x_46); +lean_ctor_set(x_98, 3, x_95); +lean_ctor_set(x_98, 4, x_96); +x_99 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_99, 0, x_88); +lean_ctor_set(x_99, 1, x_89); +lean_ctor_set(x_99, 2, x_98); +lean_ctor_set(x_99, 3, x_90); +lean_ctor_set(x_99, 4, x_91); +lean_ctor_set(x_99, 5, x_92); if (lean_is_scalar(x_39)) { - x_96 = lean_alloc_ctor(0, 2, 0); + x_100 = lean_alloc_ctor(0, 2, 0); } else { - x_96 = x_39; + x_100 = x_39; } -lean_ctor_set(x_96, 0, x_74); -lean_ctor_set(x_96, 1, x_95); -return x_96; +lean_ctor_set(x_100, 0, x_76); +lean_ctor_set(x_100, 1, x_99); +return x_100; } } } } else { -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_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; lean_object* x_173; -x_125 = lean_ctor_get(x_44, 0); -x_126 = lean_ctor_get(x_44, 1); -x_127 = lean_ctor_get(x_44, 2); -x_128 = lean_ctor_get(x_44, 3); -lean_inc(x_128); -lean_inc(x_127); -lean_inc(x_126); -lean_inc(x_125); -lean_dec(x_44); -x_162 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_163 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_163, 0, x_125); -lean_ctor_set(x_163, 1, x_126); -lean_ctor_set(x_163, 2, x_162); -lean_ctor_set(x_163, 3, x_128); -lean_ctor_set(x_38, 2, x_163); -x_164 = lean_ctor_get(x_6, 0); -lean_inc(x_164); -x_165 = lean_ctor_get(x_6, 1); -lean_inc(x_165); -x_166 = lean_ctor_get(x_6, 2); -lean_inc(x_166); -x_167 = lean_ctor_get(x_6, 3); -lean_inc(x_167); -x_168 = lean_ctor_get(x_6, 4); -lean_inc(x_168); -if (lean_is_exclusive(x_6)) { - lean_ctor_release(x_6, 0); - lean_ctor_release(x_6, 1); - lean_ctor_release(x_6, 2); - lean_ctor_release(x_6, 3); - lean_ctor_release(x_6, 4); - x_169 = x_6; -} else { - lean_dec_ref(x_6); - x_169 = lean_box(0); -} -x_170 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_170, 0, x_40); -lean_ctor_set(x_170, 1, x_27); -x_171 = lean_array_push(x_166, x_170); -if (lean_is_scalar(x_169)) { - x_172 = lean_alloc_ctor(0, 5, 0); -} else { - x_172 = x_169; -} -lean_ctor_set(x_172, 0, x_164); -lean_ctor_set(x_172, 1, x_165); -lean_ctor_set(x_172, 2, x_171); -lean_ctor_set(x_172, 3, x_167); -lean_ctor_set(x_172, 4, x_168); -x_173 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__4(x_1, x_2, x_3, x_4, x_42, x_172, x_38); -if (lean_obj_tag(x_173) == 0) -{ -lean_object* x_174; lean_object* x_175; lean_object* x_176; -x_174 = lean_ctor_get(x_173, 0); -lean_inc(x_174); -x_175 = lean_ctor_get(x_173, 1); -lean_inc(x_175); -lean_dec(x_173); -x_176 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_176, 0, x_174); -x_129 = x_176; -x_130 = x_175; -goto block_161; -} -else -{ -lean_object* x_177; lean_object* x_178; lean_object* x_179; -x_177 = lean_ctor_get(x_173, 0); -lean_inc(x_177); -x_178 = lean_ctor_get(x_173, 1); -lean_inc(x_178); -lean_dec(x_173); -x_179 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_179, 0, x_177); -x_129 = x_179; -x_130 = x_178; -goto block_161; -} -block_161: -{ -if (lean_obj_tag(x_129) == 0) -{ -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_131 = lean_ctor_get(x_130, 2); -lean_inc(x_131); -x_132 = lean_ctor_get(x_129, 0); -lean_inc(x_132); -lean_dec(x_129); -x_133 = lean_ctor_get(x_130, 0); +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_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; lean_object* x_180; +x_129 = lean_ctor_get(x_44, 0); +x_130 = lean_ctor_get(x_44, 1); +x_131 = lean_ctor_get(x_44, 2); +x_132 = lean_ctor_get(x_44, 3); +x_133 = lean_ctor_get(x_44, 4); lean_inc(x_133); -x_134 = lean_ctor_get(x_130, 1); -lean_inc(x_134); -x_135 = lean_ctor_get(x_130, 3); -lean_inc(x_135); -x_136 = lean_ctor_get(x_130, 4); -lean_inc(x_136); -x_137 = lean_ctor_get(x_130, 5); -lean_inc(x_137); -if (lean_is_exclusive(x_130)) { - lean_ctor_release(x_130, 0); - lean_ctor_release(x_130, 1); - lean_ctor_release(x_130, 2); - lean_ctor_release(x_130, 3); - lean_ctor_release(x_130, 4); - lean_ctor_release(x_130, 5); - x_138 = x_130; -} else { - lean_dec_ref(x_130); - x_138 = lean_box(0); -} -x_139 = lean_ctor_get(x_131, 0); -lean_inc(x_139); -x_140 = lean_ctor_get(x_131, 1); -lean_inc(x_140); -x_141 = lean_ctor_get(x_131, 3); -lean_inc(x_141); -if (lean_is_exclusive(x_131)) { - lean_ctor_release(x_131, 0); - lean_ctor_release(x_131, 1); - lean_ctor_release(x_131, 2); - lean_ctor_release(x_131, 3); - x_142 = x_131; -} else { - lean_dec_ref(x_131); - x_142 = lean_box(0); -} -if (lean_is_scalar(x_142)) { - x_143 = lean_alloc_ctor(0, 4, 0); -} else { - x_143 = x_142; -} -lean_ctor_set(x_143, 0, x_139); -lean_ctor_set(x_143, 1, x_140); -lean_ctor_set(x_143, 2, x_127); -lean_ctor_set(x_143, 3, x_141); -if (lean_is_scalar(x_138)) { - x_144 = lean_alloc_ctor(0, 6, 0); -} else { - x_144 = x_138; -} -lean_ctor_set(x_144, 0, x_133); -lean_ctor_set(x_144, 1, x_134); -lean_ctor_set(x_144, 2, x_143); -lean_ctor_set(x_144, 3, x_135); -lean_ctor_set(x_144, 4, x_136); -lean_ctor_set(x_144, 5, x_137); -if (lean_is_scalar(x_39)) { - x_145 = lean_alloc_ctor(1, 2, 0); -} else { - x_145 = x_39; - lean_ctor_set_tag(x_145, 1); -} -lean_ctor_set(x_145, 0, x_132); -lean_ctor_set(x_145, 1, x_144); -return x_145; -} -else -{ -lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; -x_146 = lean_ctor_get(x_130, 2); -lean_inc(x_146); -x_147 = lean_ctor_get(x_129, 0); -lean_inc(x_147); -lean_dec(x_129); -x_148 = lean_ctor_get(x_130, 0); -lean_inc(x_148); -x_149 = lean_ctor_get(x_130, 1); -lean_inc(x_149); -x_150 = lean_ctor_get(x_130, 3); -lean_inc(x_150); -x_151 = lean_ctor_get(x_130, 4); -lean_inc(x_151); -x_152 = lean_ctor_get(x_130, 5); -lean_inc(x_152); -if (lean_is_exclusive(x_130)) { - lean_ctor_release(x_130, 0); - lean_ctor_release(x_130, 1); - lean_ctor_release(x_130, 2); - lean_ctor_release(x_130, 3); - lean_ctor_release(x_130, 4); - lean_ctor_release(x_130, 5); - x_153 = x_130; -} else { - lean_dec_ref(x_130); - x_153 = lean_box(0); -} -x_154 = lean_ctor_get(x_146, 0); -lean_inc(x_154); -x_155 = lean_ctor_get(x_146, 1); -lean_inc(x_155); -x_156 = lean_ctor_get(x_146, 3); -lean_inc(x_156); -if (lean_is_exclusive(x_146)) { - lean_ctor_release(x_146, 0); - lean_ctor_release(x_146, 1); - lean_ctor_release(x_146, 2); - lean_ctor_release(x_146, 3); - x_157 = x_146; -} else { - lean_dec_ref(x_146); - x_157 = lean_box(0); -} -if (lean_is_scalar(x_157)) { - x_158 = lean_alloc_ctor(0, 4, 0); -} else { - x_158 = x_157; -} -lean_ctor_set(x_158, 0, x_154); -lean_ctor_set(x_158, 1, x_155); -lean_ctor_set(x_158, 2, x_127); -lean_ctor_set(x_158, 3, x_156); -if (lean_is_scalar(x_153)) { - x_159 = lean_alloc_ctor(0, 6, 0); -} else { - x_159 = x_153; -} -lean_ctor_set(x_159, 0, x_148); -lean_ctor_set(x_159, 1, x_149); -lean_ctor_set(x_159, 2, x_158); -lean_ctor_set(x_159, 3, x_150); -lean_ctor_set(x_159, 4, x_151); -lean_ctor_set(x_159, 5, x_152); -if (lean_is_scalar(x_39)) { - x_160 = lean_alloc_ctor(0, 2, 0); -} else { - x_160 = x_39; -} -lean_ctor_set(x_160, 0, x_147); -lean_ctor_set(x_160, 1, x_159); -return x_160; -} -} -} -} -else -{ -lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; 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_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; lean_object* x_231; lean_object* x_232; lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_object* x_236; -x_180 = lean_ctor_get(x_38, 2); -x_181 = lean_ctor_get(x_38, 0); -x_182 = lean_ctor_get(x_38, 1); -x_183 = lean_ctor_get(x_38, 3); -x_184 = lean_ctor_get(x_38, 4); -x_185 = lean_ctor_get(x_38, 5); -lean_inc(x_185); -lean_inc(x_184); -lean_inc(x_183); -lean_inc(x_180); -lean_inc(x_182); -lean_inc(x_181); -lean_dec(x_38); -x_186 = lean_ctor_get(x_180, 0); -lean_inc(x_186); -x_187 = lean_ctor_get(x_180, 1); -lean_inc(x_187); -x_188 = lean_ctor_get(x_180, 2); -lean_inc(x_188); -x_189 = lean_ctor_get(x_180, 3); -lean_inc(x_189); -if (lean_is_exclusive(x_180)) { - lean_ctor_release(x_180, 0); - lean_ctor_release(x_180, 1); - lean_ctor_release(x_180, 2); - lean_ctor_release(x_180, 3); - x_190 = x_180; -} else { - lean_dec_ref(x_180); - x_190 = lean_box(0); -} -x_224 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_190)) { - x_225 = lean_alloc_ctor(0, 4, 0); -} else { - x_225 = x_190; -} -lean_ctor_set(x_225, 0, x_186); -lean_ctor_set(x_225, 1, x_187); -lean_ctor_set(x_225, 2, x_224); -lean_ctor_set(x_225, 3, x_189); -x_226 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_226, 0, x_181); -lean_ctor_set(x_226, 1, x_182); -lean_ctor_set(x_226, 2, x_225); -lean_ctor_set(x_226, 3, x_183); -lean_ctor_set(x_226, 4, x_184); -lean_ctor_set(x_226, 5, x_185); -x_227 = lean_ctor_get(x_6, 0); -lean_inc(x_227); -x_228 = lean_ctor_get(x_6, 1); -lean_inc(x_228); -x_229 = lean_ctor_get(x_6, 2); -lean_inc(x_229); -x_230 = lean_ctor_get(x_6, 3); -lean_inc(x_230); -x_231 = lean_ctor_get(x_6, 4); -lean_inc(x_231); +lean_inc(x_132); +lean_inc(x_131); +lean_inc(x_130); +lean_inc(x_129); +lean_dec(x_44); +x_169 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_170 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_170, 0, x_129); +lean_ctor_set(x_170, 1, x_130); +lean_ctor_set(x_170, 2, x_169); +lean_ctor_set(x_170, 3, x_132); +lean_ctor_set(x_170, 4, x_133); +lean_ctor_set(x_38, 2, x_170); +x_171 = lean_ctor_get(x_6, 0); +lean_inc(x_171); +x_172 = lean_ctor_get(x_6, 1); +lean_inc(x_172); +x_173 = lean_ctor_get(x_6, 2); +lean_inc(x_173); +x_174 = lean_ctor_get(x_6, 3); +lean_inc(x_174); +x_175 = lean_ctor_get(x_6, 4); +lean_inc(x_175); if (lean_is_exclusive(x_6)) { lean_ctor_release(x_6, 0); lean_ctor_release(x_6, 1); lean_ctor_release(x_6, 2); lean_ctor_release(x_6, 3); lean_ctor_release(x_6, 4); - x_232 = x_6; + x_176 = x_6; } else { lean_dec_ref(x_6); - x_232 = lean_box(0); + x_176 = lean_box(0); } -x_233 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_233, 0, x_40); -lean_ctor_set(x_233, 1, x_27); -x_234 = lean_array_push(x_229, x_233); -if (lean_is_scalar(x_232)) { +x_177 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_177, 0, x_40); +lean_ctor_set(x_177, 1, x_27); +x_178 = lean_array_push(x_173, x_177); +if (lean_is_scalar(x_176)) { + x_179 = lean_alloc_ctor(0, 5, 0); +} else { + x_179 = x_176; +} +lean_ctor_set(x_179, 0, x_171); +lean_ctor_set(x_179, 1, x_172); +lean_ctor_set(x_179, 2, x_178); +lean_ctor_set(x_179, 3, x_174); +lean_ctor_set(x_179, 4, x_175); +x_180 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__4(x_1, x_2, x_3, x_4, x_42, x_179, x_38); +if (lean_obj_tag(x_180) == 0) +{ +lean_object* x_181; lean_object* x_182; lean_object* x_183; +x_181 = lean_ctor_get(x_180, 0); +lean_inc(x_181); +x_182 = lean_ctor_get(x_180, 1); +lean_inc(x_182); +lean_dec(x_180); +x_183 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_183, 0, x_181); +x_134 = x_183; +x_135 = x_182; +goto block_168; +} +else +{ +lean_object* x_184; lean_object* x_185; lean_object* x_186; +x_184 = lean_ctor_get(x_180, 0); +lean_inc(x_184); +x_185 = lean_ctor_get(x_180, 1); +lean_inc(x_185); +lean_dec(x_180); +x_186 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_186, 0, x_184); +x_134 = x_186; +x_135 = x_185; +goto block_168; +} +block_168: +{ +if (lean_obj_tag(x_134) == 0) +{ +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; +x_136 = lean_ctor_get(x_135, 2); +lean_inc(x_136); +x_137 = lean_ctor_get(x_134, 0); +lean_inc(x_137); +lean_dec(x_134); +x_138 = lean_ctor_get(x_135, 0); +lean_inc(x_138); +x_139 = lean_ctor_get(x_135, 1); +lean_inc(x_139); +x_140 = lean_ctor_get(x_135, 3); +lean_inc(x_140); +x_141 = lean_ctor_get(x_135, 4); +lean_inc(x_141); +x_142 = lean_ctor_get(x_135, 5); +lean_inc(x_142); +if (lean_is_exclusive(x_135)) { + lean_ctor_release(x_135, 0); + lean_ctor_release(x_135, 1); + lean_ctor_release(x_135, 2); + lean_ctor_release(x_135, 3); + lean_ctor_release(x_135, 4); + lean_ctor_release(x_135, 5); + x_143 = x_135; +} else { + lean_dec_ref(x_135); + x_143 = lean_box(0); +} +x_144 = lean_ctor_get(x_136, 0); +lean_inc(x_144); +x_145 = lean_ctor_get(x_136, 1); +lean_inc(x_145); +x_146 = lean_ctor_get(x_136, 3); +lean_inc(x_146); +x_147 = lean_ctor_get(x_136, 4); +lean_inc(x_147); +if (lean_is_exclusive(x_136)) { + lean_ctor_release(x_136, 0); + lean_ctor_release(x_136, 1); + lean_ctor_release(x_136, 2); + lean_ctor_release(x_136, 3); + lean_ctor_release(x_136, 4); + x_148 = x_136; +} else { + lean_dec_ref(x_136); + x_148 = lean_box(0); +} +if (lean_is_scalar(x_148)) { + x_149 = lean_alloc_ctor(0, 5, 0); +} else { + x_149 = x_148; +} +lean_ctor_set(x_149, 0, x_144); +lean_ctor_set(x_149, 1, x_145); +lean_ctor_set(x_149, 2, x_131); +lean_ctor_set(x_149, 3, x_146); +lean_ctor_set(x_149, 4, x_147); +if (lean_is_scalar(x_143)) { + x_150 = lean_alloc_ctor(0, 6, 0); +} else { + x_150 = x_143; +} +lean_ctor_set(x_150, 0, x_138); +lean_ctor_set(x_150, 1, x_139); +lean_ctor_set(x_150, 2, x_149); +lean_ctor_set(x_150, 3, x_140); +lean_ctor_set(x_150, 4, x_141); +lean_ctor_set(x_150, 5, x_142); +if (lean_is_scalar(x_39)) { + x_151 = lean_alloc_ctor(1, 2, 0); +} else { + x_151 = x_39; + lean_ctor_set_tag(x_151, 1); +} +lean_ctor_set(x_151, 0, x_137); +lean_ctor_set(x_151, 1, x_150); +return x_151; +} +else +{ +lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; +x_152 = lean_ctor_get(x_135, 2); +lean_inc(x_152); +x_153 = lean_ctor_get(x_134, 0); +lean_inc(x_153); +lean_dec(x_134); +x_154 = lean_ctor_get(x_135, 0); +lean_inc(x_154); +x_155 = lean_ctor_get(x_135, 1); +lean_inc(x_155); +x_156 = lean_ctor_get(x_135, 3); +lean_inc(x_156); +x_157 = lean_ctor_get(x_135, 4); +lean_inc(x_157); +x_158 = lean_ctor_get(x_135, 5); +lean_inc(x_158); +if (lean_is_exclusive(x_135)) { + lean_ctor_release(x_135, 0); + lean_ctor_release(x_135, 1); + lean_ctor_release(x_135, 2); + lean_ctor_release(x_135, 3); + lean_ctor_release(x_135, 4); + lean_ctor_release(x_135, 5); + x_159 = x_135; +} else { + lean_dec_ref(x_135); + x_159 = lean_box(0); +} +x_160 = lean_ctor_get(x_152, 0); +lean_inc(x_160); +x_161 = lean_ctor_get(x_152, 1); +lean_inc(x_161); +x_162 = lean_ctor_get(x_152, 3); +lean_inc(x_162); +x_163 = lean_ctor_get(x_152, 4); +lean_inc(x_163); +if (lean_is_exclusive(x_152)) { + lean_ctor_release(x_152, 0); + lean_ctor_release(x_152, 1); + lean_ctor_release(x_152, 2); + lean_ctor_release(x_152, 3); + lean_ctor_release(x_152, 4); + x_164 = x_152; +} else { + lean_dec_ref(x_152); + x_164 = lean_box(0); +} +if (lean_is_scalar(x_164)) { + x_165 = lean_alloc_ctor(0, 5, 0); +} else { + x_165 = x_164; +} +lean_ctor_set(x_165, 0, x_160); +lean_ctor_set(x_165, 1, x_161); +lean_ctor_set(x_165, 2, x_131); +lean_ctor_set(x_165, 3, x_162); +lean_ctor_set(x_165, 4, x_163); +if (lean_is_scalar(x_159)) { + x_166 = lean_alloc_ctor(0, 6, 0); +} else { + x_166 = x_159; +} +lean_ctor_set(x_166, 0, x_154); +lean_ctor_set(x_166, 1, x_155); +lean_ctor_set(x_166, 2, x_165); +lean_ctor_set(x_166, 3, x_156); +lean_ctor_set(x_166, 4, x_157); +lean_ctor_set(x_166, 5, x_158); +if (lean_is_scalar(x_39)) { + x_167 = lean_alloc_ctor(0, 2, 0); +} else { + x_167 = x_39; +} +lean_ctor_set(x_167, 0, x_153); +lean_ctor_set(x_167, 1, x_166); +return x_167; +} +} +} +} +else +{ +lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_234; lean_object* x_235; lean_object* x_236; lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; lean_object* x_242; lean_object* x_243; lean_object* x_244; lean_object* x_245; lean_object* x_246; +x_187 = lean_ctor_get(x_38, 2); +x_188 = lean_ctor_get(x_38, 0); +x_189 = lean_ctor_get(x_38, 1); +x_190 = lean_ctor_get(x_38, 3); +x_191 = lean_ctor_get(x_38, 4); +x_192 = lean_ctor_get(x_38, 5); +lean_inc(x_192); +lean_inc(x_191); +lean_inc(x_190); +lean_inc(x_187); +lean_inc(x_189); +lean_inc(x_188); +lean_dec(x_38); +x_193 = lean_ctor_get(x_187, 0); +lean_inc(x_193); +x_194 = lean_ctor_get(x_187, 1); +lean_inc(x_194); +x_195 = lean_ctor_get(x_187, 2); +lean_inc(x_195); +x_196 = lean_ctor_get(x_187, 3); +lean_inc(x_196); +x_197 = lean_ctor_get(x_187, 4); +lean_inc(x_197); +if (lean_is_exclusive(x_187)) { + lean_ctor_release(x_187, 0); + lean_ctor_release(x_187, 1); + lean_ctor_release(x_187, 2); + lean_ctor_release(x_187, 3); + lean_ctor_release(x_187, 4); + x_198 = x_187; +} else { + lean_dec_ref(x_187); + x_198 = lean_box(0); +} +x_234 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_198)) { x_235 = lean_alloc_ctor(0, 5, 0); } else { - x_235 = x_232; + x_235 = x_198; } -lean_ctor_set(x_235, 0, x_227); -lean_ctor_set(x_235, 1, x_228); +lean_ctor_set(x_235, 0, x_193); +lean_ctor_set(x_235, 1, x_194); lean_ctor_set(x_235, 2, x_234); -lean_ctor_set(x_235, 3, x_230); -lean_ctor_set(x_235, 4, x_231); -x_236 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__4(x_1, x_2, x_3, x_4, x_42, x_235, x_226); -if (lean_obj_tag(x_236) == 0) -{ -lean_object* x_237; lean_object* x_238; lean_object* x_239; -x_237 = lean_ctor_get(x_236, 0); +lean_ctor_set(x_235, 3, x_196); +lean_ctor_set(x_235, 4, x_197); +x_236 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_236, 0, x_188); +lean_ctor_set(x_236, 1, x_189); +lean_ctor_set(x_236, 2, x_235); +lean_ctor_set(x_236, 3, x_190); +lean_ctor_set(x_236, 4, x_191); +lean_ctor_set(x_236, 5, x_192); +x_237 = lean_ctor_get(x_6, 0); lean_inc(x_237); -x_238 = lean_ctor_get(x_236, 1); +x_238 = lean_ctor_get(x_6, 1); lean_inc(x_238); -lean_dec(x_236); -x_239 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_239, 0, x_237); -x_191 = x_239; -x_192 = x_238; -goto block_223; -} -else -{ -lean_object* x_240; lean_object* x_241; lean_object* x_242; -x_240 = lean_ctor_get(x_236, 0); +x_239 = lean_ctor_get(x_6, 2); +lean_inc(x_239); +x_240 = lean_ctor_get(x_6, 3); lean_inc(x_240); -x_241 = lean_ctor_get(x_236, 1); +x_241 = lean_ctor_get(x_6, 4); lean_inc(x_241); -lean_dec(x_236); -x_242 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_242, 0, x_240); -x_191 = x_242; -x_192 = x_241; -goto block_223; +if (lean_is_exclusive(x_6)) { + lean_ctor_release(x_6, 0); + lean_ctor_release(x_6, 1); + lean_ctor_release(x_6, 2); + lean_ctor_release(x_6, 3); + lean_ctor_release(x_6, 4); + x_242 = x_6; +} else { + lean_dec_ref(x_6); + x_242 = lean_box(0); } -block_223: +x_243 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_243, 0, x_40); +lean_ctor_set(x_243, 1, x_27); +x_244 = lean_array_push(x_239, x_243); +if (lean_is_scalar(x_242)) { + x_245 = lean_alloc_ctor(0, 5, 0); +} else { + x_245 = x_242; +} +lean_ctor_set(x_245, 0, x_237); +lean_ctor_set(x_245, 1, x_238); +lean_ctor_set(x_245, 2, x_244); +lean_ctor_set(x_245, 3, x_240); +lean_ctor_set(x_245, 4, x_241); +x_246 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__4(x_1, x_2, x_3, x_4, x_42, x_245, x_236); +if (lean_obj_tag(x_246) == 0) { -if (lean_obj_tag(x_191) == 0) -{ -lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; -x_193 = lean_ctor_get(x_192, 2); -lean_inc(x_193); -x_194 = lean_ctor_get(x_191, 0); -lean_inc(x_194); -lean_dec(x_191); -x_195 = lean_ctor_get(x_192, 0); -lean_inc(x_195); -x_196 = lean_ctor_get(x_192, 1); -lean_inc(x_196); -x_197 = lean_ctor_get(x_192, 3); -lean_inc(x_197); -x_198 = lean_ctor_get(x_192, 4); -lean_inc(x_198); -x_199 = lean_ctor_get(x_192, 5); -lean_inc(x_199); -if (lean_is_exclusive(x_192)) { - lean_ctor_release(x_192, 0); - lean_ctor_release(x_192, 1); - lean_ctor_release(x_192, 2); - lean_ctor_release(x_192, 3); - lean_ctor_release(x_192, 4); - lean_ctor_release(x_192, 5); - x_200 = x_192; -} else { - lean_dec_ref(x_192); - x_200 = lean_box(0); -} -x_201 = lean_ctor_get(x_193, 0); -lean_inc(x_201); -x_202 = lean_ctor_get(x_193, 1); -lean_inc(x_202); -x_203 = lean_ctor_get(x_193, 3); -lean_inc(x_203); -if (lean_is_exclusive(x_193)) { - lean_ctor_release(x_193, 0); - lean_ctor_release(x_193, 1); - lean_ctor_release(x_193, 2); - lean_ctor_release(x_193, 3); - x_204 = x_193; -} else { - lean_dec_ref(x_193); - x_204 = lean_box(0); -} -if (lean_is_scalar(x_204)) { - x_205 = lean_alloc_ctor(0, 4, 0); -} else { - x_205 = x_204; -} -lean_ctor_set(x_205, 0, x_201); -lean_ctor_set(x_205, 1, x_202); -lean_ctor_set(x_205, 2, x_188); -lean_ctor_set(x_205, 3, x_203); -if (lean_is_scalar(x_200)) { - x_206 = lean_alloc_ctor(0, 6, 0); -} else { - x_206 = x_200; -} -lean_ctor_set(x_206, 0, x_195); -lean_ctor_set(x_206, 1, x_196); -lean_ctor_set(x_206, 2, x_205); -lean_ctor_set(x_206, 3, x_197); -lean_ctor_set(x_206, 4, x_198); -lean_ctor_set(x_206, 5, x_199); -if (lean_is_scalar(x_39)) { - x_207 = lean_alloc_ctor(1, 2, 0); -} else { - x_207 = x_39; - lean_ctor_set_tag(x_207, 1); -} -lean_ctor_set(x_207, 0, x_194); -lean_ctor_set(x_207, 1, x_206); -return x_207; +lean_object* x_247; lean_object* x_248; lean_object* x_249; +x_247 = lean_ctor_get(x_246, 0); +lean_inc(x_247); +x_248 = lean_ctor_get(x_246, 1); +lean_inc(x_248); +lean_dec(x_246); +x_249 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_249, 0, x_247); +x_199 = x_249; +x_200 = x_248; +goto block_233; } else { -lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; -x_208 = lean_ctor_get(x_192, 2); -lean_inc(x_208); -x_209 = lean_ctor_get(x_191, 0); +lean_object* x_250; lean_object* x_251; lean_object* x_252; +x_250 = lean_ctor_get(x_246, 0); +lean_inc(x_250); +x_251 = lean_ctor_get(x_246, 1); +lean_inc(x_251); +lean_dec(x_246); +x_252 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_252, 0, x_250); +x_199 = x_252; +x_200 = x_251; +goto block_233; +} +block_233: +{ +if (lean_obj_tag(x_199) == 0) +{ +lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; +x_201 = lean_ctor_get(x_200, 2); +lean_inc(x_201); +x_202 = lean_ctor_get(x_199, 0); +lean_inc(x_202); +lean_dec(x_199); +x_203 = lean_ctor_get(x_200, 0); +lean_inc(x_203); +x_204 = lean_ctor_get(x_200, 1); +lean_inc(x_204); +x_205 = lean_ctor_get(x_200, 3); +lean_inc(x_205); +x_206 = lean_ctor_get(x_200, 4); +lean_inc(x_206); +x_207 = lean_ctor_get(x_200, 5); +lean_inc(x_207); +if (lean_is_exclusive(x_200)) { + lean_ctor_release(x_200, 0); + lean_ctor_release(x_200, 1); + lean_ctor_release(x_200, 2); + lean_ctor_release(x_200, 3); + lean_ctor_release(x_200, 4); + lean_ctor_release(x_200, 5); + x_208 = x_200; +} else { + lean_dec_ref(x_200); + x_208 = lean_box(0); +} +x_209 = lean_ctor_get(x_201, 0); lean_inc(x_209); -lean_dec(x_191); -x_210 = lean_ctor_get(x_192, 0); +x_210 = lean_ctor_get(x_201, 1); lean_inc(x_210); -x_211 = lean_ctor_get(x_192, 1); +x_211 = lean_ctor_get(x_201, 3); lean_inc(x_211); -x_212 = lean_ctor_get(x_192, 3); +x_212 = lean_ctor_get(x_201, 4); lean_inc(x_212); -x_213 = lean_ctor_get(x_192, 4); -lean_inc(x_213); -x_214 = lean_ctor_get(x_192, 5); -lean_inc(x_214); -if (lean_is_exclusive(x_192)) { - lean_ctor_release(x_192, 0); - lean_ctor_release(x_192, 1); - lean_ctor_release(x_192, 2); - lean_ctor_release(x_192, 3); - lean_ctor_release(x_192, 4); - lean_ctor_release(x_192, 5); - x_215 = x_192; +if (lean_is_exclusive(x_201)) { + lean_ctor_release(x_201, 0); + lean_ctor_release(x_201, 1); + lean_ctor_release(x_201, 2); + lean_ctor_release(x_201, 3); + lean_ctor_release(x_201, 4); + x_213 = x_201; } else { - lean_dec_ref(x_192); - x_215 = lean_box(0); + lean_dec_ref(x_201); + x_213 = lean_box(0); } -x_216 = lean_ctor_get(x_208, 0); -lean_inc(x_216); -x_217 = lean_ctor_get(x_208, 1); -lean_inc(x_217); -x_218 = lean_ctor_get(x_208, 3); -lean_inc(x_218); -if (lean_is_exclusive(x_208)) { - lean_ctor_release(x_208, 0); - lean_ctor_release(x_208, 1); - lean_ctor_release(x_208, 2); - lean_ctor_release(x_208, 3); - x_219 = x_208; +if (lean_is_scalar(x_213)) { + x_214 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_208); - x_219 = lean_box(0); + x_214 = x_213; } -if (lean_is_scalar(x_219)) { - x_220 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_214, 0, x_209); +lean_ctor_set(x_214, 1, x_210); +lean_ctor_set(x_214, 2, x_195); +lean_ctor_set(x_214, 3, x_211); +lean_ctor_set(x_214, 4, x_212); +if (lean_is_scalar(x_208)) { + x_215 = lean_alloc_ctor(0, 6, 0); } else { - x_220 = x_219; + x_215 = x_208; } -lean_ctor_set(x_220, 0, x_216); -lean_ctor_set(x_220, 1, x_217); -lean_ctor_set(x_220, 2, x_188); -lean_ctor_set(x_220, 3, x_218); -if (lean_is_scalar(x_215)) { - x_221 = lean_alloc_ctor(0, 6, 0); -} else { - x_221 = x_215; -} -lean_ctor_set(x_221, 0, x_210); -lean_ctor_set(x_221, 1, x_211); -lean_ctor_set(x_221, 2, x_220); -lean_ctor_set(x_221, 3, x_212); -lean_ctor_set(x_221, 4, x_213); -lean_ctor_set(x_221, 5, x_214); +lean_ctor_set(x_215, 0, x_203); +lean_ctor_set(x_215, 1, x_204); +lean_ctor_set(x_215, 2, x_214); +lean_ctor_set(x_215, 3, x_205); +lean_ctor_set(x_215, 4, x_206); +lean_ctor_set(x_215, 5, x_207); if (lean_is_scalar(x_39)) { - x_222 = lean_alloc_ctor(0, 2, 0); + x_216 = lean_alloc_ctor(1, 2, 0); } else { - x_222 = x_39; + x_216 = x_39; + lean_ctor_set_tag(x_216, 1); } -lean_ctor_set(x_222, 0, x_209); -lean_ctor_set(x_222, 1, x_221); -return x_222; +lean_ctor_set(x_216, 0, x_202); +lean_ctor_set(x_216, 1, x_215); +return x_216; +} +else +{ +lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; lean_object* x_224; lean_object* x_225; lean_object* x_226; lean_object* x_227; lean_object* x_228; lean_object* x_229; lean_object* x_230; lean_object* x_231; lean_object* x_232; +x_217 = lean_ctor_get(x_200, 2); +lean_inc(x_217); +x_218 = lean_ctor_get(x_199, 0); +lean_inc(x_218); +lean_dec(x_199); +x_219 = lean_ctor_get(x_200, 0); +lean_inc(x_219); +x_220 = lean_ctor_get(x_200, 1); +lean_inc(x_220); +x_221 = lean_ctor_get(x_200, 3); +lean_inc(x_221); +x_222 = lean_ctor_get(x_200, 4); +lean_inc(x_222); +x_223 = lean_ctor_get(x_200, 5); +lean_inc(x_223); +if (lean_is_exclusive(x_200)) { + lean_ctor_release(x_200, 0); + lean_ctor_release(x_200, 1); + lean_ctor_release(x_200, 2); + lean_ctor_release(x_200, 3); + lean_ctor_release(x_200, 4); + lean_ctor_release(x_200, 5); + x_224 = x_200; +} else { + lean_dec_ref(x_200); + x_224 = lean_box(0); +} +x_225 = lean_ctor_get(x_217, 0); +lean_inc(x_225); +x_226 = lean_ctor_get(x_217, 1); +lean_inc(x_226); +x_227 = lean_ctor_get(x_217, 3); +lean_inc(x_227); +x_228 = lean_ctor_get(x_217, 4); +lean_inc(x_228); +if (lean_is_exclusive(x_217)) { + lean_ctor_release(x_217, 0); + lean_ctor_release(x_217, 1); + lean_ctor_release(x_217, 2); + lean_ctor_release(x_217, 3); + lean_ctor_release(x_217, 4); + x_229 = x_217; +} else { + lean_dec_ref(x_217); + x_229 = lean_box(0); +} +if (lean_is_scalar(x_229)) { + x_230 = lean_alloc_ctor(0, 5, 0); +} else { + x_230 = x_229; +} +lean_ctor_set(x_230, 0, x_225); +lean_ctor_set(x_230, 1, x_226); +lean_ctor_set(x_230, 2, x_195); +lean_ctor_set(x_230, 3, x_227); +lean_ctor_set(x_230, 4, x_228); +if (lean_is_scalar(x_224)) { + x_231 = lean_alloc_ctor(0, 6, 0); +} else { + x_231 = x_224; +} +lean_ctor_set(x_231, 0, x_219); +lean_ctor_set(x_231, 1, x_220); +lean_ctor_set(x_231, 2, x_230); +lean_ctor_set(x_231, 3, x_221); +lean_ctor_set(x_231, 4, x_222); +lean_ctor_set(x_231, 5, x_223); +if (lean_is_scalar(x_39)) { + x_232 = lean_alloc_ctor(0, 2, 0); +} else { + x_232 = x_39; +} +lean_ctor_set(x_232, 0, x_218); +lean_ctor_set(x_232, 1, x_231); +return x_232; } } } } default: { -lean_object* x_243; lean_object* x_244; -x_243 = lean_ctor_get(x_32, 1); -lean_inc(x_243); +lean_object* x_253; lean_object* x_254; +x_253 = lean_ctor_get(x_32, 1); +lean_inc(x_253); lean_dec(x_32); lean_inc(x_6); -x_244 = l_Lean_Meta_isClassExpensive___main(x_31, x_6, x_243); -if (lean_obj_tag(x_244) == 0) +x_254 = l_Lean_Meta_isClassExpensive___main(x_31, x_6, x_253); +if (lean_obj_tag(x_254) == 0) { -lean_object* x_245; -x_245 = lean_ctor_get(x_244, 0); -lean_inc(x_245); -if (lean_obj_tag(x_245) == 0) +lean_object* x_255; +x_255 = lean_ctor_get(x_254, 0); +lean_inc(x_255); +if (lean_obj_tag(x_255) == 0) { -lean_object* x_246; lean_object* x_247; lean_object* x_248; +lean_object* x_256; lean_object* x_257; lean_object* x_258; lean_dec(x_27); -x_246 = lean_ctor_get(x_244, 1); -lean_inc(x_246); -lean_dec(x_244); -x_247 = lean_unsigned_to_nat(1u); -x_248 = lean_nat_add(x_5, x_247); +x_256 = lean_ctor_get(x_254, 1); +lean_inc(x_256); +lean_dec(x_254); +x_257 = lean_unsigned_to_nat(1u); +x_258 = lean_nat_add(x_5, x_257); lean_dec(x_5); -x_5 = x_248; -x_7 = x_246; +x_5 = x_258; +x_7 = x_256; goto _start; } else { -lean_object* x_250; lean_object* x_251; lean_object* x_252; lean_object* x_253; lean_object* x_254; uint8_t x_255; -x_250 = lean_ctor_get(x_244, 1); -lean_inc(x_250); -if (lean_is_exclusive(x_244)) { - lean_ctor_release(x_244, 0); - lean_ctor_release(x_244, 1); - x_251 = x_244; +lean_object* x_260; lean_object* x_261; lean_object* x_262; lean_object* x_263; lean_object* x_264; uint8_t x_265; +x_260 = lean_ctor_get(x_254, 1); +lean_inc(x_260); +if (lean_is_exclusive(x_254)) { + lean_ctor_release(x_254, 0); + lean_ctor_release(x_254, 1); + x_261 = x_254; } else { - lean_dec_ref(x_244); - x_251 = lean_box(0); + lean_dec_ref(x_254); + x_261 = lean_box(0); } -x_252 = lean_ctor_get(x_245, 0); -lean_inc(x_252); -lean_dec(x_245); -x_253 = lean_unsigned_to_nat(1u); -x_254 = lean_nat_add(x_5, x_253); -lean_dec(x_5); -x_255 = !lean_is_exclusive(x_250); -if (x_255 == 0) -{ -lean_object* x_256; uint8_t x_257; -x_256 = lean_ctor_get(x_250, 2); -x_257 = !lean_is_exclusive(x_256); -if (x_257 == 0) -{ -lean_object* x_258; lean_object* x_259; lean_object* x_260; lean_object* x_310; uint8_t x_311; -x_258 = lean_ctor_get(x_256, 2); -x_310 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_256, 2, x_310); -x_311 = !lean_is_exclusive(x_6); -if (x_311 == 0) -{ -lean_object* x_312; lean_object* x_313; lean_object* x_314; lean_object* x_315; -x_312 = lean_ctor_get(x_6, 2); -x_313 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_313, 0, x_252); -lean_ctor_set(x_313, 1, x_27); -x_314 = lean_array_push(x_312, x_313); -lean_ctor_set(x_6, 2, x_314); -x_315 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__4(x_1, x_2, x_3, x_4, x_254, x_6, x_250); -if (lean_obj_tag(x_315) == 0) -{ -lean_object* x_316; lean_object* x_317; lean_object* x_318; -x_316 = lean_ctor_get(x_315, 0); -lean_inc(x_316); -x_317 = lean_ctor_get(x_315, 1); -lean_inc(x_317); -lean_dec(x_315); -x_318 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_318, 0, x_316); -x_259 = x_318; -x_260 = x_317; -goto block_309; -} -else -{ -lean_object* x_319; lean_object* x_320; lean_object* x_321; -x_319 = lean_ctor_get(x_315, 0); -lean_inc(x_319); -x_320 = lean_ctor_get(x_315, 1); -lean_inc(x_320); -lean_dec(x_315); -x_321 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_321, 0, x_319); -x_259 = x_321; -x_260 = x_320; -goto block_309; -} -} -else -{ -lean_object* x_322; lean_object* x_323; lean_object* x_324; lean_object* x_325; lean_object* x_326; lean_object* x_327; lean_object* x_328; lean_object* x_329; lean_object* x_330; -x_322 = lean_ctor_get(x_6, 0); -x_323 = lean_ctor_get(x_6, 1); -x_324 = lean_ctor_get(x_6, 2); -x_325 = lean_ctor_get(x_6, 3); -x_326 = lean_ctor_get(x_6, 4); -lean_inc(x_326); -lean_inc(x_325); -lean_inc(x_324); -lean_inc(x_323); -lean_inc(x_322); -lean_dec(x_6); -x_327 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_327, 0, x_252); -lean_ctor_set(x_327, 1, x_27); -x_328 = lean_array_push(x_324, x_327); -x_329 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_329, 0, x_322); -lean_ctor_set(x_329, 1, x_323); -lean_ctor_set(x_329, 2, x_328); -lean_ctor_set(x_329, 3, x_325); -lean_ctor_set(x_329, 4, x_326); -x_330 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__4(x_1, x_2, x_3, x_4, x_254, x_329, x_250); -if (lean_obj_tag(x_330) == 0) -{ -lean_object* x_331; lean_object* x_332; lean_object* x_333; -x_331 = lean_ctor_get(x_330, 0); -lean_inc(x_331); -x_332 = lean_ctor_get(x_330, 1); -lean_inc(x_332); -lean_dec(x_330); -x_333 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_333, 0, x_331); -x_259 = x_333; -x_260 = x_332; -goto block_309; -} -else -{ -lean_object* x_334; lean_object* x_335; lean_object* x_336; -x_334 = lean_ctor_get(x_330, 0); -lean_inc(x_334); -x_335 = lean_ctor_get(x_330, 1); -lean_inc(x_335); -lean_dec(x_330); -x_336 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_336, 0, x_334); -x_259 = x_336; -x_260 = x_335; -goto block_309; -} -} -block_309: -{ -if (lean_obj_tag(x_259) == 0) -{ -lean_object* x_261; lean_object* x_262; uint8_t x_263; -x_261 = lean_ctor_get(x_260, 2); -lean_inc(x_261); -x_262 = lean_ctor_get(x_259, 0); +x_262 = lean_ctor_get(x_255, 0); lean_inc(x_262); -lean_dec(x_259); -x_263 = !lean_is_exclusive(x_260); -if (x_263 == 0) -{ -lean_object* x_264; uint8_t x_265; -x_264 = lean_ctor_get(x_260, 2); -lean_dec(x_264); -x_265 = !lean_is_exclusive(x_261); +lean_dec(x_255); +x_263 = lean_unsigned_to_nat(1u); +x_264 = lean_nat_add(x_5, x_263); +lean_dec(x_5); +x_265 = !lean_is_exclusive(x_260); if (x_265 == 0) { -lean_object* x_266; lean_object* x_267; -x_266 = lean_ctor_get(x_261, 2); -lean_dec(x_266); -lean_ctor_set(x_261, 2, x_258); -if (lean_is_scalar(x_251)) { - x_267 = lean_alloc_ctor(1, 2, 0); -} else { - x_267 = x_251; - lean_ctor_set_tag(x_267, 1); -} -lean_ctor_set(x_267, 0, x_262); -lean_ctor_set(x_267, 1, x_260); -return x_267; +lean_object* x_266; uint8_t x_267; +x_266 = lean_ctor_get(x_260, 2); +x_267 = !lean_is_exclusive(x_266); +if (x_267 == 0) +{ +lean_object* x_268; lean_object* x_269; lean_object* x_270; lean_object* x_324; uint8_t x_325; +x_268 = lean_ctor_get(x_266, 2); +x_324 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_266, 2, x_324); +x_325 = !lean_is_exclusive(x_6); +if (x_325 == 0) +{ +lean_object* x_326; lean_object* x_327; lean_object* x_328; lean_object* x_329; +x_326 = lean_ctor_get(x_6, 2); +x_327 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_327, 0, x_262); +lean_ctor_set(x_327, 1, x_27); +x_328 = lean_array_push(x_326, x_327); +lean_ctor_set(x_6, 2, x_328); +x_329 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__4(x_1, x_2, x_3, x_4, x_264, x_6, x_260); +if (lean_obj_tag(x_329) == 0) +{ +lean_object* x_330; lean_object* x_331; lean_object* x_332; +x_330 = lean_ctor_get(x_329, 0); +lean_inc(x_330); +x_331 = lean_ctor_get(x_329, 1); +lean_inc(x_331); +lean_dec(x_329); +x_332 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_332, 0, x_330); +x_269 = x_332; +x_270 = x_331; +goto block_323; } else { -lean_object* x_268; lean_object* x_269; lean_object* x_270; lean_object* x_271; lean_object* x_272; -x_268 = lean_ctor_get(x_261, 0); -x_269 = lean_ctor_get(x_261, 1); -x_270 = lean_ctor_get(x_261, 3); -lean_inc(x_270); -lean_inc(x_269); -lean_inc(x_268); -lean_dec(x_261); -x_271 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_271, 0, x_268); -lean_ctor_set(x_271, 1, x_269); -lean_ctor_set(x_271, 2, x_258); -lean_ctor_set(x_271, 3, x_270); -lean_ctor_set(x_260, 2, x_271); -if (lean_is_scalar(x_251)) { - x_272 = lean_alloc_ctor(1, 2, 0); -} else { - x_272 = x_251; - lean_ctor_set_tag(x_272, 1); -} -lean_ctor_set(x_272, 0, x_262); -lean_ctor_set(x_272, 1, x_260); -return x_272; +lean_object* x_333; lean_object* x_334; lean_object* x_335; +x_333 = lean_ctor_get(x_329, 0); +lean_inc(x_333); +x_334 = lean_ctor_get(x_329, 1); +lean_inc(x_334); +lean_dec(x_329); +x_335 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_335, 0, x_333); +x_269 = x_335; +x_270 = x_334; +goto block_323; } } else { -lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_object* x_276; lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; lean_object* x_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; -x_273 = lean_ctor_get(x_260, 0); -x_274 = lean_ctor_get(x_260, 1); -x_275 = lean_ctor_get(x_260, 3); -x_276 = lean_ctor_get(x_260, 4); -x_277 = lean_ctor_get(x_260, 5); -lean_inc(x_277); -lean_inc(x_276); -lean_inc(x_275); -lean_inc(x_274); -lean_inc(x_273); -lean_dec(x_260); -x_278 = lean_ctor_get(x_261, 0); -lean_inc(x_278); -x_279 = lean_ctor_get(x_261, 1); -lean_inc(x_279); -x_280 = lean_ctor_get(x_261, 3); +lean_object* x_336; lean_object* x_337; lean_object* x_338; lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; +x_336 = lean_ctor_get(x_6, 0); +x_337 = lean_ctor_get(x_6, 1); +x_338 = lean_ctor_get(x_6, 2); +x_339 = lean_ctor_get(x_6, 3); +x_340 = lean_ctor_get(x_6, 4); +lean_inc(x_340); +lean_inc(x_339); +lean_inc(x_338); +lean_inc(x_337); +lean_inc(x_336); +lean_dec(x_6); +x_341 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_341, 0, x_262); +lean_ctor_set(x_341, 1, x_27); +x_342 = lean_array_push(x_338, x_341); +x_343 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_343, 0, x_336); +lean_ctor_set(x_343, 1, x_337); +lean_ctor_set(x_343, 2, x_342); +lean_ctor_set(x_343, 3, x_339); +lean_ctor_set(x_343, 4, x_340); +x_344 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__4(x_1, x_2, x_3, x_4, x_264, x_343, x_260); +if (lean_obj_tag(x_344) == 0) +{ +lean_object* x_345; lean_object* x_346; lean_object* x_347; +x_345 = lean_ctor_get(x_344, 0); +lean_inc(x_345); +x_346 = lean_ctor_get(x_344, 1); +lean_inc(x_346); +lean_dec(x_344); +x_347 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_347, 0, x_345); +x_269 = x_347; +x_270 = x_346; +goto block_323; +} +else +{ +lean_object* x_348; lean_object* x_349; lean_object* x_350; +x_348 = lean_ctor_get(x_344, 0); +lean_inc(x_348); +x_349 = lean_ctor_get(x_344, 1); +lean_inc(x_349); +lean_dec(x_344); +x_350 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_350, 0, x_348); +x_269 = x_350; +x_270 = x_349; +goto block_323; +} +} +block_323: +{ +if (lean_obj_tag(x_269) == 0) +{ +lean_object* x_271; lean_object* x_272; uint8_t x_273; +x_271 = lean_ctor_get(x_270, 2); +lean_inc(x_271); +x_272 = lean_ctor_get(x_269, 0); +lean_inc(x_272); +lean_dec(x_269); +x_273 = !lean_is_exclusive(x_270); +if (x_273 == 0) +{ +lean_object* x_274; uint8_t x_275; +x_274 = lean_ctor_get(x_270, 2); +lean_dec(x_274); +x_275 = !lean_is_exclusive(x_271); +if (x_275 == 0) +{ +lean_object* x_276; lean_object* x_277; +x_276 = lean_ctor_get(x_271, 2); +lean_dec(x_276); +lean_ctor_set(x_271, 2, x_268); +if (lean_is_scalar(x_261)) { + x_277 = lean_alloc_ctor(1, 2, 0); +} else { + x_277 = x_261; + lean_ctor_set_tag(x_277, 1); +} +lean_ctor_set(x_277, 0, x_272); +lean_ctor_set(x_277, 1, x_270); +return x_277; +} +else +{ +lean_object* x_278; lean_object* x_279; lean_object* x_280; lean_object* x_281; lean_object* x_282; lean_object* x_283; +x_278 = lean_ctor_get(x_271, 0); +x_279 = lean_ctor_get(x_271, 1); +x_280 = lean_ctor_get(x_271, 3); +x_281 = lean_ctor_get(x_271, 4); +lean_inc(x_281); lean_inc(x_280); -if (lean_is_exclusive(x_261)) { - lean_ctor_release(x_261, 0); - lean_ctor_release(x_261, 1); - lean_ctor_release(x_261, 2); - lean_ctor_release(x_261, 3); - x_281 = x_261; -} else { - lean_dec_ref(x_261); - x_281 = lean_box(0); -} -if (lean_is_scalar(x_281)) { - x_282 = lean_alloc_ctor(0, 4, 0); -} else { - x_282 = x_281; -} +lean_inc(x_279); +lean_inc(x_278); +lean_dec(x_271); +x_282 = lean_alloc_ctor(0, 5, 0); lean_ctor_set(x_282, 0, x_278); lean_ctor_set(x_282, 1, x_279); -lean_ctor_set(x_282, 2, x_258); +lean_ctor_set(x_282, 2, x_268); lean_ctor_set(x_282, 3, x_280); -x_283 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_283, 0, x_273); -lean_ctor_set(x_283, 1, x_274); -lean_ctor_set(x_283, 2, x_282); -lean_ctor_set(x_283, 3, x_275); -lean_ctor_set(x_283, 4, x_276); -lean_ctor_set(x_283, 5, x_277); -if (lean_is_scalar(x_251)) { - x_284 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_282, 4, x_281); +lean_ctor_set(x_270, 2, x_282); +if (lean_is_scalar(x_261)) { + x_283 = lean_alloc_ctor(1, 2, 0); } else { - x_284 = x_251; - lean_ctor_set_tag(x_284, 1); + x_283 = x_261; + lean_ctor_set_tag(x_283, 1); } -lean_ctor_set(x_284, 0, x_262); -lean_ctor_set(x_284, 1, x_283); -return x_284; +lean_ctor_set(x_283, 0, x_272); +lean_ctor_set(x_283, 1, x_270); +return x_283; } } else { -lean_object* x_285; lean_object* x_286; uint8_t x_287; -x_285 = lean_ctor_get(x_260, 2); -lean_inc(x_285); -x_286 = lean_ctor_get(x_259, 0); +lean_object* x_284; lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; lean_object* x_289; lean_object* x_290; lean_object* x_291; lean_object* x_292; lean_object* x_293; lean_object* x_294; lean_object* x_295; lean_object* x_296; +x_284 = lean_ctor_get(x_270, 0); +x_285 = lean_ctor_get(x_270, 1); +x_286 = lean_ctor_get(x_270, 3); +x_287 = lean_ctor_get(x_270, 4); +x_288 = lean_ctor_get(x_270, 5); +lean_inc(x_288); +lean_inc(x_287); lean_inc(x_286); -lean_dec(x_259); -x_287 = !lean_is_exclusive(x_260); -if (x_287 == 0) -{ -lean_object* x_288; uint8_t x_289; -x_288 = lean_ctor_get(x_260, 2); -lean_dec(x_288); -x_289 = !lean_is_exclusive(x_285); -if (x_289 == 0) -{ -lean_object* x_290; lean_object* x_291; -x_290 = lean_ctor_get(x_285, 2); -lean_dec(x_290); -lean_ctor_set(x_285, 2, x_258); -if (lean_is_scalar(x_251)) { - x_291 = lean_alloc_ctor(0, 2, 0); -} else { - x_291 = x_251; -} -lean_ctor_set(x_291, 0, x_286); -lean_ctor_set(x_291, 1, x_260); -return x_291; -} -else -{ -lean_object* x_292; lean_object* x_293; lean_object* x_294; lean_object* x_295; lean_object* x_296; -x_292 = lean_ctor_get(x_285, 0); -x_293 = lean_ctor_get(x_285, 1); -x_294 = lean_ctor_get(x_285, 3); -lean_inc(x_294); -lean_inc(x_293); +lean_inc(x_285); +lean_inc(x_284); +lean_dec(x_270); +x_289 = lean_ctor_get(x_271, 0); +lean_inc(x_289); +x_290 = lean_ctor_get(x_271, 1); +lean_inc(x_290); +x_291 = lean_ctor_get(x_271, 3); +lean_inc(x_291); +x_292 = lean_ctor_get(x_271, 4); lean_inc(x_292); -lean_dec(x_285); -x_295 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_295, 0, x_292); -lean_ctor_set(x_295, 1, x_293); -lean_ctor_set(x_295, 2, x_258); -lean_ctor_set(x_295, 3, x_294); -lean_ctor_set(x_260, 2, x_295); -if (lean_is_scalar(x_251)) { - x_296 = lean_alloc_ctor(0, 2, 0); +if (lean_is_exclusive(x_271)) { + lean_ctor_release(x_271, 0); + lean_ctor_release(x_271, 1); + lean_ctor_release(x_271, 2); + lean_ctor_release(x_271, 3); + lean_ctor_release(x_271, 4); + x_293 = x_271; } else { - x_296 = x_251; + lean_dec_ref(x_271); + x_293 = lean_box(0); } -lean_ctor_set(x_296, 0, x_286); -lean_ctor_set(x_296, 1, x_260); +if (lean_is_scalar(x_293)) { + x_294 = lean_alloc_ctor(0, 5, 0); +} else { + x_294 = x_293; +} +lean_ctor_set(x_294, 0, x_289); +lean_ctor_set(x_294, 1, x_290); +lean_ctor_set(x_294, 2, x_268); +lean_ctor_set(x_294, 3, x_291); +lean_ctor_set(x_294, 4, x_292); +x_295 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_295, 0, x_284); +lean_ctor_set(x_295, 1, x_285); +lean_ctor_set(x_295, 2, x_294); +lean_ctor_set(x_295, 3, x_286); +lean_ctor_set(x_295, 4, x_287); +lean_ctor_set(x_295, 5, x_288); +if (lean_is_scalar(x_261)) { + x_296 = lean_alloc_ctor(1, 2, 0); +} else { + x_296 = x_261; + lean_ctor_set_tag(x_296, 1); +} +lean_ctor_set(x_296, 0, x_272); +lean_ctor_set(x_296, 1, x_295); return x_296; } } else { -lean_object* x_297; lean_object* x_298; lean_object* x_299; lean_object* x_300; lean_object* x_301; lean_object* x_302; lean_object* x_303; lean_object* x_304; lean_object* x_305; lean_object* x_306; lean_object* x_307; lean_object* x_308; -x_297 = lean_ctor_get(x_260, 0); -x_298 = lean_ctor_get(x_260, 1); -x_299 = lean_ctor_get(x_260, 3); -x_300 = lean_ctor_get(x_260, 4); -x_301 = lean_ctor_get(x_260, 5); -lean_inc(x_301); -lean_inc(x_300); -lean_inc(x_299); -lean_inc(x_298); +lean_object* x_297; lean_object* x_298; uint8_t x_299; +x_297 = lean_ctor_get(x_270, 2); lean_inc(x_297); -lean_dec(x_260); -x_302 = lean_ctor_get(x_285, 0); -lean_inc(x_302); -x_303 = lean_ctor_get(x_285, 1); -lean_inc(x_303); -x_304 = lean_ctor_get(x_285, 3); +x_298 = lean_ctor_get(x_269, 0); +lean_inc(x_298); +lean_dec(x_269); +x_299 = !lean_is_exclusive(x_270); +if (x_299 == 0) +{ +lean_object* x_300; uint8_t x_301; +x_300 = lean_ctor_get(x_270, 2); +lean_dec(x_300); +x_301 = !lean_is_exclusive(x_297); +if (x_301 == 0) +{ +lean_object* x_302; lean_object* x_303; +x_302 = lean_ctor_get(x_297, 2); +lean_dec(x_302); +lean_ctor_set(x_297, 2, x_268); +if (lean_is_scalar(x_261)) { + x_303 = lean_alloc_ctor(0, 2, 0); +} else { + x_303 = x_261; +} +lean_ctor_set(x_303, 0, x_298); +lean_ctor_set(x_303, 1, x_270); +return x_303; +} +else +{ +lean_object* x_304; lean_object* x_305; lean_object* x_306; lean_object* x_307; lean_object* x_308; lean_object* x_309; +x_304 = lean_ctor_get(x_297, 0); +x_305 = lean_ctor_get(x_297, 1); +x_306 = lean_ctor_get(x_297, 3); +x_307 = lean_ctor_get(x_297, 4); +lean_inc(x_307); +lean_inc(x_306); +lean_inc(x_305); lean_inc(x_304); -if (lean_is_exclusive(x_285)) { - lean_ctor_release(x_285, 0); - lean_ctor_release(x_285, 1); - lean_ctor_release(x_285, 2); - lean_ctor_release(x_285, 3); - x_305 = x_285; +lean_dec(x_297); +x_308 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_308, 0, x_304); +lean_ctor_set(x_308, 1, x_305); +lean_ctor_set(x_308, 2, x_268); +lean_ctor_set(x_308, 3, x_306); +lean_ctor_set(x_308, 4, x_307); +lean_ctor_set(x_270, 2, x_308); +if (lean_is_scalar(x_261)) { + x_309 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_285); - x_305 = lean_box(0); + x_309 = x_261; } -if (lean_is_scalar(x_305)) { - x_306 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_309, 0, x_298); +lean_ctor_set(x_309, 1, x_270); +return x_309; +} +} +else +{ +lean_object* x_310; lean_object* x_311; lean_object* x_312; lean_object* x_313; lean_object* x_314; lean_object* x_315; lean_object* x_316; lean_object* x_317; lean_object* x_318; lean_object* x_319; lean_object* x_320; lean_object* x_321; lean_object* x_322; +x_310 = lean_ctor_get(x_270, 0); +x_311 = lean_ctor_get(x_270, 1); +x_312 = lean_ctor_get(x_270, 3); +x_313 = lean_ctor_get(x_270, 4); +x_314 = lean_ctor_get(x_270, 5); +lean_inc(x_314); +lean_inc(x_313); +lean_inc(x_312); +lean_inc(x_311); +lean_inc(x_310); +lean_dec(x_270); +x_315 = lean_ctor_get(x_297, 0); +lean_inc(x_315); +x_316 = lean_ctor_get(x_297, 1); +lean_inc(x_316); +x_317 = lean_ctor_get(x_297, 3); +lean_inc(x_317); +x_318 = lean_ctor_get(x_297, 4); +lean_inc(x_318); +if (lean_is_exclusive(x_297)) { + lean_ctor_release(x_297, 0); + lean_ctor_release(x_297, 1); + lean_ctor_release(x_297, 2); + lean_ctor_release(x_297, 3); + lean_ctor_release(x_297, 4); + x_319 = x_297; } else { - x_306 = x_305; + lean_dec_ref(x_297); + x_319 = lean_box(0); } -lean_ctor_set(x_306, 0, x_302); -lean_ctor_set(x_306, 1, x_303); -lean_ctor_set(x_306, 2, x_258); -lean_ctor_set(x_306, 3, x_304); -x_307 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_307, 0, x_297); -lean_ctor_set(x_307, 1, x_298); -lean_ctor_set(x_307, 2, x_306); -lean_ctor_set(x_307, 3, x_299); -lean_ctor_set(x_307, 4, x_300); -lean_ctor_set(x_307, 5, x_301); -if (lean_is_scalar(x_251)) { - x_308 = lean_alloc_ctor(0, 2, 0); +if (lean_is_scalar(x_319)) { + x_320 = lean_alloc_ctor(0, 5, 0); } else { - x_308 = x_251; + x_320 = x_319; } -lean_ctor_set(x_308, 0, x_286); -lean_ctor_set(x_308, 1, x_307); -return x_308; +lean_ctor_set(x_320, 0, x_315); +lean_ctor_set(x_320, 1, x_316); +lean_ctor_set(x_320, 2, x_268); +lean_ctor_set(x_320, 3, x_317); +lean_ctor_set(x_320, 4, x_318); +x_321 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_321, 0, x_310); +lean_ctor_set(x_321, 1, x_311); +lean_ctor_set(x_321, 2, x_320); +lean_ctor_set(x_321, 3, x_312); +lean_ctor_set(x_321, 4, x_313); +lean_ctor_set(x_321, 5, x_314); +if (lean_is_scalar(x_261)) { + x_322 = lean_alloc_ctor(0, 2, 0); +} else { + x_322 = x_261; +} +lean_ctor_set(x_322, 0, x_298); +lean_ctor_set(x_322, 1, x_321); +return x_322; } } } } else { -lean_object* x_337; lean_object* x_338; lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_374; lean_object* x_375; 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; -x_337 = lean_ctor_get(x_256, 0); -x_338 = lean_ctor_get(x_256, 1); -x_339 = lean_ctor_get(x_256, 2); -x_340 = lean_ctor_get(x_256, 3); -lean_inc(x_340); -lean_inc(x_339); -lean_inc(x_338); -lean_inc(x_337); -lean_dec(x_256); -x_374 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_375 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_375, 0, x_337); -lean_ctor_set(x_375, 1, x_338); -lean_ctor_set(x_375, 2, x_374); -lean_ctor_set(x_375, 3, x_340); -lean_ctor_set(x_250, 2, x_375); -x_376 = lean_ctor_get(x_6, 0); -lean_inc(x_376); -x_377 = lean_ctor_get(x_6, 1); -lean_inc(x_377); -x_378 = lean_ctor_get(x_6, 2); -lean_inc(x_378); -x_379 = lean_ctor_get(x_6, 3); -lean_inc(x_379); -x_380 = lean_ctor_get(x_6, 4); -lean_inc(x_380); +lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; lean_object* x_391; lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; lean_object* x_400; lean_object* x_401; lean_object* x_402; +x_351 = lean_ctor_get(x_266, 0); +x_352 = lean_ctor_get(x_266, 1); +x_353 = lean_ctor_get(x_266, 2); +x_354 = lean_ctor_get(x_266, 3); +x_355 = lean_ctor_get(x_266, 4); +lean_inc(x_355); +lean_inc(x_354); +lean_inc(x_353); +lean_inc(x_352); +lean_inc(x_351); +lean_dec(x_266); +x_391 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_392 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_392, 0, x_351); +lean_ctor_set(x_392, 1, x_352); +lean_ctor_set(x_392, 2, x_391); +lean_ctor_set(x_392, 3, x_354); +lean_ctor_set(x_392, 4, x_355); +lean_ctor_set(x_260, 2, x_392); +x_393 = lean_ctor_get(x_6, 0); +lean_inc(x_393); +x_394 = lean_ctor_get(x_6, 1); +lean_inc(x_394); +x_395 = lean_ctor_get(x_6, 2); +lean_inc(x_395); +x_396 = lean_ctor_get(x_6, 3); +lean_inc(x_396); +x_397 = lean_ctor_get(x_6, 4); +lean_inc(x_397); if (lean_is_exclusive(x_6)) { lean_ctor_release(x_6, 0); lean_ctor_release(x_6, 1); lean_ctor_release(x_6, 2); lean_ctor_release(x_6, 3); lean_ctor_release(x_6, 4); - x_381 = x_6; + x_398 = x_6; } else { lean_dec_ref(x_6); - x_381 = lean_box(0); + x_398 = lean_box(0); } -x_382 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_382, 0, x_252); -lean_ctor_set(x_382, 1, x_27); -x_383 = lean_array_push(x_378, x_382); -if (lean_is_scalar(x_381)) { - x_384 = lean_alloc_ctor(0, 5, 0); +x_399 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_399, 0, x_262); +lean_ctor_set(x_399, 1, x_27); +x_400 = lean_array_push(x_395, x_399); +if (lean_is_scalar(x_398)) { + x_401 = lean_alloc_ctor(0, 5, 0); } else { - x_384 = x_381; + x_401 = x_398; } -lean_ctor_set(x_384, 0, x_376); -lean_ctor_set(x_384, 1, x_377); -lean_ctor_set(x_384, 2, x_383); -lean_ctor_set(x_384, 3, x_379); -lean_ctor_set(x_384, 4, x_380); -x_385 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__4(x_1, x_2, x_3, x_4, x_254, x_384, x_250); -if (lean_obj_tag(x_385) == 0) +lean_ctor_set(x_401, 0, x_393); +lean_ctor_set(x_401, 1, x_394); +lean_ctor_set(x_401, 2, x_400); +lean_ctor_set(x_401, 3, x_396); +lean_ctor_set(x_401, 4, x_397); +x_402 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__4(x_1, x_2, x_3, x_4, x_264, x_401, x_260); +if (lean_obj_tag(x_402) == 0) { -lean_object* x_386; lean_object* x_387; lean_object* x_388; -x_386 = lean_ctor_get(x_385, 0); -lean_inc(x_386); -x_387 = lean_ctor_get(x_385, 1); -lean_inc(x_387); -lean_dec(x_385); -x_388 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_388, 0, x_386); -x_341 = x_388; -x_342 = x_387; -goto block_373; +lean_object* x_403; lean_object* x_404; lean_object* x_405; +x_403 = lean_ctor_get(x_402, 0); +lean_inc(x_403); +x_404 = lean_ctor_get(x_402, 1); +lean_inc(x_404); +lean_dec(x_402); +x_405 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_405, 0, x_403); +x_356 = x_405; +x_357 = x_404; +goto block_390; } else { -lean_object* x_389; lean_object* x_390; lean_object* x_391; -x_389 = lean_ctor_get(x_385, 0); -lean_inc(x_389); -x_390 = lean_ctor_get(x_385, 1); -lean_inc(x_390); -lean_dec(x_385); -x_391 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_391, 0, x_389); -x_341 = x_391; -x_342 = x_390; -goto block_373; +lean_object* x_406; lean_object* x_407; lean_object* x_408; +x_406 = lean_ctor_get(x_402, 0); +lean_inc(x_406); +x_407 = lean_ctor_get(x_402, 1); +lean_inc(x_407); +lean_dec(x_402); +x_408 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_408, 0, x_406); +x_356 = x_408; +x_357 = x_407; +goto block_390; } -block_373: +block_390: { -if (lean_obj_tag(x_341) == 0) +if (lean_obj_tag(x_356) == 0) { -lean_object* x_343; lean_object* x_344; lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; lean_object* x_350; lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; -x_343 = lean_ctor_get(x_342, 2); -lean_inc(x_343); -x_344 = lean_ctor_get(x_341, 0); -lean_inc(x_344); -lean_dec(x_341); -x_345 = lean_ctor_get(x_342, 0); -lean_inc(x_345); -x_346 = lean_ctor_get(x_342, 1); -lean_inc(x_346); -x_347 = lean_ctor_get(x_342, 3); -lean_inc(x_347); -x_348 = lean_ctor_get(x_342, 4); -lean_inc(x_348); -x_349 = lean_ctor_get(x_342, 5); -lean_inc(x_349); -if (lean_is_exclusive(x_342)) { - lean_ctor_release(x_342, 0); - lean_ctor_release(x_342, 1); - lean_ctor_release(x_342, 2); - lean_ctor_release(x_342, 3); - lean_ctor_release(x_342, 4); - lean_ctor_release(x_342, 5); - x_350 = x_342; -} else { - lean_dec_ref(x_342); - x_350 = lean_box(0); -} -x_351 = lean_ctor_get(x_343, 0); -lean_inc(x_351); -x_352 = lean_ctor_get(x_343, 1); -lean_inc(x_352); -x_353 = lean_ctor_get(x_343, 3); -lean_inc(x_353); -if (lean_is_exclusive(x_343)) { - lean_ctor_release(x_343, 0); - lean_ctor_release(x_343, 1); - lean_ctor_release(x_343, 2); - lean_ctor_release(x_343, 3); - x_354 = x_343; -} else { - lean_dec_ref(x_343); - x_354 = lean_box(0); -} -if (lean_is_scalar(x_354)) { - x_355 = lean_alloc_ctor(0, 4, 0); -} else { - x_355 = x_354; -} -lean_ctor_set(x_355, 0, x_351); -lean_ctor_set(x_355, 1, x_352); -lean_ctor_set(x_355, 2, x_339); -lean_ctor_set(x_355, 3, x_353); -if (lean_is_scalar(x_350)) { - x_356 = lean_alloc_ctor(0, 6, 0); -} else { - x_356 = x_350; -} -lean_ctor_set(x_356, 0, x_345); -lean_ctor_set(x_356, 1, x_346); -lean_ctor_set(x_356, 2, x_355); -lean_ctor_set(x_356, 3, x_347); -lean_ctor_set(x_356, 4, x_348); -lean_ctor_set(x_356, 5, x_349); -if (lean_is_scalar(x_251)) { - x_357 = lean_alloc_ctor(1, 2, 0); -} else { - x_357 = x_251; - lean_ctor_set_tag(x_357, 1); -} -lean_ctor_set(x_357, 0, x_344); -lean_ctor_set(x_357, 1, x_356); -return x_357; -} -else -{ -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; -x_358 = lean_ctor_get(x_342, 2); +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, 2); lean_inc(x_358); -x_359 = lean_ctor_get(x_341, 0); +x_359 = lean_ctor_get(x_356, 0); lean_inc(x_359); -lean_dec(x_341); -x_360 = lean_ctor_get(x_342, 0); +lean_dec(x_356); +x_360 = lean_ctor_get(x_357, 0); lean_inc(x_360); -x_361 = lean_ctor_get(x_342, 1); +x_361 = lean_ctor_get(x_357, 1); lean_inc(x_361); -x_362 = lean_ctor_get(x_342, 3); +x_362 = lean_ctor_get(x_357, 3); lean_inc(x_362); -x_363 = lean_ctor_get(x_342, 4); +x_363 = lean_ctor_get(x_357, 4); lean_inc(x_363); -x_364 = lean_ctor_get(x_342, 5); +x_364 = lean_ctor_get(x_357, 5); lean_inc(x_364); -if (lean_is_exclusive(x_342)) { - lean_ctor_release(x_342, 0); - lean_ctor_release(x_342, 1); - lean_ctor_release(x_342, 2); - lean_ctor_release(x_342, 3); - lean_ctor_release(x_342, 4); - lean_ctor_release(x_342, 5); - x_365 = x_342; +if (lean_is_exclusive(x_357)) { + lean_ctor_release(x_357, 0); + lean_ctor_release(x_357, 1); + lean_ctor_release(x_357, 2); + lean_ctor_release(x_357, 3); + lean_ctor_release(x_357, 4); + lean_ctor_release(x_357, 5); + x_365 = x_357; } else { - lean_dec_ref(x_342); + lean_dec_ref(x_357); x_365 = lean_box(0); } x_366 = lean_ctor_get(x_358, 0); @@ -4182,315 +4171,411 @@ x_367 = lean_ctor_get(x_358, 1); lean_inc(x_367); x_368 = lean_ctor_get(x_358, 3); lean_inc(x_368); +x_369 = lean_ctor_get(x_358, 4); +lean_inc(x_369); if (lean_is_exclusive(x_358)) { lean_ctor_release(x_358, 0); lean_ctor_release(x_358, 1); lean_ctor_release(x_358, 2); lean_ctor_release(x_358, 3); - x_369 = x_358; + lean_ctor_release(x_358, 4); + x_370 = x_358; } else { lean_dec_ref(x_358); - x_369 = lean_box(0); + x_370 = lean_box(0); } -if (lean_is_scalar(x_369)) { - x_370 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_370)) { + x_371 = lean_alloc_ctor(0, 5, 0); } else { - x_370 = x_369; + x_371 = x_370; } -lean_ctor_set(x_370, 0, x_366); -lean_ctor_set(x_370, 1, x_367); -lean_ctor_set(x_370, 2, x_339); -lean_ctor_set(x_370, 3, x_368); +lean_ctor_set(x_371, 0, x_366); +lean_ctor_set(x_371, 1, x_367); +lean_ctor_set(x_371, 2, x_353); +lean_ctor_set(x_371, 3, x_368); +lean_ctor_set(x_371, 4, x_369); if (lean_is_scalar(x_365)) { - x_371 = lean_alloc_ctor(0, 6, 0); + x_372 = lean_alloc_ctor(0, 6, 0); } else { - x_371 = x_365; + x_372 = x_365; } -lean_ctor_set(x_371, 0, x_360); -lean_ctor_set(x_371, 1, x_361); -lean_ctor_set(x_371, 2, x_370); -lean_ctor_set(x_371, 3, x_362); -lean_ctor_set(x_371, 4, x_363); -lean_ctor_set(x_371, 5, x_364); -if (lean_is_scalar(x_251)) { - x_372 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_372, 0, x_360); +lean_ctor_set(x_372, 1, x_361); +lean_ctor_set(x_372, 2, x_371); +lean_ctor_set(x_372, 3, x_362); +lean_ctor_set(x_372, 4, x_363); +lean_ctor_set(x_372, 5, x_364); +if (lean_is_scalar(x_261)) { + x_373 = lean_alloc_ctor(1, 2, 0); } else { - x_372 = x_251; + x_373 = x_261; + lean_ctor_set_tag(x_373, 1); } -lean_ctor_set(x_372, 0, x_359); -lean_ctor_set(x_372, 1, x_371); -return x_372; +lean_ctor_set(x_373, 0, x_359); +lean_ctor_set(x_373, 1, x_372); +return x_373; +} +else +{ +lean_object* x_374; lean_object* x_375; 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; +x_374 = lean_ctor_get(x_357, 2); +lean_inc(x_374); +x_375 = lean_ctor_get(x_356, 0); +lean_inc(x_375); +lean_dec(x_356); +x_376 = lean_ctor_get(x_357, 0); +lean_inc(x_376); +x_377 = lean_ctor_get(x_357, 1); +lean_inc(x_377); +x_378 = lean_ctor_get(x_357, 3); +lean_inc(x_378); +x_379 = lean_ctor_get(x_357, 4); +lean_inc(x_379); +x_380 = lean_ctor_get(x_357, 5); +lean_inc(x_380); +if (lean_is_exclusive(x_357)) { + lean_ctor_release(x_357, 0); + lean_ctor_release(x_357, 1); + lean_ctor_release(x_357, 2); + lean_ctor_release(x_357, 3); + lean_ctor_release(x_357, 4); + lean_ctor_release(x_357, 5); + x_381 = x_357; +} else { + lean_dec_ref(x_357); + x_381 = lean_box(0); +} +x_382 = lean_ctor_get(x_374, 0); +lean_inc(x_382); +x_383 = lean_ctor_get(x_374, 1); +lean_inc(x_383); +x_384 = lean_ctor_get(x_374, 3); +lean_inc(x_384); +x_385 = lean_ctor_get(x_374, 4); +lean_inc(x_385); +if (lean_is_exclusive(x_374)) { + lean_ctor_release(x_374, 0); + lean_ctor_release(x_374, 1); + lean_ctor_release(x_374, 2); + lean_ctor_release(x_374, 3); + lean_ctor_release(x_374, 4); + x_386 = x_374; +} else { + lean_dec_ref(x_374); + x_386 = lean_box(0); +} +if (lean_is_scalar(x_386)) { + x_387 = lean_alloc_ctor(0, 5, 0); +} else { + x_387 = x_386; +} +lean_ctor_set(x_387, 0, x_382); +lean_ctor_set(x_387, 1, x_383); +lean_ctor_set(x_387, 2, x_353); +lean_ctor_set(x_387, 3, x_384); +lean_ctor_set(x_387, 4, x_385); +if (lean_is_scalar(x_381)) { + x_388 = lean_alloc_ctor(0, 6, 0); +} else { + x_388 = x_381; +} +lean_ctor_set(x_388, 0, x_376); +lean_ctor_set(x_388, 1, x_377); +lean_ctor_set(x_388, 2, x_387); +lean_ctor_set(x_388, 3, x_378); +lean_ctor_set(x_388, 4, x_379); +lean_ctor_set(x_388, 5, x_380); +if (lean_is_scalar(x_261)) { + x_389 = lean_alloc_ctor(0, 2, 0); +} else { + x_389 = x_261; +} +lean_ctor_set(x_389, 0, x_375); +lean_ctor_set(x_389, 1, x_388); +return x_389; } } } } else { -lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; lean_object* x_400; lean_object* x_401; lean_object* x_402; lean_object* x_403; lean_object* x_404; 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; lean_object* x_445; lean_object* x_446; lean_object* x_447; lean_object* x_448; -x_392 = lean_ctor_get(x_250, 2); -x_393 = lean_ctor_get(x_250, 0); -x_394 = lean_ctor_get(x_250, 1); -x_395 = lean_ctor_get(x_250, 3); -x_396 = lean_ctor_get(x_250, 4); -x_397 = lean_ctor_get(x_250, 5); -lean_inc(x_397); -lean_inc(x_396); -lean_inc(x_395); -lean_inc(x_392); -lean_inc(x_394); -lean_inc(x_393); -lean_dec(x_250); -x_398 = lean_ctor_get(x_392, 0); -lean_inc(x_398); -x_399 = lean_ctor_get(x_392, 1); -lean_inc(x_399); -x_400 = lean_ctor_get(x_392, 2); -lean_inc(x_400); -x_401 = lean_ctor_get(x_392, 3); -lean_inc(x_401); -if (lean_is_exclusive(x_392)) { - lean_ctor_release(x_392, 0); - lean_ctor_release(x_392, 1); - lean_ctor_release(x_392, 2); - lean_ctor_release(x_392, 3); - x_402 = x_392; +lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_object* x_412; lean_object* x_413; lean_object* x_414; lean_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_456; lean_object* x_457; lean_object* x_458; lean_object* x_459; lean_object* x_460; lean_object* x_461; lean_object* x_462; lean_object* x_463; lean_object* x_464; lean_object* x_465; lean_object* x_466; lean_object* x_467; lean_object* x_468; +x_409 = lean_ctor_get(x_260, 2); +x_410 = lean_ctor_get(x_260, 0); +x_411 = lean_ctor_get(x_260, 1); +x_412 = lean_ctor_get(x_260, 3); +x_413 = lean_ctor_get(x_260, 4); +x_414 = lean_ctor_get(x_260, 5); +lean_inc(x_414); +lean_inc(x_413); +lean_inc(x_412); +lean_inc(x_409); +lean_inc(x_411); +lean_inc(x_410); +lean_dec(x_260); +x_415 = lean_ctor_get(x_409, 0); +lean_inc(x_415); +x_416 = lean_ctor_get(x_409, 1); +lean_inc(x_416); +x_417 = lean_ctor_get(x_409, 2); +lean_inc(x_417); +x_418 = lean_ctor_get(x_409, 3); +lean_inc(x_418); +x_419 = lean_ctor_get(x_409, 4); +lean_inc(x_419); +if (lean_is_exclusive(x_409)) { + lean_ctor_release(x_409, 0); + lean_ctor_release(x_409, 1); + lean_ctor_release(x_409, 2); + lean_ctor_release(x_409, 3); + lean_ctor_release(x_409, 4); + x_420 = x_409; } else { - lean_dec_ref(x_392); - x_402 = lean_box(0); + lean_dec_ref(x_409); + x_420 = lean_box(0); } -x_436 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_402)) { - x_437 = lean_alloc_ctor(0, 4, 0); +x_456 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_420)) { + x_457 = lean_alloc_ctor(0, 5, 0); } else { - x_437 = x_402; + x_457 = x_420; } -lean_ctor_set(x_437, 0, x_398); -lean_ctor_set(x_437, 1, x_399); -lean_ctor_set(x_437, 2, x_436); -lean_ctor_set(x_437, 3, x_401); -x_438 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_438, 0, x_393); -lean_ctor_set(x_438, 1, x_394); -lean_ctor_set(x_438, 2, x_437); -lean_ctor_set(x_438, 3, x_395); -lean_ctor_set(x_438, 4, x_396); -lean_ctor_set(x_438, 5, x_397); -x_439 = lean_ctor_get(x_6, 0); -lean_inc(x_439); -x_440 = lean_ctor_get(x_6, 1); -lean_inc(x_440); -x_441 = lean_ctor_get(x_6, 2); -lean_inc(x_441); -x_442 = lean_ctor_get(x_6, 3); -lean_inc(x_442); -x_443 = lean_ctor_get(x_6, 4); -lean_inc(x_443); +lean_ctor_set(x_457, 0, x_415); +lean_ctor_set(x_457, 1, x_416); +lean_ctor_set(x_457, 2, x_456); +lean_ctor_set(x_457, 3, x_418); +lean_ctor_set(x_457, 4, x_419); +x_458 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_458, 0, x_410); +lean_ctor_set(x_458, 1, x_411); +lean_ctor_set(x_458, 2, x_457); +lean_ctor_set(x_458, 3, x_412); +lean_ctor_set(x_458, 4, x_413); +lean_ctor_set(x_458, 5, x_414); +x_459 = lean_ctor_get(x_6, 0); +lean_inc(x_459); +x_460 = lean_ctor_get(x_6, 1); +lean_inc(x_460); +x_461 = lean_ctor_get(x_6, 2); +lean_inc(x_461); +x_462 = lean_ctor_get(x_6, 3); +lean_inc(x_462); +x_463 = lean_ctor_get(x_6, 4); +lean_inc(x_463); if (lean_is_exclusive(x_6)) { lean_ctor_release(x_6, 0); lean_ctor_release(x_6, 1); lean_ctor_release(x_6, 2); lean_ctor_release(x_6, 3); lean_ctor_release(x_6, 4); - x_444 = x_6; + x_464 = x_6; } else { lean_dec_ref(x_6); - x_444 = lean_box(0); + x_464 = lean_box(0); } -x_445 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_445, 0, x_252); -lean_ctor_set(x_445, 1, x_27); -x_446 = lean_array_push(x_441, x_445); -if (lean_is_scalar(x_444)) { - x_447 = lean_alloc_ctor(0, 5, 0); +x_465 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_465, 0, x_262); +lean_ctor_set(x_465, 1, x_27); +x_466 = lean_array_push(x_461, x_465); +if (lean_is_scalar(x_464)) { + x_467 = lean_alloc_ctor(0, 5, 0); } else { - x_447 = x_444; + x_467 = x_464; } -lean_ctor_set(x_447, 0, x_439); -lean_ctor_set(x_447, 1, x_440); -lean_ctor_set(x_447, 2, x_446); -lean_ctor_set(x_447, 3, x_442); -lean_ctor_set(x_447, 4, x_443); -x_448 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__4(x_1, x_2, x_3, x_4, x_254, x_447, x_438); -if (lean_obj_tag(x_448) == 0) +lean_ctor_set(x_467, 0, x_459); +lean_ctor_set(x_467, 1, x_460); +lean_ctor_set(x_467, 2, x_466); +lean_ctor_set(x_467, 3, x_462); +lean_ctor_set(x_467, 4, x_463); +x_468 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__4(x_1, x_2, x_3, x_4, x_264, x_467, x_458); +if (lean_obj_tag(x_468) == 0) { -lean_object* x_449; lean_object* x_450; lean_object* x_451; -x_449 = lean_ctor_get(x_448, 0); -lean_inc(x_449); -x_450 = lean_ctor_get(x_448, 1); -lean_inc(x_450); -lean_dec(x_448); -x_451 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_451, 0, x_449); -x_403 = x_451; -x_404 = x_450; -goto block_435; +lean_object* x_469; lean_object* x_470; lean_object* x_471; +x_469 = lean_ctor_get(x_468, 0); +lean_inc(x_469); +x_470 = lean_ctor_get(x_468, 1); +lean_inc(x_470); +lean_dec(x_468); +x_471 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_471, 0, x_469); +x_421 = x_471; +x_422 = x_470; +goto block_455; } else { -lean_object* x_452; lean_object* x_453; lean_object* x_454; -x_452 = lean_ctor_get(x_448, 0); -lean_inc(x_452); -x_453 = lean_ctor_get(x_448, 1); -lean_inc(x_453); -lean_dec(x_448); -x_454 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_454, 0, x_452); -x_403 = x_454; -x_404 = x_453; -goto block_435; +lean_object* x_472; lean_object* x_473; lean_object* x_474; +x_472 = lean_ctor_get(x_468, 0); +lean_inc(x_472); +x_473 = lean_ctor_get(x_468, 1); +lean_inc(x_473); +lean_dec(x_468); +x_474 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_474, 0, x_472); +x_421 = x_474; +x_422 = x_473; +goto block_455; } -block_435: +block_455: { -if (lean_obj_tag(x_403) == 0) +if (lean_obj_tag(x_421) == 0) { -lean_object* x_405; lean_object* x_406; lean_object* x_407; lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_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; -x_405 = lean_ctor_get(x_404, 2); -lean_inc(x_405); -x_406 = lean_ctor_get(x_403, 0); -lean_inc(x_406); -lean_dec(x_403); -x_407 = lean_ctor_get(x_404, 0); -lean_inc(x_407); -x_408 = lean_ctor_get(x_404, 1); -lean_inc(x_408); -x_409 = lean_ctor_get(x_404, 3); -lean_inc(x_409); -x_410 = lean_ctor_get(x_404, 4); -lean_inc(x_410); -x_411 = lean_ctor_get(x_404, 5); -lean_inc(x_411); -if (lean_is_exclusive(x_404)) { - lean_ctor_release(x_404, 0); - lean_ctor_release(x_404, 1); - lean_ctor_release(x_404, 2); - lean_ctor_release(x_404, 3); - lean_ctor_release(x_404, 4); - lean_ctor_release(x_404, 5); - x_412 = x_404; -} else { - lean_dec_ref(x_404); - x_412 = lean_box(0); -} -x_413 = lean_ctor_get(x_405, 0); -lean_inc(x_413); -x_414 = lean_ctor_get(x_405, 1); -lean_inc(x_414); -x_415 = lean_ctor_get(x_405, 3); -lean_inc(x_415); -if (lean_is_exclusive(x_405)) { - lean_ctor_release(x_405, 0); - lean_ctor_release(x_405, 1); - lean_ctor_release(x_405, 2); - lean_ctor_release(x_405, 3); - x_416 = x_405; -} else { - lean_dec_ref(x_405); - x_416 = lean_box(0); -} -if (lean_is_scalar(x_416)) { - x_417 = lean_alloc_ctor(0, 4, 0); -} else { - x_417 = x_416; -} -lean_ctor_set(x_417, 0, x_413); -lean_ctor_set(x_417, 1, x_414); -lean_ctor_set(x_417, 2, x_400); -lean_ctor_set(x_417, 3, x_415); -if (lean_is_scalar(x_412)) { - x_418 = lean_alloc_ctor(0, 6, 0); -} else { - x_418 = x_412; -} -lean_ctor_set(x_418, 0, x_407); -lean_ctor_set(x_418, 1, x_408); -lean_ctor_set(x_418, 2, x_417); -lean_ctor_set(x_418, 3, x_409); -lean_ctor_set(x_418, 4, x_410); -lean_ctor_set(x_418, 5, x_411); -if (lean_is_scalar(x_251)) { - x_419 = lean_alloc_ctor(1, 2, 0); -} else { - x_419 = x_251; - lean_ctor_set_tag(x_419, 1); -} -lean_ctor_set(x_419, 0, x_406); -lean_ctor_set(x_419, 1, x_418); -return x_419; -} -else -{ -lean_object* x_420; lean_object* x_421; lean_object* x_422; lean_object* x_423; lean_object* x_424; lean_object* x_425; lean_object* x_426; lean_object* x_427; 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; -x_420 = lean_ctor_get(x_404, 2); -lean_inc(x_420); -x_421 = lean_ctor_get(x_403, 0); -lean_inc(x_421); -lean_dec(x_403); -x_422 = lean_ctor_get(x_404, 0); -lean_inc(x_422); -x_423 = lean_ctor_get(x_404, 1); +lean_object* x_423; lean_object* x_424; lean_object* x_425; lean_object* x_426; lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; 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; +x_423 = lean_ctor_get(x_422, 2); lean_inc(x_423); -x_424 = lean_ctor_get(x_404, 3); +x_424 = lean_ctor_get(x_421, 0); lean_inc(x_424); -x_425 = lean_ctor_get(x_404, 4); +lean_dec(x_421); +x_425 = lean_ctor_get(x_422, 0); lean_inc(x_425); -x_426 = lean_ctor_get(x_404, 5); +x_426 = lean_ctor_get(x_422, 1); lean_inc(x_426); -if (lean_is_exclusive(x_404)) { - lean_ctor_release(x_404, 0); - lean_ctor_release(x_404, 1); - lean_ctor_release(x_404, 2); - lean_ctor_release(x_404, 3); - lean_ctor_release(x_404, 4); - lean_ctor_release(x_404, 5); - x_427 = x_404; -} else { - lean_dec_ref(x_404); - x_427 = lean_box(0); -} -x_428 = lean_ctor_get(x_420, 0); +x_427 = lean_ctor_get(x_422, 3); +lean_inc(x_427); +x_428 = lean_ctor_get(x_422, 4); lean_inc(x_428); -x_429 = lean_ctor_get(x_420, 1); +x_429 = lean_ctor_get(x_422, 5); lean_inc(x_429); -x_430 = lean_ctor_get(x_420, 3); -lean_inc(x_430); -if (lean_is_exclusive(x_420)) { - lean_ctor_release(x_420, 0); - lean_ctor_release(x_420, 1); - lean_ctor_release(x_420, 2); - lean_ctor_release(x_420, 3); - x_431 = x_420; +if (lean_is_exclusive(x_422)) { + lean_ctor_release(x_422, 0); + lean_ctor_release(x_422, 1); + lean_ctor_release(x_422, 2); + lean_ctor_release(x_422, 3); + lean_ctor_release(x_422, 4); + lean_ctor_release(x_422, 5); + x_430 = x_422; } else { - lean_dec_ref(x_420); - x_431 = lean_box(0); + lean_dec_ref(x_422); + x_430 = lean_box(0); } -if (lean_is_scalar(x_431)) { - x_432 = lean_alloc_ctor(0, 4, 0); +x_431 = lean_ctor_get(x_423, 0); +lean_inc(x_431); +x_432 = lean_ctor_get(x_423, 1); +lean_inc(x_432); +x_433 = lean_ctor_get(x_423, 3); +lean_inc(x_433); +x_434 = lean_ctor_get(x_423, 4); +lean_inc(x_434); +if (lean_is_exclusive(x_423)) { + lean_ctor_release(x_423, 0); + lean_ctor_release(x_423, 1); + lean_ctor_release(x_423, 2); + lean_ctor_release(x_423, 3); + lean_ctor_release(x_423, 4); + x_435 = x_423; } else { - x_432 = x_431; + lean_dec_ref(x_423); + x_435 = lean_box(0); } -lean_ctor_set(x_432, 0, x_428); -lean_ctor_set(x_432, 1, x_429); -lean_ctor_set(x_432, 2, x_400); -lean_ctor_set(x_432, 3, x_430); -if (lean_is_scalar(x_427)) { - x_433 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_435)) { + x_436 = lean_alloc_ctor(0, 5, 0); } else { - x_433 = x_427; + x_436 = x_435; } -lean_ctor_set(x_433, 0, x_422); -lean_ctor_set(x_433, 1, x_423); -lean_ctor_set(x_433, 2, x_432); -lean_ctor_set(x_433, 3, x_424); -lean_ctor_set(x_433, 4, x_425); -lean_ctor_set(x_433, 5, x_426); -if (lean_is_scalar(x_251)) { - x_434 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_436, 0, x_431); +lean_ctor_set(x_436, 1, x_432); +lean_ctor_set(x_436, 2, x_417); +lean_ctor_set(x_436, 3, x_433); +lean_ctor_set(x_436, 4, x_434); +if (lean_is_scalar(x_430)) { + x_437 = lean_alloc_ctor(0, 6, 0); } else { - x_434 = x_251; + x_437 = x_430; } -lean_ctor_set(x_434, 0, x_421); -lean_ctor_set(x_434, 1, x_433); -return x_434; +lean_ctor_set(x_437, 0, x_425); +lean_ctor_set(x_437, 1, x_426); +lean_ctor_set(x_437, 2, x_436); +lean_ctor_set(x_437, 3, x_427); +lean_ctor_set(x_437, 4, x_428); +lean_ctor_set(x_437, 5, x_429); +if (lean_is_scalar(x_261)) { + x_438 = lean_alloc_ctor(1, 2, 0); +} else { + x_438 = x_261; + lean_ctor_set_tag(x_438, 1); +} +lean_ctor_set(x_438, 0, x_424); +lean_ctor_set(x_438, 1, x_437); +return x_438; +} +else +{ +lean_object* x_439; lean_object* x_440; lean_object* x_441; lean_object* x_442; lean_object* x_443; lean_object* x_444; lean_object* x_445; lean_object* x_446; lean_object* x_447; lean_object* x_448; lean_object* x_449; lean_object* x_450; lean_object* x_451; lean_object* x_452; lean_object* x_453; lean_object* x_454; +x_439 = lean_ctor_get(x_422, 2); +lean_inc(x_439); +x_440 = lean_ctor_get(x_421, 0); +lean_inc(x_440); +lean_dec(x_421); +x_441 = lean_ctor_get(x_422, 0); +lean_inc(x_441); +x_442 = lean_ctor_get(x_422, 1); +lean_inc(x_442); +x_443 = lean_ctor_get(x_422, 3); +lean_inc(x_443); +x_444 = lean_ctor_get(x_422, 4); +lean_inc(x_444); +x_445 = lean_ctor_get(x_422, 5); +lean_inc(x_445); +if (lean_is_exclusive(x_422)) { + lean_ctor_release(x_422, 0); + lean_ctor_release(x_422, 1); + lean_ctor_release(x_422, 2); + lean_ctor_release(x_422, 3); + lean_ctor_release(x_422, 4); + lean_ctor_release(x_422, 5); + x_446 = x_422; +} else { + lean_dec_ref(x_422); + x_446 = lean_box(0); +} +x_447 = lean_ctor_get(x_439, 0); +lean_inc(x_447); +x_448 = lean_ctor_get(x_439, 1); +lean_inc(x_448); +x_449 = lean_ctor_get(x_439, 3); +lean_inc(x_449); +x_450 = lean_ctor_get(x_439, 4); +lean_inc(x_450); +if (lean_is_exclusive(x_439)) { + lean_ctor_release(x_439, 0); + lean_ctor_release(x_439, 1); + lean_ctor_release(x_439, 2); + lean_ctor_release(x_439, 3); + lean_ctor_release(x_439, 4); + x_451 = x_439; +} else { + lean_dec_ref(x_439); + x_451 = lean_box(0); +} +if (lean_is_scalar(x_451)) { + x_452 = lean_alloc_ctor(0, 5, 0); +} else { + x_452 = x_451; +} +lean_ctor_set(x_452, 0, x_447); +lean_ctor_set(x_452, 1, x_448); +lean_ctor_set(x_452, 2, x_417); +lean_ctor_set(x_452, 3, x_449); +lean_ctor_set(x_452, 4, x_450); +if (lean_is_scalar(x_446)) { + x_453 = lean_alloc_ctor(0, 6, 0); +} else { + x_453 = x_446; +} +lean_ctor_set(x_453, 0, x_441); +lean_ctor_set(x_453, 1, x_442); +lean_ctor_set(x_453, 2, x_452); +lean_ctor_set(x_453, 3, x_443); +lean_ctor_set(x_453, 4, x_444); +lean_ctor_set(x_453, 5, x_445); +if (lean_is_scalar(x_261)) { + x_454 = lean_alloc_ctor(0, 2, 0); +} else { + x_454 = x_261; +} +lean_ctor_set(x_454, 0, x_440); +lean_ctor_set(x_454, 1, x_453); +return x_454; } } } @@ -4498,28 +4583,28 @@ return x_434; } else { -uint8_t x_455; +uint8_t x_475; lean_dec(x_27); lean_dec(x_6); lean_dec(x_5); lean_dec(x_2); -x_455 = !lean_is_exclusive(x_244); -if (x_455 == 0) +x_475 = !lean_is_exclusive(x_254); +if (x_475 == 0) { -return x_244; +return x_254; } else { -lean_object* x_456; lean_object* x_457; lean_object* x_458; -x_456 = lean_ctor_get(x_244, 0); -x_457 = lean_ctor_get(x_244, 1); -lean_inc(x_457); -lean_inc(x_456); -lean_dec(x_244); -x_458 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_458, 0, x_456); -lean_ctor_set(x_458, 1, x_457); -return x_458; +lean_object* x_476; lean_object* x_477; lean_object* x_478; +x_476 = lean_ctor_get(x_254, 0); +x_477 = lean_ctor_get(x_254, 1); +lean_inc(x_477); +lean_inc(x_476); +lean_dec(x_254); +x_478 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_478, 0, x_476); +lean_ctor_set(x_478, 1, x_477); +return x_478; } } } @@ -4527,56 +4612,56 @@ return x_458; } else { -uint8_t x_459; +uint8_t x_479; lean_dec(x_31); lean_dec(x_27); lean_dec(x_6); lean_dec(x_5); lean_dec(x_2); -x_459 = !lean_is_exclusive(x_32); -if (x_459 == 0) +x_479 = !lean_is_exclusive(x_32); +if (x_479 == 0) { return x_32; } else { -lean_object* x_460; lean_object* x_461; lean_object* x_462; -x_460 = lean_ctor_get(x_32, 0); -x_461 = lean_ctor_get(x_32, 1); -lean_inc(x_461); -lean_inc(x_460); +lean_object* x_480; lean_object* x_481; lean_object* x_482; +x_480 = lean_ctor_get(x_32, 0); +x_481 = lean_ctor_get(x_32, 1); +lean_inc(x_481); +lean_inc(x_480); lean_dec(x_32); -x_462 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_462, 0, x_460); -lean_ctor_set(x_462, 1, x_461); -return x_462; +x_482 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_482, 0, x_480); +lean_ctor_set(x_482, 1, x_481); +return x_482; } } } else { -uint8_t x_463; +uint8_t x_483; lean_dec(x_27); lean_dec(x_6); lean_dec(x_5); lean_dec(x_2); -x_463 = !lean_is_exclusive(x_28); -if (x_463 == 0) +x_483 = !lean_is_exclusive(x_28); +if (x_483 == 0) { return x_28; } else { -lean_object* x_464; lean_object* x_465; lean_object* x_466; -x_464 = lean_ctor_get(x_28, 0); -x_465 = lean_ctor_get(x_28, 1); -lean_inc(x_465); -lean_inc(x_464); +lean_object* x_484; lean_object* x_485; lean_object* x_486; +x_484 = lean_ctor_get(x_28, 0); +x_485 = lean_ctor_get(x_28, 1); +lean_inc(x_485); +lean_inc(x_484); lean_dec(x_28); -x_466 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_466, 0, x_464); -lean_ctor_set(x_466, 1, x_465); -return x_466; +x_486 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_486, 0, x_484); +lean_ctor_set(x_486, 1, x_485); +return x_486; } } } @@ -4771,105 +4856,105 @@ x_36 = lean_ctor_get(x_30, 2); x_37 = !lean_is_exclusive(x_36); if (x_37 == 0) { -lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_90; uint8_t x_91; +lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_94; uint8_t x_95; x_38 = lean_ctor_get(x_36, 2); -x_90 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_36, 2, x_90); -x_91 = !lean_is_exclusive(x_11); -if (x_91 == 0) +x_94 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_36, 2, x_94); +x_95 = !lean_is_exclusive(x_11); +if (x_95 == 0) { -lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; -x_92 = lean_ctor_get(x_11, 2); -x_93 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_93, 0, x_32); -lean_ctor_set(x_93, 1, x_19); -x_94 = lean_array_push(x_92, x_93); -lean_ctor_set(x_11, 2, x_94); -x_95 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_34, x_11, x_30); -if (lean_obj_tag(x_95) == 0) +lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; +x_96 = lean_ctor_get(x_11, 2); +x_97 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_97, 0, x_32); +lean_ctor_set(x_97, 1, x_19); +x_98 = lean_array_push(x_96, x_97); +lean_ctor_set(x_11, 2, x_98); +x_99 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_34, x_11, x_30); +if (lean_obj_tag(x_99) == 0) { -lean_object* x_96; lean_object* x_97; lean_object* x_98; -x_96 = lean_ctor_get(x_95, 0); -lean_inc(x_96); -x_97 = lean_ctor_get(x_95, 1); -lean_inc(x_97); -lean_dec(x_95); -x_98 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_98, 0, x_96); -x_39 = x_98; -x_40 = x_97; -goto block_89; -} -else -{ -lean_object* x_99; lean_object* x_100; lean_object* x_101; -x_99 = lean_ctor_get(x_95, 0); -lean_inc(x_99); -x_100 = lean_ctor_get(x_95, 1); +lean_object* x_100; lean_object* x_101; lean_object* x_102; +x_100 = lean_ctor_get(x_99, 0); lean_inc(x_100); -lean_dec(x_95); -x_101 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_101, 0, x_99); -x_39 = x_101; -x_40 = x_100; -goto block_89; -} +x_101 = lean_ctor_get(x_99, 1); +lean_inc(x_101); +lean_dec(x_99); +x_102 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_102, 0, x_100); +x_39 = x_102; +x_40 = x_101; +goto block_93; } else { -lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; -x_102 = lean_ctor_get(x_11, 0); -x_103 = lean_ctor_get(x_11, 1); -x_104 = lean_ctor_get(x_11, 2); -x_105 = lean_ctor_get(x_11, 3); -x_106 = lean_ctor_get(x_11, 4); -lean_inc(x_106); -lean_inc(x_105); -lean_inc(x_104); +lean_object* x_103; lean_object* x_104; lean_object* x_105; +x_103 = lean_ctor_get(x_99, 0); lean_inc(x_103); -lean_inc(x_102); -lean_dec(x_11); -x_107 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_107, 0, x_32); -lean_ctor_set(x_107, 1, x_19); -x_108 = lean_array_push(x_104, x_107); -x_109 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_109, 0, x_102); -lean_ctor_set(x_109, 1, x_103); -lean_ctor_set(x_109, 2, x_108); -lean_ctor_set(x_109, 3, x_105); -lean_ctor_set(x_109, 4, x_106); -x_110 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_34, x_109, x_30); -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); -x_113 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_113, 0, x_111); -x_39 = x_113; -x_40 = x_112; -goto block_89; +x_104 = lean_ctor_get(x_99, 1); +lean_inc(x_104); +lean_dec(x_99); +x_105 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_105, 0, x_103); +x_39 = x_105; +x_40 = x_104; +goto block_93; +} } else { -lean_object* x_114; lean_object* x_115; lean_object* x_116; -x_114 = lean_ctor_get(x_110, 0); -lean_inc(x_114); -x_115 = lean_ctor_get(x_110, 1); +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; +x_106 = lean_ctor_get(x_11, 0); +x_107 = lean_ctor_get(x_11, 1); +x_108 = lean_ctor_get(x_11, 2); +x_109 = lean_ctor_get(x_11, 3); +x_110 = lean_ctor_get(x_11, 4); +lean_inc(x_110); +lean_inc(x_109); +lean_inc(x_108); +lean_inc(x_107); +lean_inc(x_106); +lean_dec(x_11); +x_111 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_111, 0, x_32); +lean_ctor_set(x_111, 1, x_19); +x_112 = lean_array_push(x_108, x_111); +x_113 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_113, 0, x_106); +lean_ctor_set(x_113, 1, x_107); +lean_ctor_set(x_113, 2, x_112); +lean_ctor_set(x_113, 3, x_109); +lean_ctor_set(x_113, 4, x_110); +x_114 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_34, x_113, x_30); +if (lean_obj_tag(x_114) == 0) +{ +lean_object* x_115; lean_object* x_116; lean_object* x_117; +x_115 = lean_ctor_get(x_114, 0); lean_inc(x_115); -lean_dec(x_110); -x_116 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_116, 0, x_114); -x_39 = x_116; -x_40 = x_115; -goto block_89; +x_116 = lean_ctor_get(x_114, 1); +lean_inc(x_116); +lean_dec(x_114); +x_117 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_117, 0, x_115); +x_39 = x_117; +x_40 = x_116; +goto block_93; +} +else +{ +lean_object* x_118; lean_object* x_119; lean_object* x_120; +x_118 = lean_ctor_get(x_114, 0); +lean_inc(x_118); +x_119 = lean_ctor_get(x_114, 1); +lean_inc(x_119); +lean_dec(x_114); +x_120 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_120, 0, x_118); +x_39 = x_120; +x_40 = x_119; +goto block_93; } } -block_89: +block_93: { if (lean_obj_tag(x_39) == 0) { @@ -4904,1284 +4989,1262 @@ return x_47; } else { -lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; +lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; x_48 = lean_ctor_get(x_41, 0); x_49 = lean_ctor_get(x_41, 1); x_50 = lean_ctor_get(x_41, 3); +x_51 = lean_ctor_get(x_41, 4); +lean_inc(x_51); lean_inc(x_50); lean_inc(x_49); lean_inc(x_48); lean_dec(x_41); -x_51 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_51, 0, x_48); -lean_ctor_set(x_51, 1, x_49); -lean_ctor_set(x_51, 2, x_38); -lean_ctor_set(x_51, 3, x_50); -lean_ctor_set(x_40, 2, x_51); +x_52 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_52, 0, x_48); +lean_ctor_set(x_52, 1, x_49); +lean_ctor_set(x_52, 2, x_38); +lean_ctor_set(x_52, 3, x_50); +lean_ctor_set(x_52, 4, x_51); +lean_ctor_set(x_40, 2, x_52); if (lean_is_scalar(x_31)) { - x_52 = lean_alloc_ctor(1, 2, 0); + x_53 = lean_alloc_ctor(1, 2, 0); } else { - x_52 = x_31; - lean_ctor_set_tag(x_52, 1); + x_53 = x_31; + lean_ctor_set_tag(x_53, 1); } -lean_ctor_set(x_52, 0, x_42); -lean_ctor_set(x_52, 1, x_40); -return x_52; +lean_ctor_set(x_53, 0, x_42); +lean_ctor_set(x_53, 1, x_40); +return x_53; } } else { -lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; -x_53 = lean_ctor_get(x_40, 0); -x_54 = lean_ctor_get(x_40, 1); -x_55 = lean_ctor_get(x_40, 3); -x_56 = lean_ctor_get(x_40, 4); -x_57 = lean_ctor_get(x_40, 5); +lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; +x_54 = lean_ctor_get(x_40, 0); +x_55 = lean_ctor_get(x_40, 1); +x_56 = lean_ctor_get(x_40, 3); +x_57 = lean_ctor_get(x_40, 4); +x_58 = lean_ctor_get(x_40, 5); +lean_inc(x_58); lean_inc(x_57); lean_inc(x_56); lean_inc(x_55); lean_inc(x_54); -lean_inc(x_53); lean_dec(x_40); -x_58 = lean_ctor_get(x_41, 0); -lean_inc(x_58); -x_59 = lean_ctor_get(x_41, 1); +x_59 = lean_ctor_get(x_41, 0); lean_inc(x_59); -x_60 = lean_ctor_get(x_41, 3); +x_60 = lean_ctor_get(x_41, 1); lean_inc(x_60); +x_61 = lean_ctor_get(x_41, 3); +lean_inc(x_61); +x_62 = lean_ctor_get(x_41, 4); +lean_inc(x_62); if (lean_is_exclusive(x_41)) { lean_ctor_release(x_41, 0); lean_ctor_release(x_41, 1); lean_ctor_release(x_41, 2); lean_ctor_release(x_41, 3); - x_61 = x_41; + lean_ctor_release(x_41, 4); + x_63 = x_41; } else { lean_dec_ref(x_41); - x_61 = lean_box(0); + x_63 = lean_box(0); } -if (lean_is_scalar(x_61)) { - x_62 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_63)) { + x_64 = lean_alloc_ctor(0, 5, 0); } else { - x_62 = x_61; + x_64 = x_63; } -lean_ctor_set(x_62, 0, x_58); -lean_ctor_set(x_62, 1, x_59); -lean_ctor_set(x_62, 2, x_38); -lean_ctor_set(x_62, 3, x_60); -x_63 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_63, 0, x_53); -lean_ctor_set(x_63, 1, x_54); -lean_ctor_set(x_63, 2, x_62); -lean_ctor_set(x_63, 3, x_55); -lean_ctor_set(x_63, 4, x_56); -lean_ctor_set(x_63, 5, x_57); +lean_ctor_set(x_64, 0, x_59); +lean_ctor_set(x_64, 1, x_60); +lean_ctor_set(x_64, 2, x_38); +lean_ctor_set(x_64, 3, x_61); +lean_ctor_set(x_64, 4, x_62); +x_65 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_65, 0, x_54); +lean_ctor_set(x_65, 1, x_55); +lean_ctor_set(x_65, 2, x_64); +lean_ctor_set(x_65, 3, x_56); +lean_ctor_set(x_65, 4, x_57); +lean_ctor_set(x_65, 5, x_58); if (lean_is_scalar(x_31)) { - x_64 = lean_alloc_ctor(1, 2, 0); + x_66 = lean_alloc_ctor(1, 2, 0); } else { - x_64 = x_31; - lean_ctor_set_tag(x_64, 1); + x_66 = x_31; + lean_ctor_set_tag(x_66, 1); } -lean_ctor_set(x_64, 0, x_42); -lean_ctor_set(x_64, 1, x_63); -return x_64; +lean_ctor_set(x_66, 0, x_42); +lean_ctor_set(x_66, 1, x_65); +return x_66; } } else { -lean_object* x_65; lean_object* x_66; uint8_t x_67; -x_65 = lean_ctor_get(x_40, 2); -lean_inc(x_65); -x_66 = lean_ctor_get(x_39, 0); -lean_inc(x_66); +lean_object* x_67; lean_object* x_68; uint8_t x_69; +x_67 = lean_ctor_get(x_40, 2); +lean_inc(x_67); +x_68 = lean_ctor_get(x_39, 0); +lean_inc(x_68); lean_dec(x_39); -x_67 = !lean_is_exclusive(x_40); -if (x_67 == 0) -{ -lean_object* x_68; uint8_t x_69; -x_68 = lean_ctor_get(x_40, 2); -lean_dec(x_68); -x_69 = !lean_is_exclusive(x_65); +x_69 = !lean_is_exclusive(x_40); if (x_69 == 0) { -lean_object* x_70; lean_object* x_71; -x_70 = lean_ctor_get(x_65, 2); +lean_object* x_70; uint8_t x_71; +x_70 = lean_ctor_get(x_40, 2); lean_dec(x_70); -lean_ctor_set(x_65, 2, x_38); +x_71 = !lean_is_exclusive(x_67); +if (x_71 == 0) +{ +lean_object* x_72; lean_object* x_73; +x_72 = lean_ctor_get(x_67, 2); +lean_dec(x_72); +lean_ctor_set(x_67, 2, x_38); if (lean_is_scalar(x_31)) { - x_71 = lean_alloc_ctor(0, 2, 0); + x_73 = lean_alloc_ctor(0, 2, 0); } else { - x_71 = x_31; + x_73 = x_31; } -lean_ctor_set(x_71, 0, x_66); -lean_ctor_set(x_71, 1, x_40); -return x_71; +lean_ctor_set(x_73, 0, x_68); +lean_ctor_set(x_73, 1, x_40); +return x_73; } else { -lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; -x_72 = lean_ctor_get(x_65, 0); -x_73 = lean_ctor_get(x_65, 1); -x_74 = lean_ctor_get(x_65, 3); +lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; +x_74 = lean_ctor_get(x_67, 0); +x_75 = lean_ctor_get(x_67, 1); +x_76 = lean_ctor_get(x_67, 3); +x_77 = lean_ctor_get(x_67, 4); +lean_inc(x_77); +lean_inc(x_76); +lean_inc(x_75); lean_inc(x_74); -lean_inc(x_73); -lean_inc(x_72); -lean_dec(x_65); -x_75 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_75, 0, x_72); -lean_ctor_set(x_75, 1, x_73); -lean_ctor_set(x_75, 2, x_38); -lean_ctor_set(x_75, 3, x_74); -lean_ctor_set(x_40, 2, x_75); +lean_dec(x_67); +x_78 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_78, 0, x_74); +lean_ctor_set(x_78, 1, x_75); +lean_ctor_set(x_78, 2, x_38); +lean_ctor_set(x_78, 3, x_76); +lean_ctor_set(x_78, 4, x_77); +lean_ctor_set(x_40, 2, x_78); if (lean_is_scalar(x_31)) { - x_76 = lean_alloc_ctor(0, 2, 0); + x_79 = lean_alloc_ctor(0, 2, 0); } else { - x_76 = x_31; + x_79 = x_31; } -lean_ctor_set(x_76, 0, x_66); -lean_ctor_set(x_76, 1, x_40); -return x_76; +lean_ctor_set(x_79, 0, x_68); +lean_ctor_set(x_79, 1, x_40); +return x_79; } } else { -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; -x_77 = lean_ctor_get(x_40, 0); -x_78 = lean_ctor_get(x_40, 1); -x_79 = lean_ctor_get(x_40, 3); -x_80 = lean_ctor_get(x_40, 4); -x_81 = lean_ctor_get(x_40, 5); +lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; +x_80 = lean_ctor_get(x_40, 0); +x_81 = lean_ctor_get(x_40, 1); +x_82 = lean_ctor_get(x_40, 3); +x_83 = lean_ctor_get(x_40, 4); +x_84 = lean_ctor_get(x_40, 5); +lean_inc(x_84); +lean_inc(x_83); +lean_inc(x_82); lean_inc(x_81); lean_inc(x_80); -lean_inc(x_79); -lean_inc(x_78); -lean_inc(x_77); lean_dec(x_40); -x_82 = lean_ctor_get(x_65, 0); -lean_inc(x_82); -x_83 = lean_ctor_get(x_65, 1); -lean_inc(x_83); -x_84 = lean_ctor_get(x_65, 3); -lean_inc(x_84); -if (lean_is_exclusive(x_65)) { - lean_ctor_release(x_65, 0); - lean_ctor_release(x_65, 1); - lean_ctor_release(x_65, 2); - lean_ctor_release(x_65, 3); - x_85 = x_65; +x_85 = lean_ctor_get(x_67, 0); +lean_inc(x_85); +x_86 = lean_ctor_get(x_67, 1); +lean_inc(x_86); +x_87 = lean_ctor_get(x_67, 3); +lean_inc(x_87); +x_88 = lean_ctor_get(x_67, 4); +lean_inc(x_88); +if (lean_is_exclusive(x_67)) { + lean_ctor_release(x_67, 0); + lean_ctor_release(x_67, 1); + lean_ctor_release(x_67, 2); + lean_ctor_release(x_67, 3); + lean_ctor_release(x_67, 4); + x_89 = x_67; } else { - lean_dec_ref(x_65); - x_85 = lean_box(0); + lean_dec_ref(x_67); + x_89 = lean_box(0); } -if (lean_is_scalar(x_85)) { - x_86 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_89)) { + x_90 = lean_alloc_ctor(0, 5, 0); } else { - x_86 = x_85; + x_90 = x_89; } -lean_ctor_set(x_86, 0, x_82); -lean_ctor_set(x_86, 1, x_83); -lean_ctor_set(x_86, 2, x_38); -lean_ctor_set(x_86, 3, x_84); -x_87 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_87, 0, x_77); -lean_ctor_set(x_87, 1, x_78); -lean_ctor_set(x_87, 2, x_86); -lean_ctor_set(x_87, 3, x_79); -lean_ctor_set(x_87, 4, x_80); -lean_ctor_set(x_87, 5, x_81); +lean_ctor_set(x_90, 0, x_85); +lean_ctor_set(x_90, 1, x_86); +lean_ctor_set(x_90, 2, x_38); +lean_ctor_set(x_90, 3, x_87); +lean_ctor_set(x_90, 4, x_88); +x_91 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_91, 0, x_80); +lean_ctor_set(x_91, 1, x_81); +lean_ctor_set(x_91, 2, x_90); +lean_ctor_set(x_91, 3, x_82); +lean_ctor_set(x_91, 4, x_83); +lean_ctor_set(x_91, 5, x_84); if (lean_is_scalar(x_31)) { - x_88 = lean_alloc_ctor(0, 2, 0); + x_92 = lean_alloc_ctor(0, 2, 0); } else { - x_88 = x_31; + x_92 = x_31; } -lean_ctor_set(x_88, 0, x_66); -lean_ctor_set(x_88, 1, x_87); -return x_88; +lean_ctor_set(x_92, 0, x_68); +lean_ctor_set(x_92, 1, x_91); +return x_92; } } } } else { -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_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; -x_117 = lean_ctor_get(x_36, 0); -x_118 = lean_ctor_get(x_36, 1); -x_119 = lean_ctor_get(x_36, 2); -x_120 = lean_ctor_get(x_36, 3); -lean_inc(x_120); -lean_inc(x_119); -lean_inc(x_118); -lean_inc(x_117); -lean_dec(x_36); -x_154 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_155 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_155, 0, x_117); -lean_ctor_set(x_155, 1, x_118); -lean_ctor_set(x_155, 2, x_154); -lean_ctor_set(x_155, 3, x_120); -lean_ctor_set(x_30, 2, x_155); -x_156 = lean_ctor_get(x_11, 0); -lean_inc(x_156); -x_157 = lean_ctor_get(x_11, 1); -lean_inc(x_157); -x_158 = lean_ctor_get(x_11, 2); -lean_inc(x_158); -x_159 = lean_ctor_get(x_11, 3); -lean_inc(x_159); -x_160 = lean_ctor_get(x_11, 4); -lean_inc(x_160); -if (lean_is_exclusive(x_11)) { - lean_ctor_release(x_11, 0); - lean_ctor_release(x_11, 1); - lean_ctor_release(x_11, 2); - lean_ctor_release(x_11, 3); - lean_ctor_release(x_11, 4); - x_161 = x_11; -} else { - lean_dec_ref(x_11); - x_161 = lean_box(0); -} -x_162 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_162, 0, x_32); -lean_ctor_set(x_162, 1, x_19); -x_163 = lean_array_push(x_158, x_162); -if (lean_is_scalar(x_161)) { - x_164 = lean_alloc_ctor(0, 5, 0); -} else { - x_164 = x_161; -} -lean_ctor_set(x_164, 0, x_156); -lean_ctor_set(x_164, 1, x_157); -lean_ctor_set(x_164, 2, x_163); -lean_ctor_set(x_164, 3, x_159); -lean_ctor_set(x_164, 4, x_160); -x_165 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_34, x_164, x_30); -if (lean_obj_tag(x_165) == 0) -{ -lean_object* x_166; lean_object* x_167; lean_object* x_168; -x_166 = lean_ctor_get(x_165, 0); -lean_inc(x_166); -x_167 = lean_ctor_get(x_165, 1); -lean_inc(x_167); -lean_dec(x_165); -x_168 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_168, 0, x_166); -x_121 = x_168; -x_122 = x_167; -goto block_153; -} -else -{ -lean_object* x_169; lean_object* x_170; lean_object* x_171; -x_169 = lean_ctor_get(x_165, 0); -lean_inc(x_169); -x_170 = lean_ctor_get(x_165, 1); -lean_inc(x_170); -lean_dec(x_165); -x_171 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_171, 0, x_169); -x_121 = x_171; -x_122 = x_170; -goto block_153; -} -block_153: -{ -if (lean_obj_tag(x_121) == 0) -{ -lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; -x_123 = lean_ctor_get(x_122, 2); -lean_inc(x_123); -x_124 = lean_ctor_get(x_121, 0); -lean_inc(x_124); -lean_dec(x_121); -x_125 = lean_ctor_get(x_122, 0); +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_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; +x_121 = lean_ctor_get(x_36, 0); +x_122 = lean_ctor_get(x_36, 1); +x_123 = lean_ctor_get(x_36, 2); +x_124 = lean_ctor_get(x_36, 3); +x_125 = lean_ctor_get(x_36, 4); lean_inc(x_125); -x_126 = lean_ctor_get(x_122, 1); -lean_inc(x_126); -x_127 = lean_ctor_get(x_122, 3); -lean_inc(x_127); -x_128 = lean_ctor_get(x_122, 4); -lean_inc(x_128); -x_129 = lean_ctor_get(x_122, 5); -lean_inc(x_129); -if (lean_is_exclusive(x_122)) { - lean_ctor_release(x_122, 0); - lean_ctor_release(x_122, 1); - lean_ctor_release(x_122, 2); - lean_ctor_release(x_122, 3); - lean_ctor_release(x_122, 4); - lean_ctor_release(x_122, 5); - x_130 = x_122; -} else { - lean_dec_ref(x_122); - x_130 = lean_box(0); -} -x_131 = lean_ctor_get(x_123, 0); -lean_inc(x_131); -x_132 = lean_ctor_get(x_123, 1); -lean_inc(x_132); -x_133 = lean_ctor_get(x_123, 3); -lean_inc(x_133); -if (lean_is_exclusive(x_123)) { - lean_ctor_release(x_123, 0); - lean_ctor_release(x_123, 1); - lean_ctor_release(x_123, 2); - lean_ctor_release(x_123, 3); - x_134 = x_123; -} else { - lean_dec_ref(x_123); - x_134 = lean_box(0); -} -if (lean_is_scalar(x_134)) { - x_135 = lean_alloc_ctor(0, 4, 0); -} else { - x_135 = x_134; -} -lean_ctor_set(x_135, 0, x_131); -lean_ctor_set(x_135, 1, x_132); -lean_ctor_set(x_135, 2, x_119); -lean_ctor_set(x_135, 3, x_133); -if (lean_is_scalar(x_130)) { - x_136 = lean_alloc_ctor(0, 6, 0); -} else { - x_136 = x_130; -} -lean_ctor_set(x_136, 0, x_125); -lean_ctor_set(x_136, 1, x_126); -lean_ctor_set(x_136, 2, x_135); -lean_ctor_set(x_136, 3, x_127); -lean_ctor_set(x_136, 4, x_128); -lean_ctor_set(x_136, 5, x_129); -if (lean_is_scalar(x_31)) { - x_137 = lean_alloc_ctor(1, 2, 0); -} else { - x_137 = x_31; - lean_ctor_set_tag(x_137, 1); -} -lean_ctor_set(x_137, 0, x_124); -lean_ctor_set(x_137, 1, x_136); -return x_137; -} -else -{ -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; -x_138 = lean_ctor_get(x_122, 2); -lean_inc(x_138); -x_139 = lean_ctor_get(x_121, 0); -lean_inc(x_139); -lean_dec(x_121); -x_140 = lean_ctor_get(x_122, 0); -lean_inc(x_140); -x_141 = lean_ctor_get(x_122, 1); -lean_inc(x_141); -x_142 = lean_ctor_get(x_122, 3); -lean_inc(x_142); -x_143 = lean_ctor_get(x_122, 4); -lean_inc(x_143); -x_144 = lean_ctor_get(x_122, 5); -lean_inc(x_144); -if (lean_is_exclusive(x_122)) { - lean_ctor_release(x_122, 0); - lean_ctor_release(x_122, 1); - lean_ctor_release(x_122, 2); - lean_ctor_release(x_122, 3); - lean_ctor_release(x_122, 4); - lean_ctor_release(x_122, 5); - x_145 = x_122; -} else { - lean_dec_ref(x_122); - x_145 = lean_box(0); -} -x_146 = lean_ctor_get(x_138, 0); -lean_inc(x_146); -x_147 = lean_ctor_get(x_138, 1); -lean_inc(x_147); -x_148 = lean_ctor_get(x_138, 3); -lean_inc(x_148); -if (lean_is_exclusive(x_138)) { - lean_ctor_release(x_138, 0); - lean_ctor_release(x_138, 1); - lean_ctor_release(x_138, 2); - lean_ctor_release(x_138, 3); - x_149 = x_138; -} else { - lean_dec_ref(x_138); - x_149 = lean_box(0); -} -if (lean_is_scalar(x_149)) { - x_150 = lean_alloc_ctor(0, 4, 0); -} else { - x_150 = x_149; -} -lean_ctor_set(x_150, 0, x_146); -lean_ctor_set(x_150, 1, x_147); -lean_ctor_set(x_150, 2, x_119); -lean_ctor_set(x_150, 3, x_148); -if (lean_is_scalar(x_145)) { - x_151 = lean_alloc_ctor(0, 6, 0); -} else { - x_151 = x_145; -} -lean_ctor_set(x_151, 0, x_140); -lean_ctor_set(x_151, 1, x_141); -lean_ctor_set(x_151, 2, x_150); -lean_ctor_set(x_151, 3, x_142); -lean_ctor_set(x_151, 4, x_143); -lean_ctor_set(x_151, 5, x_144); -if (lean_is_scalar(x_31)) { - x_152 = lean_alloc_ctor(0, 2, 0); -} else { - x_152 = x_31; -} -lean_ctor_set(x_152, 0, x_139); -lean_ctor_set(x_152, 1, x_151); -return x_152; -} -} -} -} -else -{ -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; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; lean_object* x_224; lean_object* x_225; lean_object* x_226; lean_object* x_227; lean_object* x_228; -x_172 = lean_ctor_get(x_30, 2); -x_173 = lean_ctor_get(x_30, 0); -x_174 = lean_ctor_get(x_30, 1); -x_175 = lean_ctor_get(x_30, 3); -x_176 = lean_ctor_get(x_30, 4); -x_177 = lean_ctor_get(x_30, 5); -lean_inc(x_177); -lean_inc(x_176); -lean_inc(x_175); -lean_inc(x_172); -lean_inc(x_174); -lean_inc(x_173); -lean_dec(x_30); -x_178 = lean_ctor_get(x_172, 0); -lean_inc(x_178); -x_179 = lean_ctor_get(x_172, 1); -lean_inc(x_179); -x_180 = lean_ctor_get(x_172, 2); -lean_inc(x_180); -x_181 = lean_ctor_get(x_172, 3); -lean_inc(x_181); -if (lean_is_exclusive(x_172)) { - lean_ctor_release(x_172, 0); - lean_ctor_release(x_172, 1); - lean_ctor_release(x_172, 2); - lean_ctor_release(x_172, 3); - x_182 = x_172; -} else { - lean_dec_ref(x_172); - x_182 = lean_box(0); -} -x_216 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_182)) { - x_217 = lean_alloc_ctor(0, 4, 0); -} else { - x_217 = x_182; -} -lean_ctor_set(x_217, 0, x_178); -lean_ctor_set(x_217, 1, x_179); -lean_ctor_set(x_217, 2, x_216); -lean_ctor_set(x_217, 3, x_181); -x_218 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_218, 0, x_173); -lean_ctor_set(x_218, 1, x_174); -lean_ctor_set(x_218, 2, x_217); -lean_ctor_set(x_218, 3, x_175); -lean_ctor_set(x_218, 4, x_176); -lean_ctor_set(x_218, 5, x_177); -x_219 = lean_ctor_get(x_11, 0); -lean_inc(x_219); -x_220 = lean_ctor_get(x_11, 1); -lean_inc(x_220); -x_221 = lean_ctor_get(x_11, 2); -lean_inc(x_221); -x_222 = lean_ctor_get(x_11, 3); -lean_inc(x_222); -x_223 = lean_ctor_get(x_11, 4); -lean_inc(x_223); +lean_inc(x_124); +lean_inc(x_123); +lean_inc(x_122); +lean_inc(x_121); +lean_dec(x_36); +x_161 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_162 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_162, 0, x_121); +lean_ctor_set(x_162, 1, x_122); +lean_ctor_set(x_162, 2, x_161); +lean_ctor_set(x_162, 3, x_124); +lean_ctor_set(x_162, 4, x_125); +lean_ctor_set(x_30, 2, x_162); +x_163 = lean_ctor_get(x_11, 0); +lean_inc(x_163); +x_164 = lean_ctor_get(x_11, 1); +lean_inc(x_164); +x_165 = lean_ctor_get(x_11, 2); +lean_inc(x_165); +x_166 = lean_ctor_get(x_11, 3); +lean_inc(x_166); +x_167 = lean_ctor_get(x_11, 4); +lean_inc(x_167); if (lean_is_exclusive(x_11)) { lean_ctor_release(x_11, 0); lean_ctor_release(x_11, 1); lean_ctor_release(x_11, 2); lean_ctor_release(x_11, 3); lean_ctor_release(x_11, 4); - x_224 = x_11; + x_168 = x_11; } else { lean_dec_ref(x_11); - x_224 = lean_box(0); + x_168 = lean_box(0); } -x_225 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_225, 0, x_32); -lean_ctor_set(x_225, 1, x_19); -x_226 = lean_array_push(x_221, x_225); -if (lean_is_scalar(x_224)) { +x_169 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_169, 0, x_32); +lean_ctor_set(x_169, 1, x_19); +x_170 = lean_array_push(x_165, x_169); +if (lean_is_scalar(x_168)) { + x_171 = lean_alloc_ctor(0, 5, 0); +} else { + x_171 = x_168; +} +lean_ctor_set(x_171, 0, x_163); +lean_ctor_set(x_171, 1, x_164); +lean_ctor_set(x_171, 2, x_170); +lean_ctor_set(x_171, 3, x_166); +lean_ctor_set(x_171, 4, x_167); +x_172 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_34, x_171, x_30); +if (lean_obj_tag(x_172) == 0) +{ +lean_object* x_173; lean_object* x_174; lean_object* x_175; +x_173 = lean_ctor_get(x_172, 0); +lean_inc(x_173); +x_174 = lean_ctor_get(x_172, 1); +lean_inc(x_174); +lean_dec(x_172); +x_175 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_175, 0, x_173); +x_126 = x_175; +x_127 = x_174; +goto block_160; +} +else +{ +lean_object* x_176; lean_object* x_177; lean_object* x_178; +x_176 = lean_ctor_get(x_172, 0); +lean_inc(x_176); +x_177 = lean_ctor_get(x_172, 1); +lean_inc(x_177); +lean_dec(x_172); +x_178 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_178, 0, x_176); +x_126 = x_178; +x_127 = x_177; +goto block_160; +} +block_160: +{ +if (lean_obj_tag(x_126) == 0) +{ +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; +x_128 = lean_ctor_get(x_127, 2); +lean_inc(x_128); +x_129 = lean_ctor_get(x_126, 0); +lean_inc(x_129); +lean_dec(x_126); +x_130 = lean_ctor_get(x_127, 0); +lean_inc(x_130); +x_131 = lean_ctor_get(x_127, 1); +lean_inc(x_131); +x_132 = lean_ctor_get(x_127, 3); +lean_inc(x_132); +x_133 = lean_ctor_get(x_127, 4); +lean_inc(x_133); +x_134 = lean_ctor_get(x_127, 5); +lean_inc(x_134); +if (lean_is_exclusive(x_127)) { + lean_ctor_release(x_127, 0); + lean_ctor_release(x_127, 1); + lean_ctor_release(x_127, 2); + lean_ctor_release(x_127, 3); + lean_ctor_release(x_127, 4); + lean_ctor_release(x_127, 5); + x_135 = x_127; +} else { + lean_dec_ref(x_127); + x_135 = lean_box(0); +} +x_136 = lean_ctor_get(x_128, 0); +lean_inc(x_136); +x_137 = lean_ctor_get(x_128, 1); +lean_inc(x_137); +x_138 = lean_ctor_get(x_128, 3); +lean_inc(x_138); +x_139 = lean_ctor_get(x_128, 4); +lean_inc(x_139); +if (lean_is_exclusive(x_128)) { + lean_ctor_release(x_128, 0); + lean_ctor_release(x_128, 1); + lean_ctor_release(x_128, 2); + lean_ctor_release(x_128, 3); + lean_ctor_release(x_128, 4); + x_140 = x_128; +} else { + lean_dec_ref(x_128); + x_140 = lean_box(0); +} +if (lean_is_scalar(x_140)) { + x_141 = lean_alloc_ctor(0, 5, 0); +} else { + x_141 = x_140; +} +lean_ctor_set(x_141, 0, x_136); +lean_ctor_set(x_141, 1, x_137); +lean_ctor_set(x_141, 2, x_123); +lean_ctor_set(x_141, 3, x_138); +lean_ctor_set(x_141, 4, x_139); +if (lean_is_scalar(x_135)) { + x_142 = lean_alloc_ctor(0, 6, 0); +} else { + x_142 = x_135; +} +lean_ctor_set(x_142, 0, x_130); +lean_ctor_set(x_142, 1, x_131); +lean_ctor_set(x_142, 2, x_141); +lean_ctor_set(x_142, 3, x_132); +lean_ctor_set(x_142, 4, x_133); +lean_ctor_set(x_142, 5, x_134); +if (lean_is_scalar(x_31)) { + x_143 = lean_alloc_ctor(1, 2, 0); +} else { + x_143 = x_31; + lean_ctor_set_tag(x_143, 1); +} +lean_ctor_set(x_143, 0, x_129); +lean_ctor_set(x_143, 1, x_142); +return x_143; +} +else +{ +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; +x_144 = lean_ctor_get(x_127, 2); +lean_inc(x_144); +x_145 = lean_ctor_get(x_126, 0); +lean_inc(x_145); +lean_dec(x_126); +x_146 = lean_ctor_get(x_127, 0); +lean_inc(x_146); +x_147 = lean_ctor_get(x_127, 1); +lean_inc(x_147); +x_148 = lean_ctor_get(x_127, 3); +lean_inc(x_148); +x_149 = lean_ctor_get(x_127, 4); +lean_inc(x_149); +x_150 = lean_ctor_get(x_127, 5); +lean_inc(x_150); +if (lean_is_exclusive(x_127)) { + lean_ctor_release(x_127, 0); + lean_ctor_release(x_127, 1); + lean_ctor_release(x_127, 2); + lean_ctor_release(x_127, 3); + lean_ctor_release(x_127, 4); + lean_ctor_release(x_127, 5); + x_151 = x_127; +} else { + lean_dec_ref(x_127); + x_151 = lean_box(0); +} +x_152 = lean_ctor_get(x_144, 0); +lean_inc(x_152); +x_153 = lean_ctor_get(x_144, 1); +lean_inc(x_153); +x_154 = lean_ctor_get(x_144, 3); +lean_inc(x_154); +x_155 = lean_ctor_get(x_144, 4); +lean_inc(x_155); +if (lean_is_exclusive(x_144)) { + lean_ctor_release(x_144, 0); + lean_ctor_release(x_144, 1); + lean_ctor_release(x_144, 2); + lean_ctor_release(x_144, 3); + lean_ctor_release(x_144, 4); + x_156 = x_144; +} else { + lean_dec_ref(x_144); + x_156 = lean_box(0); +} +if (lean_is_scalar(x_156)) { + x_157 = lean_alloc_ctor(0, 5, 0); +} else { + x_157 = x_156; +} +lean_ctor_set(x_157, 0, x_152); +lean_ctor_set(x_157, 1, x_153); +lean_ctor_set(x_157, 2, x_123); +lean_ctor_set(x_157, 3, x_154); +lean_ctor_set(x_157, 4, x_155); +if (lean_is_scalar(x_151)) { + x_158 = lean_alloc_ctor(0, 6, 0); +} else { + x_158 = x_151; +} +lean_ctor_set(x_158, 0, x_146); +lean_ctor_set(x_158, 1, x_147); +lean_ctor_set(x_158, 2, x_157); +lean_ctor_set(x_158, 3, x_148); +lean_ctor_set(x_158, 4, x_149); +lean_ctor_set(x_158, 5, x_150); +if (lean_is_scalar(x_31)) { + x_159 = lean_alloc_ctor(0, 2, 0); +} else { + x_159 = x_31; +} +lean_ctor_set(x_159, 0, x_145); +lean_ctor_set(x_159, 1, x_158); +return x_159; +} +} +} +} +else +{ +lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_226; lean_object* x_227; lean_object* x_228; lean_object* x_229; lean_object* x_230; lean_object* x_231; lean_object* x_232; lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_object* x_236; lean_object* x_237; lean_object* x_238; +x_179 = lean_ctor_get(x_30, 2); +x_180 = lean_ctor_get(x_30, 0); +x_181 = lean_ctor_get(x_30, 1); +x_182 = lean_ctor_get(x_30, 3); +x_183 = lean_ctor_get(x_30, 4); +x_184 = lean_ctor_get(x_30, 5); +lean_inc(x_184); +lean_inc(x_183); +lean_inc(x_182); +lean_inc(x_179); +lean_inc(x_181); +lean_inc(x_180); +lean_dec(x_30); +x_185 = lean_ctor_get(x_179, 0); +lean_inc(x_185); +x_186 = lean_ctor_get(x_179, 1); +lean_inc(x_186); +x_187 = lean_ctor_get(x_179, 2); +lean_inc(x_187); +x_188 = lean_ctor_get(x_179, 3); +lean_inc(x_188); +x_189 = lean_ctor_get(x_179, 4); +lean_inc(x_189); +if (lean_is_exclusive(x_179)) { + lean_ctor_release(x_179, 0); + lean_ctor_release(x_179, 1); + lean_ctor_release(x_179, 2); + lean_ctor_release(x_179, 3); + lean_ctor_release(x_179, 4); + x_190 = x_179; +} else { + lean_dec_ref(x_179); + x_190 = lean_box(0); +} +x_226 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_190)) { x_227 = lean_alloc_ctor(0, 5, 0); } else { - x_227 = x_224; + x_227 = x_190; } -lean_ctor_set(x_227, 0, x_219); -lean_ctor_set(x_227, 1, x_220); +lean_ctor_set(x_227, 0, x_185); +lean_ctor_set(x_227, 1, x_186); lean_ctor_set(x_227, 2, x_226); -lean_ctor_set(x_227, 3, x_222); -lean_ctor_set(x_227, 4, x_223); -x_228 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_34, x_227, x_218); -if (lean_obj_tag(x_228) == 0) -{ -lean_object* x_229; lean_object* x_230; lean_object* x_231; -x_229 = lean_ctor_get(x_228, 0); +lean_ctor_set(x_227, 3, x_188); +lean_ctor_set(x_227, 4, x_189); +x_228 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_228, 0, x_180); +lean_ctor_set(x_228, 1, x_181); +lean_ctor_set(x_228, 2, x_227); +lean_ctor_set(x_228, 3, x_182); +lean_ctor_set(x_228, 4, x_183); +lean_ctor_set(x_228, 5, x_184); +x_229 = lean_ctor_get(x_11, 0); lean_inc(x_229); -x_230 = lean_ctor_get(x_228, 1); +x_230 = lean_ctor_get(x_11, 1); lean_inc(x_230); -lean_dec(x_228); -x_231 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_231, 0, x_229); -x_183 = x_231; -x_184 = x_230; -goto block_215; -} -else -{ -lean_object* x_232; lean_object* x_233; lean_object* x_234; -x_232 = lean_ctor_get(x_228, 0); +x_231 = lean_ctor_get(x_11, 2); +lean_inc(x_231); +x_232 = lean_ctor_get(x_11, 3); lean_inc(x_232); -x_233 = lean_ctor_get(x_228, 1); +x_233 = lean_ctor_get(x_11, 4); lean_inc(x_233); -lean_dec(x_228); -x_234 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_234, 0, x_232); -x_183 = x_234; -x_184 = x_233; -goto block_215; +if (lean_is_exclusive(x_11)) { + lean_ctor_release(x_11, 0); + lean_ctor_release(x_11, 1); + lean_ctor_release(x_11, 2); + lean_ctor_release(x_11, 3); + lean_ctor_release(x_11, 4); + x_234 = x_11; +} else { + lean_dec_ref(x_11); + x_234 = lean_box(0); } -block_215: +x_235 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_235, 0, x_32); +lean_ctor_set(x_235, 1, x_19); +x_236 = lean_array_push(x_231, x_235); +if (lean_is_scalar(x_234)) { + x_237 = lean_alloc_ctor(0, 5, 0); +} else { + x_237 = x_234; +} +lean_ctor_set(x_237, 0, x_229); +lean_ctor_set(x_237, 1, x_230); +lean_ctor_set(x_237, 2, x_236); +lean_ctor_set(x_237, 3, x_232); +lean_ctor_set(x_237, 4, x_233); +x_238 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_34, x_237, x_228); +if (lean_obj_tag(x_238) == 0) { -if (lean_obj_tag(x_183) == 0) -{ -lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; -x_185 = lean_ctor_get(x_184, 2); -lean_inc(x_185); -x_186 = lean_ctor_get(x_183, 0); -lean_inc(x_186); -lean_dec(x_183); -x_187 = lean_ctor_get(x_184, 0); -lean_inc(x_187); -x_188 = lean_ctor_get(x_184, 1); -lean_inc(x_188); -x_189 = lean_ctor_get(x_184, 3); -lean_inc(x_189); -x_190 = lean_ctor_get(x_184, 4); -lean_inc(x_190); -x_191 = lean_ctor_get(x_184, 5); -lean_inc(x_191); -if (lean_is_exclusive(x_184)) { - lean_ctor_release(x_184, 0); - lean_ctor_release(x_184, 1); - lean_ctor_release(x_184, 2); - lean_ctor_release(x_184, 3); - lean_ctor_release(x_184, 4); - lean_ctor_release(x_184, 5); - x_192 = x_184; -} else { - lean_dec_ref(x_184); - x_192 = lean_box(0); -} -x_193 = lean_ctor_get(x_185, 0); -lean_inc(x_193); -x_194 = lean_ctor_get(x_185, 1); -lean_inc(x_194); -x_195 = lean_ctor_get(x_185, 3); -lean_inc(x_195); -if (lean_is_exclusive(x_185)) { - lean_ctor_release(x_185, 0); - lean_ctor_release(x_185, 1); - lean_ctor_release(x_185, 2); - lean_ctor_release(x_185, 3); - x_196 = x_185; -} else { - lean_dec_ref(x_185); - x_196 = lean_box(0); -} -if (lean_is_scalar(x_196)) { - x_197 = lean_alloc_ctor(0, 4, 0); -} else { - x_197 = x_196; -} -lean_ctor_set(x_197, 0, x_193); -lean_ctor_set(x_197, 1, x_194); -lean_ctor_set(x_197, 2, x_180); -lean_ctor_set(x_197, 3, x_195); -if (lean_is_scalar(x_192)) { - x_198 = lean_alloc_ctor(0, 6, 0); -} else { - x_198 = x_192; -} -lean_ctor_set(x_198, 0, x_187); -lean_ctor_set(x_198, 1, x_188); -lean_ctor_set(x_198, 2, x_197); -lean_ctor_set(x_198, 3, x_189); -lean_ctor_set(x_198, 4, x_190); -lean_ctor_set(x_198, 5, x_191); -if (lean_is_scalar(x_31)) { - x_199 = lean_alloc_ctor(1, 2, 0); -} else { - x_199 = x_31; - lean_ctor_set_tag(x_199, 1); -} -lean_ctor_set(x_199, 0, x_186); -lean_ctor_set(x_199, 1, x_198); -return x_199; +lean_object* x_239; lean_object* x_240; lean_object* x_241; +x_239 = lean_ctor_get(x_238, 0); +lean_inc(x_239); +x_240 = lean_ctor_get(x_238, 1); +lean_inc(x_240); +lean_dec(x_238); +x_241 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_241, 0, x_239); +x_191 = x_241; +x_192 = x_240; +goto block_225; } else { -lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; -x_200 = lean_ctor_get(x_184, 2); -lean_inc(x_200); -x_201 = lean_ctor_get(x_183, 0); +lean_object* x_242; lean_object* x_243; lean_object* x_244; +x_242 = lean_ctor_get(x_238, 0); +lean_inc(x_242); +x_243 = lean_ctor_get(x_238, 1); +lean_inc(x_243); +lean_dec(x_238); +x_244 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_244, 0, x_242); +x_191 = x_244; +x_192 = x_243; +goto block_225; +} +block_225: +{ +if (lean_obj_tag(x_191) == 0) +{ +lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; +x_193 = lean_ctor_get(x_192, 2); +lean_inc(x_193); +x_194 = lean_ctor_get(x_191, 0); +lean_inc(x_194); +lean_dec(x_191); +x_195 = lean_ctor_get(x_192, 0); +lean_inc(x_195); +x_196 = lean_ctor_get(x_192, 1); +lean_inc(x_196); +x_197 = lean_ctor_get(x_192, 3); +lean_inc(x_197); +x_198 = lean_ctor_get(x_192, 4); +lean_inc(x_198); +x_199 = lean_ctor_get(x_192, 5); +lean_inc(x_199); +if (lean_is_exclusive(x_192)) { + lean_ctor_release(x_192, 0); + lean_ctor_release(x_192, 1); + lean_ctor_release(x_192, 2); + lean_ctor_release(x_192, 3); + lean_ctor_release(x_192, 4); + lean_ctor_release(x_192, 5); + x_200 = x_192; +} else { + lean_dec_ref(x_192); + x_200 = lean_box(0); +} +x_201 = lean_ctor_get(x_193, 0); lean_inc(x_201); -lean_dec(x_183); -x_202 = lean_ctor_get(x_184, 0); +x_202 = lean_ctor_get(x_193, 1); lean_inc(x_202); -x_203 = lean_ctor_get(x_184, 1); +x_203 = lean_ctor_get(x_193, 3); lean_inc(x_203); -x_204 = lean_ctor_get(x_184, 3); +x_204 = lean_ctor_get(x_193, 4); lean_inc(x_204); -x_205 = lean_ctor_get(x_184, 4); -lean_inc(x_205); -x_206 = lean_ctor_get(x_184, 5); -lean_inc(x_206); -if (lean_is_exclusive(x_184)) { - lean_ctor_release(x_184, 0); - lean_ctor_release(x_184, 1); - lean_ctor_release(x_184, 2); - lean_ctor_release(x_184, 3); - lean_ctor_release(x_184, 4); - lean_ctor_release(x_184, 5); - x_207 = x_184; +if (lean_is_exclusive(x_193)) { + lean_ctor_release(x_193, 0); + lean_ctor_release(x_193, 1); + lean_ctor_release(x_193, 2); + lean_ctor_release(x_193, 3); + lean_ctor_release(x_193, 4); + x_205 = x_193; } else { - lean_dec_ref(x_184); - x_207 = lean_box(0); + lean_dec_ref(x_193); + x_205 = lean_box(0); } -x_208 = lean_ctor_get(x_200, 0); -lean_inc(x_208); -x_209 = lean_ctor_get(x_200, 1); -lean_inc(x_209); -x_210 = lean_ctor_get(x_200, 3); -lean_inc(x_210); -if (lean_is_exclusive(x_200)) { - lean_ctor_release(x_200, 0); - lean_ctor_release(x_200, 1); - lean_ctor_release(x_200, 2); - lean_ctor_release(x_200, 3); - x_211 = x_200; +if (lean_is_scalar(x_205)) { + x_206 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_200); - x_211 = lean_box(0); + x_206 = x_205; } -if (lean_is_scalar(x_211)) { - x_212 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_206, 0, x_201); +lean_ctor_set(x_206, 1, x_202); +lean_ctor_set(x_206, 2, x_187); +lean_ctor_set(x_206, 3, x_203); +lean_ctor_set(x_206, 4, x_204); +if (lean_is_scalar(x_200)) { + x_207 = lean_alloc_ctor(0, 6, 0); } else { - x_212 = x_211; + x_207 = x_200; } -lean_ctor_set(x_212, 0, x_208); -lean_ctor_set(x_212, 1, x_209); -lean_ctor_set(x_212, 2, x_180); -lean_ctor_set(x_212, 3, x_210); -if (lean_is_scalar(x_207)) { - x_213 = lean_alloc_ctor(0, 6, 0); -} else { - x_213 = x_207; -} -lean_ctor_set(x_213, 0, x_202); -lean_ctor_set(x_213, 1, x_203); -lean_ctor_set(x_213, 2, x_212); -lean_ctor_set(x_213, 3, x_204); -lean_ctor_set(x_213, 4, x_205); -lean_ctor_set(x_213, 5, x_206); +lean_ctor_set(x_207, 0, x_195); +lean_ctor_set(x_207, 1, x_196); +lean_ctor_set(x_207, 2, x_206); +lean_ctor_set(x_207, 3, x_197); +lean_ctor_set(x_207, 4, x_198); +lean_ctor_set(x_207, 5, x_199); if (lean_is_scalar(x_31)) { - x_214 = lean_alloc_ctor(0, 2, 0); + x_208 = lean_alloc_ctor(1, 2, 0); } else { - x_214 = x_31; + x_208 = x_31; + lean_ctor_set_tag(x_208, 1); } -lean_ctor_set(x_214, 0, x_201); -lean_ctor_set(x_214, 1, x_213); -return x_214; +lean_ctor_set(x_208, 0, x_194); +lean_ctor_set(x_208, 1, x_207); +return x_208; +} +else +{ +lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; lean_object* x_224; +x_209 = lean_ctor_get(x_192, 2); +lean_inc(x_209); +x_210 = lean_ctor_get(x_191, 0); +lean_inc(x_210); +lean_dec(x_191); +x_211 = lean_ctor_get(x_192, 0); +lean_inc(x_211); +x_212 = lean_ctor_get(x_192, 1); +lean_inc(x_212); +x_213 = lean_ctor_get(x_192, 3); +lean_inc(x_213); +x_214 = lean_ctor_get(x_192, 4); +lean_inc(x_214); +x_215 = lean_ctor_get(x_192, 5); +lean_inc(x_215); +if (lean_is_exclusive(x_192)) { + lean_ctor_release(x_192, 0); + lean_ctor_release(x_192, 1); + lean_ctor_release(x_192, 2); + lean_ctor_release(x_192, 3); + lean_ctor_release(x_192, 4); + lean_ctor_release(x_192, 5); + x_216 = x_192; +} else { + lean_dec_ref(x_192); + x_216 = lean_box(0); +} +x_217 = lean_ctor_get(x_209, 0); +lean_inc(x_217); +x_218 = lean_ctor_get(x_209, 1); +lean_inc(x_218); +x_219 = lean_ctor_get(x_209, 3); +lean_inc(x_219); +x_220 = lean_ctor_get(x_209, 4); +lean_inc(x_220); +if (lean_is_exclusive(x_209)) { + lean_ctor_release(x_209, 0); + lean_ctor_release(x_209, 1); + lean_ctor_release(x_209, 2); + lean_ctor_release(x_209, 3); + lean_ctor_release(x_209, 4); + x_221 = x_209; +} else { + lean_dec_ref(x_209); + x_221 = lean_box(0); +} +if (lean_is_scalar(x_221)) { + x_222 = lean_alloc_ctor(0, 5, 0); +} else { + x_222 = x_221; +} +lean_ctor_set(x_222, 0, x_217); +lean_ctor_set(x_222, 1, x_218); +lean_ctor_set(x_222, 2, x_187); +lean_ctor_set(x_222, 3, x_219); +lean_ctor_set(x_222, 4, x_220); +if (lean_is_scalar(x_216)) { + x_223 = lean_alloc_ctor(0, 6, 0); +} else { + x_223 = x_216; +} +lean_ctor_set(x_223, 0, x_211); +lean_ctor_set(x_223, 1, x_212); +lean_ctor_set(x_223, 2, x_222); +lean_ctor_set(x_223, 3, x_213); +lean_ctor_set(x_223, 4, x_214); +lean_ctor_set(x_223, 5, x_215); +if (lean_is_scalar(x_31)) { + x_224 = lean_alloc_ctor(0, 2, 0); +} else { + x_224 = x_31; +} +lean_ctor_set(x_224, 0, x_210); +lean_ctor_set(x_224, 1, x_223); +return x_224; } } } } default: { -lean_object* x_235; lean_object* x_236; -x_235 = lean_ctor_get(x_24, 1); -lean_inc(x_235); +lean_object* x_245; lean_object* x_246; +x_245 = lean_ctor_get(x_24, 1); +lean_inc(x_245); lean_dec(x_24); lean_inc(x_11); -x_236 = l_Lean_Meta_isClassExpensive___main(x_23, x_11, x_235); -if (lean_obj_tag(x_236) == 0) +x_246 = l_Lean_Meta_isClassExpensive___main(x_23, x_11, x_245); +if (lean_obj_tag(x_246) == 0) { -lean_object* x_237; -x_237 = lean_ctor_get(x_236, 0); -lean_inc(x_237); -if (lean_obj_tag(x_237) == 0) +lean_object* x_247; +x_247 = lean_ctor_get(x_246, 0); +lean_inc(x_247); +if (lean_obj_tag(x_247) == 0) { -lean_object* x_238; lean_object* x_239; lean_object* x_240; +lean_object* x_248; lean_object* x_249; lean_object* x_250; lean_dec(x_19); -x_238 = lean_ctor_get(x_236, 1); -lean_inc(x_238); -lean_dec(x_236); -x_239 = lean_unsigned_to_nat(1u); -x_240 = lean_nat_add(x_10, x_239); +x_248 = lean_ctor_get(x_246, 1); +lean_inc(x_248); +lean_dec(x_246); +x_249 = lean_unsigned_to_nat(1u); +x_250 = lean_nat_add(x_10, x_249); lean_dec(x_10); -x_10 = x_240; -x_12 = x_238; +x_10 = x_250; +x_12 = x_248; goto _start; } else { -lean_object* x_242; lean_object* x_243; lean_object* x_244; lean_object* x_245; lean_object* x_246; uint8_t x_247; -x_242 = lean_ctor_get(x_236, 1); -lean_inc(x_242); -if (lean_is_exclusive(x_236)) { - lean_ctor_release(x_236, 0); - lean_ctor_release(x_236, 1); - x_243 = x_236; +lean_object* x_252; lean_object* x_253; lean_object* x_254; lean_object* x_255; lean_object* x_256; uint8_t x_257; +x_252 = lean_ctor_get(x_246, 1); +lean_inc(x_252); +if (lean_is_exclusive(x_246)) { + lean_ctor_release(x_246, 0); + lean_ctor_release(x_246, 1); + x_253 = x_246; } else { - lean_dec_ref(x_236); - x_243 = lean_box(0); + lean_dec_ref(x_246); + x_253 = lean_box(0); } -x_244 = lean_ctor_get(x_237, 0); -lean_inc(x_244); -lean_dec(x_237); -x_245 = lean_unsigned_to_nat(1u); -x_246 = lean_nat_add(x_10, x_245); -lean_dec(x_10); -x_247 = !lean_is_exclusive(x_242); -if (x_247 == 0) -{ -lean_object* x_248; uint8_t x_249; -x_248 = lean_ctor_get(x_242, 2); -x_249 = !lean_is_exclusive(x_248); -if (x_249 == 0) -{ -lean_object* x_250; lean_object* x_251; lean_object* x_252; lean_object* x_302; uint8_t x_303; -x_250 = lean_ctor_get(x_248, 2); -x_302 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_248, 2, x_302); -x_303 = !lean_is_exclusive(x_11); -if (x_303 == 0) -{ -lean_object* x_304; lean_object* x_305; lean_object* x_306; lean_object* x_307; -x_304 = lean_ctor_get(x_11, 2); -x_305 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_305, 0, x_244); -lean_ctor_set(x_305, 1, x_19); -x_306 = lean_array_push(x_304, x_305); -lean_ctor_set(x_11, 2, x_306); -x_307 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_246, x_11, x_242); -if (lean_obj_tag(x_307) == 0) -{ -lean_object* x_308; lean_object* x_309; lean_object* x_310; -x_308 = lean_ctor_get(x_307, 0); -lean_inc(x_308); -x_309 = lean_ctor_get(x_307, 1); -lean_inc(x_309); -lean_dec(x_307); -x_310 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_310, 0, x_308); -x_251 = x_310; -x_252 = x_309; -goto block_301; -} -else -{ -lean_object* x_311; lean_object* x_312; lean_object* x_313; -x_311 = lean_ctor_get(x_307, 0); -lean_inc(x_311); -x_312 = lean_ctor_get(x_307, 1); -lean_inc(x_312); -lean_dec(x_307); -x_313 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_313, 0, x_311); -x_251 = x_313; -x_252 = x_312; -goto block_301; -} -} -else -{ -lean_object* x_314; lean_object* x_315; lean_object* x_316; lean_object* x_317; lean_object* x_318; lean_object* x_319; lean_object* x_320; lean_object* x_321; lean_object* x_322; -x_314 = lean_ctor_get(x_11, 0); -x_315 = lean_ctor_get(x_11, 1); -x_316 = lean_ctor_get(x_11, 2); -x_317 = lean_ctor_get(x_11, 3); -x_318 = lean_ctor_get(x_11, 4); -lean_inc(x_318); -lean_inc(x_317); -lean_inc(x_316); -lean_inc(x_315); -lean_inc(x_314); -lean_dec(x_11); -x_319 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_319, 0, x_244); -lean_ctor_set(x_319, 1, x_19); -x_320 = lean_array_push(x_316, x_319); -x_321 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_321, 0, x_314); -lean_ctor_set(x_321, 1, x_315); -lean_ctor_set(x_321, 2, x_320); -lean_ctor_set(x_321, 3, x_317); -lean_ctor_set(x_321, 4, x_318); -x_322 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_246, x_321, x_242); -if (lean_obj_tag(x_322) == 0) -{ -lean_object* x_323; lean_object* x_324; lean_object* x_325; -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_alloc_ctor(1, 1, 0); -lean_ctor_set(x_325, 0, x_323); -x_251 = x_325; -x_252 = x_324; -goto block_301; -} -else -{ -lean_object* x_326; lean_object* x_327; lean_object* x_328; -x_326 = lean_ctor_get(x_322, 0); -lean_inc(x_326); -x_327 = lean_ctor_get(x_322, 1); -lean_inc(x_327); -lean_dec(x_322); -x_328 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_328, 0, x_326); -x_251 = x_328; -x_252 = x_327; -goto block_301; -} -} -block_301: -{ -if (lean_obj_tag(x_251) == 0) -{ -lean_object* x_253; lean_object* x_254; uint8_t x_255; -x_253 = lean_ctor_get(x_252, 2); -lean_inc(x_253); -x_254 = lean_ctor_get(x_251, 0); +x_254 = lean_ctor_get(x_247, 0); lean_inc(x_254); -lean_dec(x_251); -x_255 = !lean_is_exclusive(x_252); -if (x_255 == 0) -{ -lean_object* x_256; uint8_t x_257; -x_256 = lean_ctor_get(x_252, 2); -lean_dec(x_256); -x_257 = !lean_is_exclusive(x_253); +lean_dec(x_247); +x_255 = lean_unsigned_to_nat(1u); +x_256 = lean_nat_add(x_10, x_255); +lean_dec(x_10); +x_257 = !lean_is_exclusive(x_252); if (x_257 == 0) { -lean_object* x_258; lean_object* x_259; -x_258 = lean_ctor_get(x_253, 2); -lean_dec(x_258); -lean_ctor_set(x_253, 2, x_250); -if (lean_is_scalar(x_243)) { - x_259 = lean_alloc_ctor(1, 2, 0); -} else { - x_259 = x_243; - lean_ctor_set_tag(x_259, 1); -} -lean_ctor_set(x_259, 0, x_254); -lean_ctor_set(x_259, 1, x_252); -return x_259; +lean_object* x_258; uint8_t x_259; +x_258 = lean_ctor_get(x_252, 2); +x_259 = !lean_is_exclusive(x_258); +if (x_259 == 0) +{ +lean_object* x_260; lean_object* x_261; lean_object* x_262; lean_object* x_316; uint8_t x_317; +x_260 = lean_ctor_get(x_258, 2); +x_316 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_258, 2, x_316); +x_317 = !lean_is_exclusive(x_11); +if (x_317 == 0) +{ +lean_object* x_318; lean_object* x_319; lean_object* x_320; lean_object* x_321; +x_318 = lean_ctor_get(x_11, 2); +x_319 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_319, 0, x_254); +lean_ctor_set(x_319, 1, x_19); +x_320 = lean_array_push(x_318, x_319); +lean_ctor_set(x_11, 2, x_320); +x_321 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_256, x_11, x_252); +if (lean_obj_tag(x_321) == 0) +{ +lean_object* x_322; lean_object* x_323; lean_object* x_324; +x_322 = lean_ctor_get(x_321, 0); +lean_inc(x_322); +x_323 = lean_ctor_get(x_321, 1); +lean_inc(x_323); +lean_dec(x_321); +x_324 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_324, 0, x_322); +x_261 = x_324; +x_262 = x_323; +goto block_315; } else { -lean_object* x_260; lean_object* x_261; lean_object* x_262; lean_object* x_263; lean_object* x_264; -x_260 = lean_ctor_get(x_253, 0); -x_261 = lean_ctor_get(x_253, 1); -x_262 = lean_ctor_get(x_253, 3); -lean_inc(x_262); -lean_inc(x_261); -lean_inc(x_260); -lean_dec(x_253); -x_263 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_263, 0, x_260); -lean_ctor_set(x_263, 1, x_261); -lean_ctor_set(x_263, 2, x_250); -lean_ctor_set(x_263, 3, x_262); -lean_ctor_set(x_252, 2, x_263); -if (lean_is_scalar(x_243)) { - x_264 = lean_alloc_ctor(1, 2, 0); -} else { - x_264 = x_243; - lean_ctor_set_tag(x_264, 1); -} -lean_ctor_set(x_264, 0, x_254); -lean_ctor_set(x_264, 1, x_252); -return x_264; +lean_object* x_325; lean_object* x_326; lean_object* x_327; +x_325 = lean_ctor_get(x_321, 0); +lean_inc(x_325); +x_326 = lean_ctor_get(x_321, 1); +lean_inc(x_326); +lean_dec(x_321); +x_327 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_327, 0, x_325); +x_261 = x_327; +x_262 = x_326; +goto block_315; } } else { -lean_object* x_265; lean_object* x_266; lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_object* x_270; lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_object* x_276; -x_265 = lean_ctor_get(x_252, 0); -x_266 = lean_ctor_get(x_252, 1); -x_267 = lean_ctor_get(x_252, 3); -x_268 = lean_ctor_get(x_252, 4); -x_269 = lean_ctor_get(x_252, 5); -lean_inc(x_269); -lean_inc(x_268); -lean_inc(x_267); -lean_inc(x_266); -lean_inc(x_265); -lean_dec(x_252); -x_270 = lean_ctor_get(x_253, 0); -lean_inc(x_270); -x_271 = lean_ctor_get(x_253, 1); -lean_inc(x_271); -x_272 = lean_ctor_get(x_253, 3); +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; +x_328 = lean_ctor_get(x_11, 0); +x_329 = lean_ctor_get(x_11, 1); +x_330 = lean_ctor_get(x_11, 2); +x_331 = lean_ctor_get(x_11, 3); +x_332 = lean_ctor_get(x_11, 4); +lean_inc(x_332); +lean_inc(x_331); +lean_inc(x_330); +lean_inc(x_329); +lean_inc(x_328); +lean_dec(x_11); +x_333 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_333, 0, x_254); +lean_ctor_set(x_333, 1, x_19); +x_334 = lean_array_push(x_330, x_333); +x_335 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_335, 0, x_328); +lean_ctor_set(x_335, 1, x_329); +lean_ctor_set(x_335, 2, x_334); +lean_ctor_set(x_335, 3, x_331); +lean_ctor_set(x_335, 4, x_332); +x_336 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_256, x_335, x_252); +if (lean_obj_tag(x_336) == 0) +{ +lean_object* x_337; lean_object* x_338; lean_object* x_339; +x_337 = lean_ctor_get(x_336, 0); +lean_inc(x_337); +x_338 = lean_ctor_get(x_336, 1); +lean_inc(x_338); +lean_dec(x_336); +x_339 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_339, 0, x_337); +x_261 = x_339; +x_262 = x_338; +goto block_315; +} +else +{ +lean_object* x_340; lean_object* x_341; lean_object* x_342; +x_340 = lean_ctor_get(x_336, 0); +lean_inc(x_340); +x_341 = lean_ctor_get(x_336, 1); +lean_inc(x_341); +lean_dec(x_336); +x_342 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_342, 0, x_340); +x_261 = x_342; +x_262 = x_341; +goto block_315; +} +} +block_315: +{ +if (lean_obj_tag(x_261) == 0) +{ +lean_object* x_263; lean_object* x_264; uint8_t x_265; +x_263 = lean_ctor_get(x_262, 2); +lean_inc(x_263); +x_264 = lean_ctor_get(x_261, 0); +lean_inc(x_264); +lean_dec(x_261); +x_265 = !lean_is_exclusive(x_262); +if (x_265 == 0) +{ +lean_object* x_266; uint8_t x_267; +x_266 = lean_ctor_get(x_262, 2); +lean_dec(x_266); +x_267 = !lean_is_exclusive(x_263); +if (x_267 == 0) +{ +lean_object* x_268; lean_object* x_269; +x_268 = lean_ctor_get(x_263, 2); +lean_dec(x_268); +lean_ctor_set(x_263, 2, x_260); +if (lean_is_scalar(x_253)) { + x_269 = lean_alloc_ctor(1, 2, 0); +} else { + x_269 = x_253; + lean_ctor_set_tag(x_269, 1); +} +lean_ctor_set(x_269, 0, x_264); +lean_ctor_set(x_269, 1, x_262); +return x_269; +} +else +{ +lean_object* x_270; lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; lean_object* x_275; +x_270 = lean_ctor_get(x_263, 0); +x_271 = lean_ctor_get(x_263, 1); +x_272 = lean_ctor_get(x_263, 3); +x_273 = lean_ctor_get(x_263, 4); +lean_inc(x_273); lean_inc(x_272); -if (lean_is_exclusive(x_253)) { - lean_ctor_release(x_253, 0); - lean_ctor_release(x_253, 1); - lean_ctor_release(x_253, 2); - lean_ctor_release(x_253, 3); - x_273 = x_253; -} else { - lean_dec_ref(x_253); - x_273 = lean_box(0); -} -if (lean_is_scalar(x_273)) { - x_274 = lean_alloc_ctor(0, 4, 0); -} else { - x_274 = x_273; -} +lean_inc(x_271); +lean_inc(x_270); +lean_dec(x_263); +x_274 = lean_alloc_ctor(0, 5, 0); lean_ctor_set(x_274, 0, x_270); lean_ctor_set(x_274, 1, x_271); -lean_ctor_set(x_274, 2, x_250); +lean_ctor_set(x_274, 2, x_260); lean_ctor_set(x_274, 3, x_272); -x_275 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_275, 0, x_265); -lean_ctor_set(x_275, 1, x_266); -lean_ctor_set(x_275, 2, x_274); -lean_ctor_set(x_275, 3, x_267); -lean_ctor_set(x_275, 4, x_268); -lean_ctor_set(x_275, 5, x_269); -if (lean_is_scalar(x_243)) { - x_276 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_274, 4, x_273); +lean_ctor_set(x_262, 2, x_274); +if (lean_is_scalar(x_253)) { + x_275 = lean_alloc_ctor(1, 2, 0); } else { - x_276 = x_243; - lean_ctor_set_tag(x_276, 1); + x_275 = x_253; + lean_ctor_set_tag(x_275, 1); } -lean_ctor_set(x_276, 0, x_254); -lean_ctor_set(x_276, 1, x_275); -return x_276; +lean_ctor_set(x_275, 0, x_264); +lean_ctor_set(x_275, 1, x_262); +return x_275; } } else { -lean_object* x_277; lean_object* x_278; uint8_t x_279; -x_277 = lean_ctor_get(x_252, 2); -lean_inc(x_277); -x_278 = lean_ctor_get(x_251, 0); +lean_object* x_276; lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; lean_object* x_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; +x_276 = lean_ctor_get(x_262, 0); +x_277 = lean_ctor_get(x_262, 1); +x_278 = lean_ctor_get(x_262, 3); +x_279 = lean_ctor_get(x_262, 4); +x_280 = lean_ctor_get(x_262, 5); +lean_inc(x_280); +lean_inc(x_279); lean_inc(x_278); -lean_dec(x_251); -x_279 = !lean_is_exclusive(x_252); -if (x_279 == 0) -{ -lean_object* x_280; uint8_t x_281; -x_280 = lean_ctor_get(x_252, 2); -lean_dec(x_280); -x_281 = !lean_is_exclusive(x_277); -if (x_281 == 0) -{ -lean_object* x_282; lean_object* x_283; -x_282 = lean_ctor_get(x_277, 2); -lean_dec(x_282); -lean_ctor_set(x_277, 2, x_250); -if (lean_is_scalar(x_243)) { - x_283 = lean_alloc_ctor(0, 2, 0); -} else { - x_283 = x_243; -} -lean_ctor_set(x_283, 0, x_278); -lean_ctor_set(x_283, 1, x_252); -return x_283; -} -else -{ -lean_object* x_284; lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; -x_284 = lean_ctor_get(x_277, 0); -x_285 = lean_ctor_get(x_277, 1); -x_286 = lean_ctor_get(x_277, 3); -lean_inc(x_286); -lean_inc(x_285); +lean_inc(x_277); +lean_inc(x_276); +lean_dec(x_262); +x_281 = lean_ctor_get(x_263, 0); +lean_inc(x_281); +x_282 = lean_ctor_get(x_263, 1); +lean_inc(x_282); +x_283 = lean_ctor_get(x_263, 3); +lean_inc(x_283); +x_284 = lean_ctor_get(x_263, 4); lean_inc(x_284); -lean_dec(x_277); -x_287 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_287, 0, x_284); -lean_ctor_set(x_287, 1, x_285); -lean_ctor_set(x_287, 2, x_250); -lean_ctor_set(x_287, 3, x_286); -lean_ctor_set(x_252, 2, x_287); -if (lean_is_scalar(x_243)) { - x_288 = lean_alloc_ctor(0, 2, 0); +if (lean_is_exclusive(x_263)) { + lean_ctor_release(x_263, 0); + lean_ctor_release(x_263, 1); + lean_ctor_release(x_263, 2); + lean_ctor_release(x_263, 3); + lean_ctor_release(x_263, 4); + x_285 = x_263; } else { - x_288 = x_243; + lean_dec_ref(x_263); + x_285 = lean_box(0); } -lean_ctor_set(x_288, 0, x_278); -lean_ctor_set(x_288, 1, x_252); +if (lean_is_scalar(x_285)) { + x_286 = lean_alloc_ctor(0, 5, 0); +} else { + x_286 = x_285; +} +lean_ctor_set(x_286, 0, x_281); +lean_ctor_set(x_286, 1, x_282); +lean_ctor_set(x_286, 2, x_260); +lean_ctor_set(x_286, 3, x_283); +lean_ctor_set(x_286, 4, x_284); +x_287 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_287, 0, x_276); +lean_ctor_set(x_287, 1, x_277); +lean_ctor_set(x_287, 2, x_286); +lean_ctor_set(x_287, 3, x_278); +lean_ctor_set(x_287, 4, x_279); +lean_ctor_set(x_287, 5, x_280); +if (lean_is_scalar(x_253)) { + x_288 = lean_alloc_ctor(1, 2, 0); +} else { + x_288 = x_253; + lean_ctor_set_tag(x_288, 1); +} +lean_ctor_set(x_288, 0, x_264); +lean_ctor_set(x_288, 1, x_287); return x_288; } } else { -lean_object* x_289; lean_object* x_290; lean_object* x_291; lean_object* x_292; lean_object* x_293; lean_object* x_294; lean_object* x_295; lean_object* x_296; lean_object* x_297; lean_object* x_298; lean_object* x_299; lean_object* x_300; -x_289 = lean_ctor_get(x_252, 0); -x_290 = lean_ctor_get(x_252, 1); -x_291 = lean_ctor_get(x_252, 3); -x_292 = lean_ctor_get(x_252, 4); -x_293 = lean_ctor_get(x_252, 5); -lean_inc(x_293); -lean_inc(x_292); -lean_inc(x_291); -lean_inc(x_290); +lean_object* x_289; lean_object* x_290; uint8_t x_291; +x_289 = lean_ctor_get(x_262, 2); lean_inc(x_289); -lean_dec(x_252); -x_294 = lean_ctor_get(x_277, 0); -lean_inc(x_294); -x_295 = lean_ctor_get(x_277, 1); -lean_inc(x_295); -x_296 = lean_ctor_get(x_277, 3); +x_290 = lean_ctor_get(x_261, 0); +lean_inc(x_290); +lean_dec(x_261); +x_291 = !lean_is_exclusive(x_262); +if (x_291 == 0) +{ +lean_object* x_292; uint8_t x_293; +x_292 = lean_ctor_get(x_262, 2); +lean_dec(x_292); +x_293 = !lean_is_exclusive(x_289); +if (x_293 == 0) +{ +lean_object* x_294; lean_object* x_295; +x_294 = lean_ctor_get(x_289, 2); +lean_dec(x_294); +lean_ctor_set(x_289, 2, x_260); +if (lean_is_scalar(x_253)) { + x_295 = lean_alloc_ctor(0, 2, 0); +} else { + x_295 = x_253; +} +lean_ctor_set(x_295, 0, x_290); +lean_ctor_set(x_295, 1, x_262); +return x_295; +} +else +{ +lean_object* x_296; lean_object* x_297; lean_object* x_298; lean_object* x_299; lean_object* x_300; lean_object* x_301; +x_296 = lean_ctor_get(x_289, 0); +x_297 = lean_ctor_get(x_289, 1); +x_298 = lean_ctor_get(x_289, 3); +x_299 = lean_ctor_get(x_289, 4); +lean_inc(x_299); +lean_inc(x_298); +lean_inc(x_297); lean_inc(x_296); -if (lean_is_exclusive(x_277)) { - lean_ctor_release(x_277, 0); - lean_ctor_release(x_277, 1); - lean_ctor_release(x_277, 2); - lean_ctor_release(x_277, 3); - x_297 = x_277; +lean_dec(x_289); +x_300 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_300, 0, x_296); +lean_ctor_set(x_300, 1, x_297); +lean_ctor_set(x_300, 2, x_260); +lean_ctor_set(x_300, 3, x_298); +lean_ctor_set(x_300, 4, x_299); +lean_ctor_set(x_262, 2, x_300); +if (lean_is_scalar(x_253)) { + x_301 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_277); - x_297 = lean_box(0); + x_301 = x_253; } -if (lean_is_scalar(x_297)) { - x_298 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_301, 0, x_290); +lean_ctor_set(x_301, 1, x_262); +return x_301; +} +} +else +{ +lean_object* x_302; lean_object* x_303; lean_object* x_304; lean_object* x_305; lean_object* x_306; lean_object* x_307; lean_object* x_308; lean_object* x_309; lean_object* x_310; lean_object* x_311; lean_object* x_312; lean_object* x_313; lean_object* x_314; +x_302 = lean_ctor_get(x_262, 0); +x_303 = lean_ctor_get(x_262, 1); +x_304 = lean_ctor_get(x_262, 3); +x_305 = lean_ctor_get(x_262, 4); +x_306 = lean_ctor_get(x_262, 5); +lean_inc(x_306); +lean_inc(x_305); +lean_inc(x_304); +lean_inc(x_303); +lean_inc(x_302); +lean_dec(x_262); +x_307 = lean_ctor_get(x_289, 0); +lean_inc(x_307); +x_308 = lean_ctor_get(x_289, 1); +lean_inc(x_308); +x_309 = lean_ctor_get(x_289, 3); +lean_inc(x_309); +x_310 = lean_ctor_get(x_289, 4); +lean_inc(x_310); +if (lean_is_exclusive(x_289)) { + lean_ctor_release(x_289, 0); + lean_ctor_release(x_289, 1); + lean_ctor_release(x_289, 2); + lean_ctor_release(x_289, 3); + lean_ctor_release(x_289, 4); + x_311 = x_289; } else { - x_298 = x_297; + lean_dec_ref(x_289); + x_311 = lean_box(0); } -lean_ctor_set(x_298, 0, x_294); -lean_ctor_set(x_298, 1, x_295); -lean_ctor_set(x_298, 2, x_250); -lean_ctor_set(x_298, 3, x_296); -x_299 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_299, 0, x_289); -lean_ctor_set(x_299, 1, x_290); -lean_ctor_set(x_299, 2, x_298); -lean_ctor_set(x_299, 3, x_291); -lean_ctor_set(x_299, 4, x_292); -lean_ctor_set(x_299, 5, x_293); -if (lean_is_scalar(x_243)) { - x_300 = lean_alloc_ctor(0, 2, 0); +if (lean_is_scalar(x_311)) { + x_312 = lean_alloc_ctor(0, 5, 0); } else { - x_300 = x_243; + x_312 = x_311; } -lean_ctor_set(x_300, 0, x_278); -lean_ctor_set(x_300, 1, x_299); -return x_300; +lean_ctor_set(x_312, 0, x_307); +lean_ctor_set(x_312, 1, x_308); +lean_ctor_set(x_312, 2, x_260); +lean_ctor_set(x_312, 3, x_309); +lean_ctor_set(x_312, 4, x_310); +x_313 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_313, 0, x_302); +lean_ctor_set(x_313, 1, x_303); +lean_ctor_set(x_313, 2, x_312); +lean_ctor_set(x_313, 3, x_304); +lean_ctor_set(x_313, 4, x_305); +lean_ctor_set(x_313, 5, x_306); +if (lean_is_scalar(x_253)) { + x_314 = lean_alloc_ctor(0, 2, 0); +} else { + x_314 = x_253; +} +lean_ctor_set(x_314, 0, x_290); +lean_ctor_set(x_314, 1, x_313); +return x_314; } } } } else { -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_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; lean_object* x_374; lean_object* x_375; lean_object* x_376; lean_object* x_377; -x_329 = lean_ctor_get(x_248, 0); -x_330 = lean_ctor_get(x_248, 1); -x_331 = lean_ctor_get(x_248, 2); -x_332 = lean_ctor_get(x_248, 3); -lean_inc(x_332); -lean_inc(x_331); -lean_inc(x_330); -lean_inc(x_329); -lean_dec(x_248); -x_366 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_367 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_367, 0, x_329); -lean_ctor_set(x_367, 1, x_330); -lean_ctor_set(x_367, 2, x_366); -lean_ctor_set(x_367, 3, x_332); -lean_ctor_set(x_242, 2, x_367); -x_368 = lean_ctor_get(x_11, 0); -lean_inc(x_368); -x_369 = lean_ctor_get(x_11, 1); -lean_inc(x_369); -x_370 = lean_ctor_get(x_11, 2); -lean_inc(x_370); -x_371 = lean_ctor_get(x_11, 3); -lean_inc(x_371); -x_372 = lean_ctor_get(x_11, 4); -lean_inc(x_372); +lean_object* x_343; lean_object* x_344; lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; 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; lean_object* x_391; lean_object* x_392; lean_object* x_393; lean_object* x_394; +x_343 = lean_ctor_get(x_258, 0); +x_344 = lean_ctor_get(x_258, 1); +x_345 = lean_ctor_get(x_258, 2); +x_346 = lean_ctor_get(x_258, 3); +x_347 = lean_ctor_get(x_258, 4); +lean_inc(x_347); +lean_inc(x_346); +lean_inc(x_345); +lean_inc(x_344); +lean_inc(x_343); +lean_dec(x_258); +x_383 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_384 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_384, 0, x_343); +lean_ctor_set(x_384, 1, x_344); +lean_ctor_set(x_384, 2, x_383); +lean_ctor_set(x_384, 3, x_346); +lean_ctor_set(x_384, 4, x_347); +lean_ctor_set(x_252, 2, x_384); +x_385 = lean_ctor_get(x_11, 0); +lean_inc(x_385); +x_386 = lean_ctor_get(x_11, 1); +lean_inc(x_386); +x_387 = lean_ctor_get(x_11, 2); +lean_inc(x_387); +x_388 = lean_ctor_get(x_11, 3); +lean_inc(x_388); +x_389 = lean_ctor_get(x_11, 4); +lean_inc(x_389); if (lean_is_exclusive(x_11)) { lean_ctor_release(x_11, 0); lean_ctor_release(x_11, 1); lean_ctor_release(x_11, 2); lean_ctor_release(x_11, 3); lean_ctor_release(x_11, 4); - x_373 = x_11; + x_390 = x_11; } else { lean_dec_ref(x_11); - x_373 = lean_box(0); + x_390 = lean_box(0); } -x_374 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_374, 0, x_244); -lean_ctor_set(x_374, 1, x_19); -x_375 = lean_array_push(x_370, x_374); -if (lean_is_scalar(x_373)) { - x_376 = lean_alloc_ctor(0, 5, 0); +x_391 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_391, 0, x_254); +lean_ctor_set(x_391, 1, x_19); +x_392 = lean_array_push(x_387, x_391); +if (lean_is_scalar(x_390)) { + x_393 = lean_alloc_ctor(0, 5, 0); } else { - x_376 = x_373; + x_393 = x_390; } -lean_ctor_set(x_376, 0, x_368); -lean_ctor_set(x_376, 1, x_369); -lean_ctor_set(x_376, 2, x_375); -lean_ctor_set(x_376, 3, x_371); -lean_ctor_set(x_376, 4, x_372); -x_377 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_246, x_376, x_242); -if (lean_obj_tag(x_377) == 0) +lean_ctor_set(x_393, 0, x_385); +lean_ctor_set(x_393, 1, x_386); +lean_ctor_set(x_393, 2, x_392); +lean_ctor_set(x_393, 3, x_388); +lean_ctor_set(x_393, 4, x_389); +x_394 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_256, x_393, x_252); +if (lean_obj_tag(x_394) == 0) { -lean_object* x_378; lean_object* x_379; lean_object* x_380; -x_378 = lean_ctor_get(x_377, 0); -lean_inc(x_378); -x_379 = lean_ctor_get(x_377, 1); -lean_inc(x_379); -lean_dec(x_377); -x_380 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_380, 0, x_378); -x_333 = x_380; -x_334 = x_379; -goto block_365; +lean_object* x_395; lean_object* x_396; lean_object* x_397; +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, 1, 0); +lean_ctor_set(x_397, 0, x_395); +x_348 = x_397; +x_349 = x_396; +goto block_382; } else { -lean_object* x_381; lean_object* x_382; lean_object* x_383; -x_381 = lean_ctor_get(x_377, 0); -lean_inc(x_381); -x_382 = lean_ctor_get(x_377, 1); -lean_inc(x_382); -lean_dec(x_377); -x_383 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_383, 0, x_381); -x_333 = x_383; -x_334 = x_382; -goto block_365; +lean_object* x_398; lean_object* x_399; lean_object* x_400; +x_398 = lean_ctor_get(x_394, 0); +lean_inc(x_398); +x_399 = lean_ctor_get(x_394, 1); +lean_inc(x_399); +lean_dec(x_394); +x_400 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_400, 0, x_398); +x_348 = x_400; +x_349 = x_399; +goto block_382; } -block_365: +block_382: { -if (lean_obj_tag(x_333) == 0) +if (lean_obj_tag(x_348) == 0) { -lean_object* x_335; lean_object* x_336; lean_object* x_337; lean_object* x_338; lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; -x_335 = lean_ctor_get(x_334, 2); -lean_inc(x_335); -x_336 = lean_ctor_get(x_333, 0); -lean_inc(x_336); -lean_dec(x_333); -x_337 = lean_ctor_get(x_334, 0); -lean_inc(x_337); -x_338 = lean_ctor_get(x_334, 1); -lean_inc(x_338); -x_339 = lean_ctor_get(x_334, 3); -lean_inc(x_339); -x_340 = lean_ctor_get(x_334, 4); -lean_inc(x_340); -x_341 = lean_ctor_get(x_334, 5); -lean_inc(x_341); -if (lean_is_exclusive(x_334)) { - lean_ctor_release(x_334, 0); - lean_ctor_release(x_334, 1); - lean_ctor_release(x_334, 2); - lean_ctor_release(x_334, 3); - lean_ctor_release(x_334, 4); - lean_ctor_release(x_334, 5); - x_342 = x_334; -} else { - lean_dec_ref(x_334); - x_342 = lean_box(0); -} -x_343 = lean_ctor_get(x_335, 0); -lean_inc(x_343); -x_344 = lean_ctor_get(x_335, 1); -lean_inc(x_344); -x_345 = lean_ctor_get(x_335, 3); -lean_inc(x_345); -if (lean_is_exclusive(x_335)) { - lean_ctor_release(x_335, 0); - lean_ctor_release(x_335, 1); - lean_ctor_release(x_335, 2); - lean_ctor_release(x_335, 3); - x_346 = x_335; -} else { - lean_dec_ref(x_335); - x_346 = lean_box(0); -} -if (lean_is_scalar(x_346)) { - x_347 = lean_alloc_ctor(0, 4, 0); -} else { - x_347 = x_346; -} -lean_ctor_set(x_347, 0, x_343); -lean_ctor_set(x_347, 1, x_344); -lean_ctor_set(x_347, 2, x_331); -lean_ctor_set(x_347, 3, x_345); -if (lean_is_scalar(x_342)) { - x_348 = lean_alloc_ctor(0, 6, 0); -} else { - x_348 = x_342; -} -lean_ctor_set(x_348, 0, x_337); -lean_ctor_set(x_348, 1, x_338); -lean_ctor_set(x_348, 2, x_347); -lean_ctor_set(x_348, 3, x_339); -lean_ctor_set(x_348, 4, x_340); -lean_ctor_set(x_348, 5, x_341); -if (lean_is_scalar(x_243)) { - x_349 = lean_alloc_ctor(1, 2, 0); -} else { - x_349 = x_243; - lean_ctor_set_tag(x_349, 1); -} -lean_ctor_set(x_349, 0, x_336); -lean_ctor_set(x_349, 1, x_348); -return x_349; -} -else -{ -lean_object* x_350; lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; 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; -x_350 = lean_ctor_get(x_334, 2); +lean_object* x_350; lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; 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; +x_350 = lean_ctor_get(x_349, 2); lean_inc(x_350); -x_351 = lean_ctor_get(x_333, 0); +x_351 = lean_ctor_get(x_348, 0); lean_inc(x_351); -lean_dec(x_333); -x_352 = lean_ctor_get(x_334, 0); +lean_dec(x_348); +x_352 = lean_ctor_get(x_349, 0); lean_inc(x_352); -x_353 = lean_ctor_get(x_334, 1); +x_353 = lean_ctor_get(x_349, 1); lean_inc(x_353); -x_354 = lean_ctor_get(x_334, 3); +x_354 = lean_ctor_get(x_349, 3); lean_inc(x_354); -x_355 = lean_ctor_get(x_334, 4); +x_355 = lean_ctor_get(x_349, 4); lean_inc(x_355); -x_356 = lean_ctor_get(x_334, 5); +x_356 = lean_ctor_get(x_349, 5); lean_inc(x_356); -if (lean_is_exclusive(x_334)) { - lean_ctor_release(x_334, 0); - lean_ctor_release(x_334, 1); - lean_ctor_release(x_334, 2); - lean_ctor_release(x_334, 3); - lean_ctor_release(x_334, 4); - lean_ctor_release(x_334, 5); - x_357 = x_334; +if (lean_is_exclusive(x_349)) { + lean_ctor_release(x_349, 0); + lean_ctor_release(x_349, 1); + lean_ctor_release(x_349, 2); + lean_ctor_release(x_349, 3); + lean_ctor_release(x_349, 4); + lean_ctor_release(x_349, 5); + x_357 = x_349; } else { - lean_dec_ref(x_334); + lean_dec_ref(x_349); x_357 = lean_box(0); } x_358 = lean_ctor_get(x_350, 0); @@ -6190,315 +6253,411 @@ x_359 = lean_ctor_get(x_350, 1); lean_inc(x_359); x_360 = lean_ctor_get(x_350, 3); lean_inc(x_360); +x_361 = lean_ctor_get(x_350, 4); +lean_inc(x_361); if (lean_is_exclusive(x_350)) { lean_ctor_release(x_350, 0); lean_ctor_release(x_350, 1); lean_ctor_release(x_350, 2); lean_ctor_release(x_350, 3); - x_361 = x_350; + lean_ctor_release(x_350, 4); + x_362 = x_350; } else { lean_dec_ref(x_350); - x_361 = lean_box(0); + x_362 = lean_box(0); } -if (lean_is_scalar(x_361)) { - x_362 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_362)) { + x_363 = lean_alloc_ctor(0, 5, 0); } else { - x_362 = x_361; + x_363 = x_362; } -lean_ctor_set(x_362, 0, x_358); -lean_ctor_set(x_362, 1, x_359); -lean_ctor_set(x_362, 2, x_331); -lean_ctor_set(x_362, 3, x_360); +lean_ctor_set(x_363, 0, x_358); +lean_ctor_set(x_363, 1, x_359); +lean_ctor_set(x_363, 2, x_345); +lean_ctor_set(x_363, 3, x_360); +lean_ctor_set(x_363, 4, x_361); if (lean_is_scalar(x_357)) { - x_363 = lean_alloc_ctor(0, 6, 0); + x_364 = lean_alloc_ctor(0, 6, 0); } else { - x_363 = x_357; + x_364 = x_357; } -lean_ctor_set(x_363, 0, x_352); -lean_ctor_set(x_363, 1, x_353); -lean_ctor_set(x_363, 2, x_362); -lean_ctor_set(x_363, 3, x_354); -lean_ctor_set(x_363, 4, x_355); -lean_ctor_set(x_363, 5, x_356); -if (lean_is_scalar(x_243)) { - x_364 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_364, 0, x_352); +lean_ctor_set(x_364, 1, x_353); +lean_ctor_set(x_364, 2, x_363); +lean_ctor_set(x_364, 3, x_354); +lean_ctor_set(x_364, 4, x_355); +lean_ctor_set(x_364, 5, x_356); +if (lean_is_scalar(x_253)) { + x_365 = lean_alloc_ctor(1, 2, 0); } else { - x_364 = x_243; + x_365 = x_253; + lean_ctor_set_tag(x_365, 1); } -lean_ctor_set(x_364, 0, x_351); -lean_ctor_set(x_364, 1, x_363); -return x_364; +lean_ctor_set(x_365, 0, x_351); +lean_ctor_set(x_365, 1, x_364); +return x_365; +} +else +{ +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; lean_object* x_374; lean_object* x_375; lean_object* x_376; lean_object* x_377; lean_object* x_378; lean_object* x_379; lean_object* x_380; lean_object* x_381; +x_366 = lean_ctor_get(x_349, 2); +lean_inc(x_366); +x_367 = lean_ctor_get(x_348, 0); +lean_inc(x_367); +lean_dec(x_348); +x_368 = lean_ctor_get(x_349, 0); +lean_inc(x_368); +x_369 = lean_ctor_get(x_349, 1); +lean_inc(x_369); +x_370 = lean_ctor_get(x_349, 3); +lean_inc(x_370); +x_371 = lean_ctor_get(x_349, 4); +lean_inc(x_371); +x_372 = lean_ctor_get(x_349, 5); +lean_inc(x_372); +if (lean_is_exclusive(x_349)) { + lean_ctor_release(x_349, 0); + lean_ctor_release(x_349, 1); + lean_ctor_release(x_349, 2); + lean_ctor_release(x_349, 3); + lean_ctor_release(x_349, 4); + lean_ctor_release(x_349, 5); + x_373 = x_349; +} else { + lean_dec_ref(x_349); + x_373 = lean_box(0); +} +x_374 = lean_ctor_get(x_366, 0); +lean_inc(x_374); +x_375 = lean_ctor_get(x_366, 1); +lean_inc(x_375); +x_376 = lean_ctor_get(x_366, 3); +lean_inc(x_376); +x_377 = lean_ctor_get(x_366, 4); +lean_inc(x_377); +if (lean_is_exclusive(x_366)) { + lean_ctor_release(x_366, 0); + lean_ctor_release(x_366, 1); + lean_ctor_release(x_366, 2); + lean_ctor_release(x_366, 3); + lean_ctor_release(x_366, 4); + x_378 = x_366; +} else { + lean_dec_ref(x_366); + x_378 = lean_box(0); +} +if (lean_is_scalar(x_378)) { + x_379 = lean_alloc_ctor(0, 5, 0); +} else { + x_379 = x_378; +} +lean_ctor_set(x_379, 0, x_374); +lean_ctor_set(x_379, 1, x_375); +lean_ctor_set(x_379, 2, x_345); +lean_ctor_set(x_379, 3, x_376); +lean_ctor_set(x_379, 4, x_377); +if (lean_is_scalar(x_373)) { + x_380 = lean_alloc_ctor(0, 6, 0); +} else { + x_380 = x_373; +} +lean_ctor_set(x_380, 0, x_368); +lean_ctor_set(x_380, 1, x_369); +lean_ctor_set(x_380, 2, x_379); +lean_ctor_set(x_380, 3, x_370); +lean_ctor_set(x_380, 4, x_371); +lean_ctor_set(x_380, 5, x_372); +if (lean_is_scalar(x_253)) { + x_381 = lean_alloc_ctor(0, 2, 0); +} else { + x_381 = x_253; +} +lean_ctor_set(x_381, 0, x_367); +lean_ctor_set(x_381, 1, x_380); +return x_381; } } } } else { -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; lean_object* x_391; lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_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; -x_384 = lean_ctor_get(x_242, 2); -x_385 = lean_ctor_get(x_242, 0); -x_386 = lean_ctor_get(x_242, 1); -x_387 = lean_ctor_get(x_242, 3); -x_388 = lean_ctor_get(x_242, 4); -x_389 = lean_ctor_get(x_242, 5); -lean_inc(x_389); -lean_inc(x_388); -lean_inc(x_387); -lean_inc(x_384); -lean_inc(x_386); -lean_inc(x_385); -lean_dec(x_242); -x_390 = lean_ctor_get(x_384, 0); -lean_inc(x_390); -x_391 = lean_ctor_get(x_384, 1); -lean_inc(x_391); -x_392 = lean_ctor_get(x_384, 2); -lean_inc(x_392); -x_393 = lean_ctor_get(x_384, 3); -lean_inc(x_393); -if (lean_is_exclusive(x_384)) { - lean_ctor_release(x_384, 0); - lean_ctor_release(x_384, 1); - lean_ctor_release(x_384, 2); - lean_ctor_release(x_384, 3); - x_394 = x_384; +lean_object* x_401; lean_object* x_402; lean_object* x_403; lean_object* x_404; lean_object* x_405; lean_object* x_406; lean_object* x_407; lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_object* x_412; lean_object* x_413; lean_object* x_414; lean_object* x_448; lean_object* x_449; lean_object* x_450; lean_object* x_451; lean_object* x_452; lean_object* x_453; lean_object* x_454; lean_object* x_455; lean_object* x_456; lean_object* x_457; lean_object* x_458; lean_object* x_459; lean_object* x_460; +x_401 = lean_ctor_get(x_252, 2); +x_402 = lean_ctor_get(x_252, 0); +x_403 = lean_ctor_get(x_252, 1); +x_404 = lean_ctor_get(x_252, 3); +x_405 = lean_ctor_get(x_252, 4); +x_406 = lean_ctor_get(x_252, 5); +lean_inc(x_406); +lean_inc(x_405); +lean_inc(x_404); +lean_inc(x_401); +lean_inc(x_403); +lean_inc(x_402); +lean_dec(x_252); +x_407 = lean_ctor_get(x_401, 0); +lean_inc(x_407); +x_408 = lean_ctor_get(x_401, 1); +lean_inc(x_408); +x_409 = lean_ctor_get(x_401, 2); +lean_inc(x_409); +x_410 = lean_ctor_get(x_401, 3); +lean_inc(x_410); +x_411 = lean_ctor_get(x_401, 4); +lean_inc(x_411); +if (lean_is_exclusive(x_401)) { + lean_ctor_release(x_401, 0); + lean_ctor_release(x_401, 1); + lean_ctor_release(x_401, 2); + lean_ctor_release(x_401, 3); + lean_ctor_release(x_401, 4); + x_412 = x_401; } else { - lean_dec_ref(x_384); - x_394 = lean_box(0); + lean_dec_ref(x_401); + x_412 = lean_box(0); } -x_428 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_394)) { - x_429 = lean_alloc_ctor(0, 4, 0); +x_448 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_412)) { + x_449 = lean_alloc_ctor(0, 5, 0); } else { - x_429 = x_394; + x_449 = x_412; } -lean_ctor_set(x_429, 0, x_390); -lean_ctor_set(x_429, 1, x_391); -lean_ctor_set(x_429, 2, x_428); -lean_ctor_set(x_429, 3, x_393); -x_430 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_430, 0, x_385); -lean_ctor_set(x_430, 1, x_386); -lean_ctor_set(x_430, 2, x_429); -lean_ctor_set(x_430, 3, x_387); -lean_ctor_set(x_430, 4, x_388); -lean_ctor_set(x_430, 5, x_389); -x_431 = lean_ctor_get(x_11, 0); -lean_inc(x_431); -x_432 = lean_ctor_get(x_11, 1); -lean_inc(x_432); -x_433 = lean_ctor_get(x_11, 2); -lean_inc(x_433); -x_434 = lean_ctor_get(x_11, 3); -lean_inc(x_434); -x_435 = lean_ctor_get(x_11, 4); -lean_inc(x_435); +lean_ctor_set(x_449, 0, x_407); +lean_ctor_set(x_449, 1, x_408); +lean_ctor_set(x_449, 2, x_448); +lean_ctor_set(x_449, 3, x_410); +lean_ctor_set(x_449, 4, x_411); +x_450 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_450, 0, x_402); +lean_ctor_set(x_450, 1, x_403); +lean_ctor_set(x_450, 2, x_449); +lean_ctor_set(x_450, 3, x_404); +lean_ctor_set(x_450, 4, x_405); +lean_ctor_set(x_450, 5, x_406); +x_451 = lean_ctor_get(x_11, 0); +lean_inc(x_451); +x_452 = lean_ctor_get(x_11, 1); +lean_inc(x_452); +x_453 = lean_ctor_get(x_11, 2); +lean_inc(x_453); +x_454 = lean_ctor_get(x_11, 3); +lean_inc(x_454); +x_455 = lean_ctor_get(x_11, 4); +lean_inc(x_455); if (lean_is_exclusive(x_11)) { lean_ctor_release(x_11, 0); lean_ctor_release(x_11, 1); lean_ctor_release(x_11, 2); lean_ctor_release(x_11, 3); lean_ctor_release(x_11, 4); - x_436 = x_11; + x_456 = x_11; } else { lean_dec_ref(x_11); - x_436 = lean_box(0); + x_456 = lean_box(0); } -x_437 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_437, 0, x_244); -lean_ctor_set(x_437, 1, x_19); -x_438 = lean_array_push(x_433, x_437); -if (lean_is_scalar(x_436)) { - x_439 = lean_alloc_ctor(0, 5, 0); +x_457 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_457, 0, x_254); +lean_ctor_set(x_457, 1, x_19); +x_458 = lean_array_push(x_453, x_457); +if (lean_is_scalar(x_456)) { + x_459 = lean_alloc_ctor(0, 5, 0); } else { - x_439 = x_436; + x_459 = x_456; } -lean_ctor_set(x_439, 0, x_431); -lean_ctor_set(x_439, 1, x_432); -lean_ctor_set(x_439, 2, x_438); -lean_ctor_set(x_439, 3, x_434); -lean_ctor_set(x_439, 4, x_435); -x_440 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_246, x_439, x_430); -if (lean_obj_tag(x_440) == 0) +lean_ctor_set(x_459, 0, x_451); +lean_ctor_set(x_459, 1, x_452); +lean_ctor_set(x_459, 2, x_458); +lean_ctor_set(x_459, 3, x_454); +lean_ctor_set(x_459, 4, x_455); +x_460 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_256, x_459, x_450); +if (lean_obj_tag(x_460) == 0) { -lean_object* x_441; lean_object* x_442; lean_object* x_443; -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_443 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_443, 0, x_441); -x_395 = x_443; -x_396 = x_442; -goto block_427; +lean_object* x_461; lean_object* x_462; lean_object* x_463; +x_461 = lean_ctor_get(x_460, 0); +lean_inc(x_461); +x_462 = lean_ctor_get(x_460, 1); +lean_inc(x_462); +lean_dec(x_460); +x_463 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_463, 0, x_461); +x_413 = x_463; +x_414 = x_462; +goto block_447; } else { -lean_object* x_444; lean_object* x_445; lean_object* x_446; -x_444 = lean_ctor_get(x_440, 0); -lean_inc(x_444); -x_445 = lean_ctor_get(x_440, 1); -lean_inc(x_445); -lean_dec(x_440); -x_446 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_446, 0, x_444); -x_395 = x_446; -x_396 = x_445; -goto block_427; +lean_object* x_464; lean_object* x_465; lean_object* x_466; +x_464 = lean_ctor_get(x_460, 0); +lean_inc(x_464); +x_465 = lean_ctor_get(x_460, 1); +lean_inc(x_465); +lean_dec(x_460); +x_466 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_466, 0, x_464); +x_413 = x_466; +x_414 = x_465; +goto block_447; } -block_427: +block_447: { -if (lean_obj_tag(x_395) == 0) +if (lean_obj_tag(x_413) == 0) { -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; lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_411; -x_397 = lean_ctor_get(x_396, 2); -lean_inc(x_397); -x_398 = lean_ctor_get(x_395, 0); -lean_inc(x_398); -lean_dec(x_395); -x_399 = lean_ctor_get(x_396, 0); -lean_inc(x_399); -x_400 = lean_ctor_get(x_396, 1); -lean_inc(x_400); -x_401 = lean_ctor_get(x_396, 3); -lean_inc(x_401); -x_402 = lean_ctor_get(x_396, 4); -lean_inc(x_402); -x_403 = lean_ctor_get(x_396, 5); -lean_inc(x_403); -if (lean_is_exclusive(x_396)) { - lean_ctor_release(x_396, 0); - lean_ctor_release(x_396, 1); - lean_ctor_release(x_396, 2); - lean_ctor_release(x_396, 3); - lean_ctor_release(x_396, 4); - lean_ctor_release(x_396, 5); - x_404 = x_396; -} else { - lean_dec_ref(x_396); - x_404 = lean_box(0); -} -x_405 = lean_ctor_get(x_397, 0); -lean_inc(x_405); -x_406 = lean_ctor_get(x_397, 1); -lean_inc(x_406); -x_407 = lean_ctor_get(x_397, 3); -lean_inc(x_407); -if (lean_is_exclusive(x_397)) { - lean_ctor_release(x_397, 0); - lean_ctor_release(x_397, 1); - lean_ctor_release(x_397, 2); - lean_ctor_release(x_397, 3); - x_408 = x_397; -} else { - lean_dec_ref(x_397); - x_408 = lean_box(0); -} -if (lean_is_scalar(x_408)) { - x_409 = lean_alloc_ctor(0, 4, 0); -} else { - x_409 = x_408; -} -lean_ctor_set(x_409, 0, x_405); -lean_ctor_set(x_409, 1, x_406); -lean_ctor_set(x_409, 2, x_392); -lean_ctor_set(x_409, 3, x_407); -if (lean_is_scalar(x_404)) { - x_410 = lean_alloc_ctor(0, 6, 0); -} else { - x_410 = x_404; -} -lean_ctor_set(x_410, 0, x_399); -lean_ctor_set(x_410, 1, x_400); -lean_ctor_set(x_410, 2, x_409); -lean_ctor_set(x_410, 3, x_401); -lean_ctor_set(x_410, 4, x_402); -lean_ctor_set(x_410, 5, x_403); -if (lean_is_scalar(x_243)) { - x_411 = lean_alloc_ctor(1, 2, 0); -} else { - x_411 = x_243; - lean_ctor_set_tag(x_411, 1); -} -lean_ctor_set(x_411, 0, x_398); -lean_ctor_set(x_411, 1, x_410); -return x_411; -} -else -{ -lean_object* x_412; lean_object* x_413; lean_object* x_414; lean_object* x_415; lean_object* x_416; lean_object* x_417; lean_object* x_418; lean_object* x_419; lean_object* x_420; lean_object* x_421; lean_object* x_422; lean_object* x_423; lean_object* x_424; lean_object* x_425; lean_object* x_426; -x_412 = lean_ctor_get(x_396, 2); -lean_inc(x_412); -x_413 = lean_ctor_get(x_395, 0); -lean_inc(x_413); -lean_dec(x_395); -x_414 = lean_ctor_get(x_396, 0); -lean_inc(x_414); -x_415 = lean_ctor_get(x_396, 1); +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; lean_object* x_426; lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; +x_415 = lean_ctor_get(x_414, 2); lean_inc(x_415); -x_416 = lean_ctor_get(x_396, 3); +x_416 = lean_ctor_get(x_413, 0); lean_inc(x_416); -x_417 = lean_ctor_get(x_396, 4); +lean_dec(x_413); +x_417 = lean_ctor_get(x_414, 0); lean_inc(x_417); -x_418 = lean_ctor_get(x_396, 5); +x_418 = lean_ctor_get(x_414, 1); lean_inc(x_418); -if (lean_is_exclusive(x_396)) { - lean_ctor_release(x_396, 0); - lean_ctor_release(x_396, 1); - lean_ctor_release(x_396, 2); - lean_ctor_release(x_396, 3); - lean_ctor_release(x_396, 4); - lean_ctor_release(x_396, 5); - x_419 = x_396; -} else { - lean_dec_ref(x_396); - x_419 = lean_box(0); -} -x_420 = lean_ctor_get(x_412, 0); +x_419 = lean_ctor_get(x_414, 3); +lean_inc(x_419); +x_420 = lean_ctor_get(x_414, 4); lean_inc(x_420); -x_421 = lean_ctor_get(x_412, 1); +x_421 = lean_ctor_get(x_414, 5); lean_inc(x_421); -x_422 = lean_ctor_get(x_412, 3); -lean_inc(x_422); -if (lean_is_exclusive(x_412)) { - lean_ctor_release(x_412, 0); - lean_ctor_release(x_412, 1); - lean_ctor_release(x_412, 2); - lean_ctor_release(x_412, 3); - x_423 = x_412; +if (lean_is_exclusive(x_414)) { + lean_ctor_release(x_414, 0); + lean_ctor_release(x_414, 1); + lean_ctor_release(x_414, 2); + lean_ctor_release(x_414, 3); + lean_ctor_release(x_414, 4); + lean_ctor_release(x_414, 5); + x_422 = x_414; } else { - lean_dec_ref(x_412); - x_423 = lean_box(0); + lean_dec_ref(x_414); + x_422 = lean_box(0); } -if (lean_is_scalar(x_423)) { - x_424 = lean_alloc_ctor(0, 4, 0); +x_423 = lean_ctor_get(x_415, 0); +lean_inc(x_423); +x_424 = lean_ctor_get(x_415, 1); +lean_inc(x_424); +x_425 = lean_ctor_get(x_415, 3); +lean_inc(x_425); +x_426 = lean_ctor_get(x_415, 4); +lean_inc(x_426); +if (lean_is_exclusive(x_415)) { + lean_ctor_release(x_415, 0); + lean_ctor_release(x_415, 1); + lean_ctor_release(x_415, 2); + lean_ctor_release(x_415, 3); + lean_ctor_release(x_415, 4); + x_427 = x_415; } else { - x_424 = x_423; + lean_dec_ref(x_415); + x_427 = lean_box(0); } -lean_ctor_set(x_424, 0, x_420); -lean_ctor_set(x_424, 1, x_421); -lean_ctor_set(x_424, 2, x_392); -lean_ctor_set(x_424, 3, x_422); -if (lean_is_scalar(x_419)) { - x_425 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_427)) { + x_428 = lean_alloc_ctor(0, 5, 0); } else { - x_425 = x_419; + x_428 = x_427; } -lean_ctor_set(x_425, 0, x_414); -lean_ctor_set(x_425, 1, x_415); -lean_ctor_set(x_425, 2, x_424); -lean_ctor_set(x_425, 3, x_416); -lean_ctor_set(x_425, 4, x_417); -lean_ctor_set(x_425, 5, x_418); -if (lean_is_scalar(x_243)) { - x_426 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_428, 0, x_423); +lean_ctor_set(x_428, 1, x_424); +lean_ctor_set(x_428, 2, x_409); +lean_ctor_set(x_428, 3, x_425); +lean_ctor_set(x_428, 4, x_426); +if (lean_is_scalar(x_422)) { + x_429 = lean_alloc_ctor(0, 6, 0); } else { - x_426 = x_243; + x_429 = x_422; } -lean_ctor_set(x_426, 0, x_413); -lean_ctor_set(x_426, 1, x_425); -return x_426; +lean_ctor_set(x_429, 0, x_417); +lean_ctor_set(x_429, 1, x_418); +lean_ctor_set(x_429, 2, x_428); +lean_ctor_set(x_429, 3, x_419); +lean_ctor_set(x_429, 4, x_420); +lean_ctor_set(x_429, 5, x_421); +if (lean_is_scalar(x_253)) { + x_430 = lean_alloc_ctor(1, 2, 0); +} else { + x_430 = x_253; + lean_ctor_set_tag(x_430, 1); +} +lean_ctor_set(x_430, 0, x_416); +lean_ctor_set(x_430, 1, x_429); +return x_430; +} +else +{ +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; lean_object* x_445; lean_object* x_446; +x_431 = lean_ctor_get(x_414, 2); +lean_inc(x_431); +x_432 = lean_ctor_get(x_413, 0); +lean_inc(x_432); +lean_dec(x_413); +x_433 = lean_ctor_get(x_414, 0); +lean_inc(x_433); +x_434 = lean_ctor_get(x_414, 1); +lean_inc(x_434); +x_435 = lean_ctor_get(x_414, 3); +lean_inc(x_435); +x_436 = lean_ctor_get(x_414, 4); +lean_inc(x_436); +x_437 = lean_ctor_get(x_414, 5); +lean_inc(x_437); +if (lean_is_exclusive(x_414)) { + lean_ctor_release(x_414, 0); + lean_ctor_release(x_414, 1); + lean_ctor_release(x_414, 2); + lean_ctor_release(x_414, 3); + lean_ctor_release(x_414, 4); + lean_ctor_release(x_414, 5); + x_438 = x_414; +} else { + lean_dec_ref(x_414); + x_438 = lean_box(0); +} +x_439 = lean_ctor_get(x_431, 0); +lean_inc(x_439); +x_440 = lean_ctor_get(x_431, 1); +lean_inc(x_440); +x_441 = lean_ctor_get(x_431, 3); +lean_inc(x_441); +x_442 = lean_ctor_get(x_431, 4); +lean_inc(x_442); +if (lean_is_exclusive(x_431)) { + lean_ctor_release(x_431, 0); + lean_ctor_release(x_431, 1); + lean_ctor_release(x_431, 2); + lean_ctor_release(x_431, 3); + lean_ctor_release(x_431, 4); + x_443 = x_431; +} else { + lean_dec_ref(x_431); + x_443 = lean_box(0); +} +if (lean_is_scalar(x_443)) { + x_444 = lean_alloc_ctor(0, 5, 0); +} else { + x_444 = x_443; +} +lean_ctor_set(x_444, 0, x_439); +lean_ctor_set(x_444, 1, x_440); +lean_ctor_set(x_444, 2, x_409); +lean_ctor_set(x_444, 3, x_441); +lean_ctor_set(x_444, 4, x_442); +if (lean_is_scalar(x_438)) { + x_445 = lean_alloc_ctor(0, 6, 0); +} else { + x_445 = x_438; +} +lean_ctor_set(x_445, 0, x_433); +lean_ctor_set(x_445, 1, x_434); +lean_ctor_set(x_445, 2, x_444); +lean_ctor_set(x_445, 3, x_435); +lean_ctor_set(x_445, 4, x_436); +lean_ctor_set(x_445, 5, x_437); +if (lean_is_scalar(x_253)) { + x_446 = lean_alloc_ctor(0, 2, 0); +} else { + x_446 = x_253; +} +lean_ctor_set(x_446, 0, x_432); +lean_ctor_set(x_446, 1, x_445); +return x_446; } } } @@ -6506,7 +6665,7 @@ return x_426; } else { -uint8_t x_447; +uint8_t x_467; lean_dec(x_19); lean_dec(x_11); lean_dec(x_10); @@ -6515,23 +6674,23 @@ lean_dec(x_7); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_447 = !lean_is_exclusive(x_236); -if (x_447 == 0) +x_467 = !lean_is_exclusive(x_246); +if (x_467 == 0) { -return x_236; +return x_246; } else { -lean_object* x_448; lean_object* x_449; lean_object* x_450; -x_448 = lean_ctor_get(x_236, 0); -x_449 = lean_ctor_get(x_236, 1); -lean_inc(x_449); -lean_inc(x_448); -lean_dec(x_236); -x_450 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_450, 0, x_448); -lean_ctor_set(x_450, 1, x_449); -return x_450; +lean_object* x_468; lean_object* x_469; lean_object* x_470; +x_468 = lean_ctor_get(x_246, 0); +x_469 = lean_ctor_get(x_246, 1); +lean_inc(x_469); +lean_inc(x_468); +lean_dec(x_246); +x_470 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_470, 0, x_468); +lean_ctor_set(x_470, 1, x_469); +return x_470; } } } @@ -6539,7 +6698,7 @@ return x_450; } else { -uint8_t x_451; +uint8_t x_471; lean_dec(x_23); lean_dec(x_19); lean_dec(x_11); @@ -6549,29 +6708,29 @@ lean_dec(x_7); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_451 = !lean_is_exclusive(x_24); -if (x_451 == 0) +x_471 = !lean_is_exclusive(x_24); +if (x_471 == 0) { return x_24; } else { -lean_object* x_452; lean_object* x_453; lean_object* x_454; -x_452 = lean_ctor_get(x_24, 0); -x_453 = lean_ctor_get(x_24, 1); -lean_inc(x_453); -lean_inc(x_452); +lean_object* x_472; lean_object* x_473; lean_object* x_474; +x_472 = lean_ctor_get(x_24, 0); +x_473 = lean_ctor_get(x_24, 1); +lean_inc(x_473); +lean_inc(x_472); lean_dec(x_24); -x_454 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_454, 0, x_452); -lean_ctor_set(x_454, 1, x_453); -return x_454; +x_474 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_474, 0, x_472); +lean_ctor_set(x_474, 1, x_473); +return x_474; } } } else { -uint8_t x_455; +uint8_t x_475; lean_dec(x_19); lean_dec(x_11); lean_dec(x_10); @@ -6580,23 +6739,23 @@ lean_dec(x_7); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_455 = !lean_is_exclusive(x_20); -if (x_455 == 0) +x_475 = !lean_is_exclusive(x_20); +if (x_475 == 0) { return x_20; } else { -lean_object* x_456; lean_object* x_457; lean_object* x_458; -x_456 = lean_ctor_get(x_20, 0); -x_457 = lean_ctor_get(x_20, 1); -lean_inc(x_457); -lean_inc(x_456); +lean_object* x_476; lean_object* x_477; lean_object* x_478; +x_476 = lean_ctor_get(x_20, 0); +x_477 = lean_ctor_get(x_20, 1); +lean_inc(x_477); +lean_inc(x_476); lean_dec(x_20); -x_458 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_458, 0, x_456); -lean_ctor_set(x_458, 1, x_457); -return x_458; +x_478 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_478, 0, x_476); +lean_ctor_set(x_478, 1, x_477); +return x_478; } } } @@ -6743,105 +6902,105 @@ x_44 = lean_ctor_get(x_38, 2); x_45 = !lean_is_exclusive(x_44); if (x_45 == 0) { -lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_98; uint8_t x_99; +lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_102; uint8_t x_103; x_46 = lean_ctor_get(x_44, 2); -x_98 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_44, 2, x_98); -x_99 = !lean_is_exclusive(x_6); -if (x_99 == 0) +x_102 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_44, 2, x_102); +x_103 = !lean_is_exclusive(x_6); +if (x_103 == 0) { -lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; -x_100 = lean_ctor_get(x_6, 2); -x_101 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_101, 0, x_40); -lean_ctor_set(x_101, 1, x_27); -x_102 = lean_array_push(x_100, x_101); -lean_ctor_set(x_6, 2, x_102); -x_103 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__6(x_1, x_2, x_3, x_4, x_42, x_6, x_38); -if (lean_obj_tag(x_103) == 0) +lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; +x_104 = lean_ctor_get(x_6, 2); +x_105 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_105, 0, x_40); +lean_ctor_set(x_105, 1, x_27); +x_106 = lean_array_push(x_104, x_105); +lean_ctor_set(x_6, 2, x_106); +x_107 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__6(x_1, x_2, x_3, x_4, x_42, x_6, x_38); +if (lean_obj_tag(x_107) == 0) { -lean_object* x_104; lean_object* x_105; lean_object* x_106; -x_104 = lean_ctor_get(x_103, 0); -lean_inc(x_104); -x_105 = lean_ctor_get(x_103, 1); -lean_inc(x_105); -lean_dec(x_103); -x_106 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_106, 0, x_104); -x_47 = x_106; -x_48 = x_105; -goto block_97; -} -else -{ -lean_object* x_107; lean_object* x_108; lean_object* x_109; -x_107 = lean_ctor_get(x_103, 0); -lean_inc(x_107); -x_108 = lean_ctor_get(x_103, 1); +lean_object* x_108; lean_object* x_109; lean_object* x_110; +x_108 = lean_ctor_get(x_107, 0); lean_inc(x_108); -lean_dec(x_103); -x_109 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_109, 0, x_107); -x_47 = x_109; -x_48 = x_108; -goto block_97; -} +x_109 = lean_ctor_get(x_107, 1); +lean_inc(x_109); +lean_dec(x_107); +x_110 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_110, 0, x_108); +x_47 = x_110; +x_48 = x_109; +goto block_101; } else { -lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; -x_110 = lean_ctor_get(x_6, 0); -x_111 = lean_ctor_get(x_6, 1); -x_112 = lean_ctor_get(x_6, 2); -x_113 = lean_ctor_get(x_6, 3); -x_114 = lean_ctor_get(x_6, 4); -lean_inc(x_114); -lean_inc(x_113); -lean_inc(x_112); +lean_object* x_111; lean_object* x_112; lean_object* x_113; +x_111 = lean_ctor_get(x_107, 0); lean_inc(x_111); -lean_inc(x_110); -lean_dec(x_6); -x_115 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_115, 0, x_40); -lean_ctor_set(x_115, 1, x_27); -x_116 = lean_array_push(x_112, x_115); -x_117 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_117, 0, x_110); -lean_ctor_set(x_117, 1, x_111); -lean_ctor_set(x_117, 2, x_116); -lean_ctor_set(x_117, 3, x_113); -lean_ctor_set(x_117, 4, x_114); -x_118 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__6(x_1, x_2, x_3, x_4, x_42, x_117, x_38); -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); -x_121 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_121, 0, x_119); -x_47 = x_121; -x_48 = x_120; -goto block_97; +x_112 = lean_ctor_get(x_107, 1); +lean_inc(x_112); +lean_dec(x_107); +x_113 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_113, 0, x_111); +x_47 = x_113; +x_48 = x_112; +goto block_101; +} } else { -lean_object* x_122; lean_object* x_123; lean_object* x_124; -x_122 = lean_ctor_get(x_118, 0); -lean_inc(x_122); -x_123 = lean_ctor_get(x_118, 1); +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; +x_114 = lean_ctor_get(x_6, 0); +x_115 = lean_ctor_get(x_6, 1); +x_116 = lean_ctor_get(x_6, 2); +x_117 = lean_ctor_get(x_6, 3); +x_118 = lean_ctor_get(x_6, 4); +lean_inc(x_118); +lean_inc(x_117); +lean_inc(x_116); +lean_inc(x_115); +lean_inc(x_114); +lean_dec(x_6); +x_119 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_119, 0, x_40); +lean_ctor_set(x_119, 1, x_27); +x_120 = lean_array_push(x_116, x_119); +x_121 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_121, 0, x_114); +lean_ctor_set(x_121, 1, x_115); +lean_ctor_set(x_121, 2, x_120); +lean_ctor_set(x_121, 3, x_117); +lean_ctor_set(x_121, 4, x_118); +x_122 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__6(x_1, x_2, x_3, x_4, x_42, x_121, x_38); +if (lean_obj_tag(x_122) == 0) +{ +lean_object* x_123; lean_object* x_124; lean_object* x_125; +x_123 = lean_ctor_get(x_122, 0); lean_inc(x_123); -lean_dec(x_118); -x_124 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_124, 0, x_122); -x_47 = x_124; -x_48 = x_123; -goto block_97; +x_124 = lean_ctor_get(x_122, 1); +lean_inc(x_124); +lean_dec(x_122); +x_125 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_125, 0, x_123); +x_47 = x_125; +x_48 = x_124; +goto block_101; +} +else +{ +lean_object* x_126; lean_object* x_127; lean_object* x_128; +x_126 = lean_ctor_get(x_122, 0); +lean_inc(x_126); +x_127 = lean_ctor_get(x_122, 1); +lean_inc(x_127); +lean_dec(x_122); +x_128 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_128, 0, x_126); +x_47 = x_128; +x_48 = x_127; +goto block_101; } } -block_97: +block_101: { if (lean_obj_tag(x_47) == 0) { @@ -6876,1284 +7035,1262 @@ return x_55; } else { -lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; +lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; x_56 = lean_ctor_get(x_49, 0); x_57 = lean_ctor_get(x_49, 1); x_58 = lean_ctor_get(x_49, 3); +x_59 = lean_ctor_get(x_49, 4); +lean_inc(x_59); lean_inc(x_58); lean_inc(x_57); lean_inc(x_56); lean_dec(x_49); -x_59 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_59, 0, x_56); -lean_ctor_set(x_59, 1, x_57); -lean_ctor_set(x_59, 2, x_46); -lean_ctor_set(x_59, 3, x_58); -lean_ctor_set(x_48, 2, x_59); +x_60 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_60, 0, x_56); +lean_ctor_set(x_60, 1, x_57); +lean_ctor_set(x_60, 2, x_46); +lean_ctor_set(x_60, 3, x_58); +lean_ctor_set(x_60, 4, x_59); +lean_ctor_set(x_48, 2, x_60); if (lean_is_scalar(x_39)) { - x_60 = lean_alloc_ctor(1, 2, 0); + x_61 = lean_alloc_ctor(1, 2, 0); } else { - x_60 = x_39; - lean_ctor_set_tag(x_60, 1); + x_61 = x_39; + lean_ctor_set_tag(x_61, 1); } -lean_ctor_set(x_60, 0, x_50); -lean_ctor_set(x_60, 1, x_48); -return x_60; +lean_ctor_set(x_61, 0, x_50); +lean_ctor_set(x_61, 1, x_48); +return x_61; } } else { -lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; -x_61 = lean_ctor_get(x_48, 0); -x_62 = lean_ctor_get(x_48, 1); -x_63 = lean_ctor_get(x_48, 3); -x_64 = lean_ctor_get(x_48, 4); -x_65 = lean_ctor_get(x_48, 5); +lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; +x_62 = lean_ctor_get(x_48, 0); +x_63 = lean_ctor_get(x_48, 1); +x_64 = lean_ctor_get(x_48, 3); +x_65 = lean_ctor_get(x_48, 4); +x_66 = lean_ctor_get(x_48, 5); +lean_inc(x_66); lean_inc(x_65); lean_inc(x_64); lean_inc(x_63); lean_inc(x_62); -lean_inc(x_61); lean_dec(x_48); -x_66 = lean_ctor_get(x_49, 0); -lean_inc(x_66); -x_67 = lean_ctor_get(x_49, 1); +x_67 = lean_ctor_get(x_49, 0); lean_inc(x_67); -x_68 = lean_ctor_get(x_49, 3); +x_68 = lean_ctor_get(x_49, 1); lean_inc(x_68); +x_69 = lean_ctor_get(x_49, 3); +lean_inc(x_69); +x_70 = lean_ctor_get(x_49, 4); +lean_inc(x_70); if (lean_is_exclusive(x_49)) { lean_ctor_release(x_49, 0); lean_ctor_release(x_49, 1); lean_ctor_release(x_49, 2); lean_ctor_release(x_49, 3); - x_69 = x_49; + lean_ctor_release(x_49, 4); + x_71 = x_49; } else { lean_dec_ref(x_49); - x_69 = lean_box(0); + x_71 = lean_box(0); } -if (lean_is_scalar(x_69)) { - x_70 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_71)) { + x_72 = lean_alloc_ctor(0, 5, 0); } else { - x_70 = x_69; + x_72 = x_71; } -lean_ctor_set(x_70, 0, x_66); -lean_ctor_set(x_70, 1, x_67); -lean_ctor_set(x_70, 2, x_46); -lean_ctor_set(x_70, 3, x_68); -x_71 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_71, 0, x_61); -lean_ctor_set(x_71, 1, x_62); -lean_ctor_set(x_71, 2, x_70); -lean_ctor_set(x_71, 3, x_63); -lean_ctor_set(x_71, 4, x_64); -lean_ctor_set(x_71, 5, x_65); +lean_ctor_set(x_72, 0, x_67); +lean_ctor_set(x_72, 1, x_68); +lean_ctor_set(x_72, 2, x_46); +lean_ctor_set(x_72, 3, x_69); +lean_ctor_set(x_72, 4, x_70); +x_73 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_73, 0, x_62); +lean_ctor_set(x_73, 1, x_63); +lean_ctor_set(x_73, 2, x_72); +lean_ctor_set(x_73, 3, x_64); +lean_ctor_set(x_73, 4, x_65); +lean_ctor_set(x_73, 5, x_66); if (lean_is_scalar(x_39)) { - x_72 = lean_alloc_ctor(1, 2, 0); + x_74 = lean_alloc_ctor(1, 2, 0); } else { - x_72 = x_39; - lean_ctor_set_tag(x_72, 1); + x_74 = x_39; + lean_ctor_set_tag(x_74, 1); } -lean_ctor_set(x_72, 0, x_50); -lean_ctor_set(x_72, 1, x_71); -return x_72; +lean_ctor_set(x_74, 0, x_50); +lean_ctor_set(x_74, 1, x_73); +return x_74; } } else { -lean_object* x_73; lean_object* x_74; uint8_t x_75; -x_73 = lean_ctor_get(x_48, 2); -lean_inc(x_73); -x_74 = lean_ctor_get(x_47, 0); -lean_inc(x_74); +lean_object* x_75; lean_object* x_76; uint8_t x_77; +x_75 = lean_ctor_get(x_48, 2); +lean_inc(x_75); +x_76 = lean_ctor_get(x_47, 0); +lean_inc(x_76); lean_dec(x_47); -x_75 = !lean_is_exclusive(x_48); -if (x_75 == 0) -{ -lean_object* x_76; uint8_t x_77; -x_76 = lean_ctor_get(x_48, 2); -lean_dec(x_76); -x_77 = !lean_is_exclusive(x_73); +x_77 = !lean_is_exclusive(x_48); if (x_77 == 0) { -lean_object* x_78; lean_object* x_79; -x_78 = lean_ctor_get(x_73, 2); +lean_object* x_78; uint8_t x_79; +x_78 = lean_ctor_get(x_48, 2); lean_dec(x_78); -lean_ctor_set(x_73, 2, x_46); +x_79 = !lean_is_exclusive(x_75); +if (x_79 == 0) +{ +lean_object* x_80; lean_object* x_81; +x_80 = lean_ctor_get(x_75, 2); +lean_dec(x_80); +lean_ctor_set(x_75, 2, x_46); if (lean_is_scalar(x_39)) { - x_79 = lean_alloc_ctor(0, 2, 0); + x_81 = lean_alloc_ctor(0, 2, 0); } else { - x_79 = x_39; + x_81 = x_39; } -lean_ctor_set(x_79, 0, x_74); -lean_ctor_set(x_79, 1, x_48); -return x_79; +lean_ctor_set(x_81, 0, x_76); +lean_ctor_set(x_81, 1, x_48); +return x_81; } else { -lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; -x_80 = lean_ctor_get(x_73, 0); -x_81 = lean_ctor_get(x_73, 1); -x_82 = lean_ctor_get(x_73, 3); +lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; +x_82 = lean_ctor_get(x_75, 0); +x_83 = lean_ctor_get(x_75, 1); +x_84 = lean_ctor_get(x_75, 3); +x_85 = lean_ctor_get(x_75, 4); +lean_inc(x_85); +lean_inc(x_84); +lean_inc(x_83); lean_inc(x_82); -lean_inc(x_81); -lean_inc(x_80); -lean_dec(x_73); -x_83 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_83, 0, x_80); -lean_ctor_set(x_83, 1, x_81); -lean_ctor_set(x_83, 2, x_46); -lean_ctor_set(x_83, 3, x_82); -lean_ctor_set(x_48, 2, x_83); +lean_dec(x_75); +x_86 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_86, 0, x_82); +lean_ctor_set(x_86, 1, x_83); +lean_ctor_set(x_86, 2, x_46); +lean_ctor_set(x_86, 3, x_84); +lean_ctor_set(x_86, 4, x_85); +lean_ctor_set(x_48, 2, x_86); if (lean_is_scalar(x_39)) { - x_84 = lean_alloc_ctor(0, 2, 0); + x_87 = lean_alloc_ctor(0, 2, 0); } else { - x_84 = x_39; + x_87 = x_39; } -lean_ctor_set(x_84, 0, x_74); -lean_ctor_set(x_84, 1, x_48); -return x_84; +lean_ctor_set(x_87, 0, x_76); +lean_ctor_set(x_87, 1, x_48); +return x_87; } } else { -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; -x_85 = lean_ctor_get(x_48, 0); -x_86 = lean_ctor_get(x_48, 1); -x_87 = lean_ctor_get(x_48, 3); -x_88 = lean_ctor_get(x_48, 4); -x_89 = lean_ctor_get(x_48, 5); +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; +x_88 = lean_ctor_get(x_48, 0); +x_89 = lean_ctor_get(x_48, 1); +x_90 = lean_ctor_get(x_48, 3); +x_91 = lean_ctor_get(x_48, 4); +x_92 = lean_ctor_get(x_48, 5); +lean_inc(x_92); +lean_inc(x_91); +lean_inc(x_90); lean_inc(x_89); lean_inc(x_88); -lean_inc(x_87); -lean_inc(x_86); -lean_inc(x_85); lean_dec(x_48); -x_90 = lean_ctor_get(x_73, 0); -lean_inc(x_90); -x_91 = lean_ctor_get(x_73, 1); -lean_inc(x_91); -x_92 = lean_ctor_get(x_73, 3); -lean_inc(x_92); -if (lean_is_exclusive(x_73)) { - lean_ctor_release(x_73, 0); - lean_ctor_release(x_73, 1); - lean_ctor_release(x_73, 2); - lean_ctor_release(x_73, 3); - x_93 = x_73; +x_93 = lean_ctor_get(x_75, 0); +lean_inc(x_93); +x_94 = lean_ctor_get(x_75, 1); +lean_inc(x_94); +x_95 = lean_ctor_get(x_75, 3); +lean_inc(x_95); +x_96 = lean_ctor_get(x_75, 4); +lean_inc(x_96); +if (lean_is_exclusive(x_75)) { + lean_ctor_release(x_75, 0); + lean_ctor_release(x_75, 1); + lean_ctor_release(x_75, 2); + lean_ctor_release(x_75, 3); + lean_ctor_release(x_75, 4); + x_97 = x_75; } else { - lean_dec_ref(x_73); - x_93 = lean_box(0); + lean_dec_ref(x_75); + x_97 = lean_box(0); } -if (lean_is_scalar(x_93)) { - x_94 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_97)) { + x_98 = lean_alloc_ctor(0, 5, 0); } else { - x_94 = x_93; + x_98 = x_97; } -lean_ctor_set(x_94, 0, x_90); -lean_ctor_set(x_94, 1, x_91); -lean_ctor_set(x_94, 2, x_46); -lean_ctor_set(x_94, 3, x_92); -x_95 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_95, 0, x_85); -lean_ctor_set(x_95, 1, x_86); -lean_ctor_set(x_95, 2, x_94); -lean_ctor_set(x_95, 3, x_87); -lean_ctor_set(x_95, 4, x_88); -lean_ctor_set(x_95, 5, x_89); +lean_ctor_set(x_98, 0, x_93); +lean_ctor_set(x_98, 1, x_94); +lean_ctor_set(x_98, 2, x_46); +lean_ctor_set(x_98, 3, x_95); +lean_ctor_set(x_98, 4, x_96); +x_99 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_99, 0, x_88); +lean_ctor_set(x_99, 1, x_89); +lean_ctor_set(x_99, 2, x_98); +lean_ctor_set(x_99, 3, x_90); +lean_ctor_set(x_99, 4, x_91); +lean_ctor_set(x_99, 5, x_92); if (lean_is_scalar(x_39)) { - x_96 = lean_alloc_ctor(0, 2, 0); + x_100 = lean_alloc_ctor(0, 2, 0); } else { - x_96 = x_39; + x_100 = x_39; } -lean_ctor_set(x_96, 0, x_74); -lean_ctor_set(x_96, 1, x_95); -return x_96; +lean_ctor_set(x_100, 0, x_76); +lean_ctor_set(x_100, 1, x_99); +return x_100; } } } } else { -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_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; lean_object* x_173; -x_125 = lean_ctor_get(x_44, 0); -x_126 = lean_ctor_get(x_44, 1); -x_127 = lean_ctor_get(x_44, 2); -x_128 = lean_ctor_get(x_44, 3); -lean_inc(x_128); -lean_inc(x_127); -lean_inc(x_126); -lean_inc(x_125); -lean_dec(x_44); -x_162 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_163 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_163, 0, x_125); -lean_ctor_set(x_163, 1, x_126); -lean_ctor_set(x_163, 2, x_162); -lean_ctor_set(x_163, 3, x_128); -lean_ctor_set(x_38, 2, x_163); -x_164 = lean_ctor_get(x_6, 0); -lean_inc(x_164); -x_165 = lean_ctor_get(x_6, 1); -lean_inc(x_165); -x_166 = lean_ctor_get(x_6, 2); -lean_inc(x_166); -x_167 = lean_ctor_get(x_6, 3); -lean_inc(x_167); -x_168 = lean_ctor_get(x_6, 4); -lean_inc(x_168); -if (lean_is_exclusive(x_6)) { - lean_ctor_release(x_6, 0); - lean_ctor_release(x_6, 1); - lean_ctor_release(x_6, 2); - lean_ctor_release(x_6, 3); - lean_ctor_release(x_6, 4); - x_169 = x_6; -} else { - lean_dec_ref(x_6); - x_169 = lean_box(0); -} -x_170 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_170, 0, x_40); -lean_ctor_set(x_170, 1, x_27); -x_171 = lean_array_push(x_166, x_170); -if (lean_is_scalar(x_169)) { - x_172 = lean_alloc_ctor(0, 5, 0); -} else { - x_172 = x_169; -} -lean_ctor_set(x_172, 0, x_164); -lean_ctor_set(x_172, 1, x_165); -lean_ctor_set(x_172, 2, x_171); -lean_ctor_set(x_172, 3, x_167); -lean_ctor_set(x_172, 4, x_168); -x_173 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__6(x_1, x_2, x_3, x_4, x_42, x_172, x_38); -if (lean_obj_tag(x_173) == 0) -{ -lean_object* x_174; lean_object* x_175; lean_object* x_176; -x_174 = lean_ctor_get(x_173, 0); -lean_inc(x_174); -x_175 = lean_ctor_get(x_173, 1); -lean_inc(x_175); -lean_dec(x_173); -x_176 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_176, 0, x_174); -x_129 = x_176; -x_130 = x_175; -goto block_161; -} -else -{ -lean_object* x_177; lean_object* x_178; lean_object* x_179; -x_177 = lean_ctor_get(x_173, 0); -lean_inc(x_177); -x_178 = lean_ctor_get(x_173, 1); -lean_inc(x_178); -lean_dec(x_173); -x_179 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_179, 0, x_177); -x_129 = x_179; -x_130 = x_178; -goto block_161; -} -block_161: -{ -if (lean_obj_tag(x_129) == 0) -{ -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_131 = lean_ctor_get(x_130, 2); -lean_inc(x_131); -x_132 = lean_ctor_get(x_129, 0); -lean_inc(x_132); -lean_dec(x_129); -x_133 = lean_ctor_get(x_130, 0); +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_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; lean_object* x_180; +x_129 = lean_ctor_get(x_44, 0); +x_130 = lean_ctor_get(x_44, 1); +x_131 = lean_ctor_get(x_44, 2); +x_132 = lean_ctor_get(x_44, 3); +x_133 = lean_ctor_get(x_44, 4); lean_inc(x_133); -x_134 = lean_ctor_get(x_130, 1); -lean_inc(x_134); -x_135 = lean_ctor_get(x_130, 3); -lean_inc(x_135); -x_136 = lean_ctor_get(x_130, 4); -lean_inc(x_136); -x_137 = lean_ctor_get(x_130, 5); -lean_inc(x_137); -if (lean_is_exclusive(x_130)) { - lean_ctor_release(x_130, 0); - lean_ctor_release(x_130, 1); - lean_ctor_release(x_130, 2); - lean_ctor_release(x_130, 3); - lean_ctor_release(x_130, 4); - lean_ctor_release(x_130, 5); - x_138 = x_130; -} else { - lean_dec_ref(x_130); - x_138 = lean_box(0); -} -x_139 = lean_ctor_get(x_131, 0); -lean_inc(x_139); -x_140 = lean_ctor_get(x_131, 1); -lean_inc(x_140); -x_141 = lean_ctor_get(x_131, 3); -lean_inc(x_141); -if (lean_is_exclusive(x_131)) { - lean_ctor_release(x_131, 0); - lean_ctor_release(x_131, 1); - lean_ctor_release(x_131, 2); - lean_ctor_release(x_131, 3); - x_142 = x_131; -} else { - lean_dec_ref(x_131); - x_142 = lean_box(0); -} -if (lean_is_scalar(x_142)) { - x_143 = lean_alloc_ctor(0, 4, 0); -} else { - x_143 = x_142; -} -lean_ctor_set(x_143, 0, x_139); -lean_ctor_set(x_143, 1, x_140); -lean_ctor_set(x_143, 2, x_127); -lean_ctor_set(x_143, 3, x_141); -if (lean_is_scalar(x_138)) { - x_144 = lean_alloc_ctor(0, 6, 0); -} else { - x_144 = x_138; -} -lean_ctor_set(x_144, 0, x_133); -lean_ctor_set(x_144, 1, x_134); -lean_ctor_set(x_144, 2, x_143); -lean_ctor_set(x_144, 3, x_135); -lean_ctor_set(x_144, 4, x_136); -lean_ctor_set(x_144, 5, x_137); -if (lean_is_scalar(x_39)) { - x_145 = lean_alloc_ctor(1, 2, 0); -} else { - x_145 = x_39; - lean_ctor_set_tag(x_145, 1); -} -lean_ctor_set(x_145, 0, x_132); -lean_ctor_set(x_145, 1, x_144); -return x_145; -} -else -{ -lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; -x_146 = lean_ctor_get(x_130, 2); -lean_inc(x_146); -x_147 = lean_ctor_get(x_129, 0); -lean_inc(x_147); -lean_dec(x_129); -x_148 = lean_ctor_get(x_130, 0); -lean_inc(x_148); -x_149 = lean_ctor_get(x_130, 1); -lean_inc(x_149); -x_150 = lean_ctor_get(x_130, 3); -lean_inc(x_150); -x_151 = lean_ctor_get(x_130, 4); -lean_inc(x_151); -x_152 = lean_ctor_get(x_130, 5); -lean_inc(x_152); -if (lean_is_exclusive(x_130)) { - lean_ctor_release(x_130, 0); - lean_ctor_release(x_130, 1); - lean_ctor_release(x_130, 2); - lean_ctor_release(x_130, 3); - lean_ctor_release(x_130, 4); - lean_ctor_release(x_130, 5); - x_153 = x_130; -} else { - lean_dec_ref(x_130); - x_153 = lean_box(0); -} -x_154 = lean_ctor_get(x_146, 0); -lean_inc(x_154); -x_155 = lean_ctor_get(x_146, 1); -lean_inc(x_155); -x_156 = lean_ctor_get(x_146, 3); -lean_inc(x_156); -if (lean_is_exclusive(x_146)) { - lean_ctor_release(x_146, 0); - lean_ctor_release(x_146, 1); - lean_ctor_release(x_146, 2); - lean_ctor_release(x_146, 3); - x_157 = x_146; -} else { - lean_dec_ref(x_146); - x_157 = lean_box(0); -} -if (lean_is_scalar(x_157)) { - x_158 = lean_alloc_ctor(0, 4, 0); -} else { - x_158 = x_157; -} -lean_ctor_set(x_158, 0, x_154); -lean_ctor_set(x_158, 1, x_155); -lean_ctor_set(x_158, 2, x_127); -lean_ctor_set(x_158, 3, x_156); -if (lean_is_scalar(x_153)) { - x_159 = lean_alloc_ctor(0, 6, 0); -} else { - x_159 = x_153; -} -lean_ctor_set(x_159, 0, x_148); -lean_ctor_set(x_159, 1, x_149); -lean_ctor_set(x_159, 2, x_158); -lean_ctor_set(x_159, 3, x_150); -lean_ctor_set(x_159, 4, x_151); -lean_ctor_set(x_159, 5, x_152); -if (lean_is_scalar(x_39)) { - x_160 = lean_alloc_ctor(0, 2, 0); -} else { - x_160 = x_39; -} -lean_ctor_set(x_160, 0, x_147); -lean_ctor_set(x_160, 1, x_159); -return x_160; -} -} -} -} -else -{ -lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; 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_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; lean_object* x_231; lean_object* x_232; lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_object* x_236; -x_180 = lean_ctor_get(x_38, 2); -x_181 = lean_ctor_get(x_38, 0); -x_182 = lean_ctor_get(x_38, 1); -x_183 = lean_ctor_get(x_38, 3); -x_184 = lean_ctor_get(x_38, 4); -x_185 = lean_ctor_get(x_38, 5); -lean_inc(x_185); -lean_inc(x_184); -lean_inc(x_183); -lean_inc(x_180); -lean_inc(x_182); -lean_inc(x_181); -lean_dec(x_38); -x_186 = lean_ctor_get(x_180, 0); -lean_inc(x_186); -x_187 = lean_ctor_get(x_180, 1); -lean_inc(x_187); -x_188 = lean_ctor_get(x_180, 2); -lean_inc(x_188); -x_189 = lean_ctor_get(x_180, 3); -lean_inc(x_189); -if (lean_is_exclusive(x_180)) { - lean_ctor_release(x_180, 0); - lean_ctor_release(x_180, 1); - lean_ctor_release(x_180, 2); - lean_ctor_release(x_180, 3); - x_190 = x_180; -} else { - lean_dec_ref(x_180); - x_190 = lean_box(0); -} -x_224 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_190)) { - x_225 = lean_alloc_ctor(0, 4, 0); -} else { - x_225 = x_190; -} -lean_ctor_set(x_225, 0, x_186); -lean_ctor_set(x_225, 1, x_187); -lean_ctor_set(x_225, 2, x_224); -lean_ctor_set(x_225, 3, x_189); -x_226 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_226, 0, x_181); -lean_ctor_set(x_226, 1, x_182); -lean_ctor_set(x_226, 2, x_225); -lean_ctor_set(x_226, 3, x_183); -lean_ctor_set(x_226, 4, x_184); -lean_ctor_set(x_226, 5, x_185); -x_227 = lean_ctor_get(x_6, 0); -lean_inc(x_227); -x_228 = lean_ctor_get(x_6, 1); -lean_inc(x_228); -x_229 = lean_ctor_get(x_6, 2); -lean_inc(x_229); -x_230 = lean_ctor_get(x_6, 3); -lean_inc(x_230); -x_231 = lean_ctor_get(x_6, 4); -lean_inc(x_231); +lean_inc(x_132); +lean_inc(x_131); +lean_inc(x_130); +lean_inc(x_129); +lean_dec(x_44); +x_169 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_170 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_170, 0, x_129); +lean_ctor_set(x_170, 1, x_130); +lean_ctor_set(x_170, 2, x_169); +lean_ctor_set(x_170, 3, x_132); +lean_ctor_set(x_170, 4, x_133); +lean_ctor_set(x_38, 2, x_170); +x_171 = lean_ctor_get(x_6, 0); +lean_inc(x_171); +x_172 = lean_ctor_get(x_6, 1); +lean_inc(x_172); +x_173 = lean_ctor_get(x_6, 2); +lean_inc(x_173); +x_174 = lean_ctor_get(x_6, 3); +lean_inc(x_174); +x_175 = lean_ctor_get(x_6, 4); +lean_inc(x_175); if (lean_is_exclusive(x_6)) { lean_ctor_release(x_6, 0); lean_ctor_release(x_6, 1); lean_ctor_release(x_6, 2); lean_ctor_release(x_6, 3); lean_ctor_release(x_6, 4); - x_232 = x_6; + x_176 = x_6; } else { lean_dec_ref(x_6); - x_232 = lean_box(0); + x_176 = lean_box(0); } -x_233 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_233, 0, x_40); -lean_ctor_set(x_233, 1, x_27); -x_234 = lean_array_push(x_229, x_233); -if (lean_is_scalar(x_232)) { +x_177 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_177, 0, x_40); +lean_ctor_set(x_177, 1, x_27); +x_178 = lean_array_push(x_173, x_177); +if (lean_is_scalar(x_176)) { + x_179 = lean_alloc_ctor(0, 5, 0); +} else { + x_179 = x_176; +} +lean_ctor_set(x_179, 0, x_171); +lean_ctor_set(x_179, 1, x_172); +lean_ctor_set(x_179, 2, x_178); +lean_ctor_set(x_179, 3, x_174); +lean_ctor_set(x_179, 4, x_175); +x_180 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__6(x_1, x_2, x_3, x_4, x_42, x_179, x_38); +if (lean_obj_tag(x_180) == 0) +{ +lean_object* x_181; lean_object* x_182; lean_object* x_183; +x_181 = lean_ctor_get(x_180, 0); +lean_inc(x_181); +x_182 = lean_ctor_get(x_180, 1); +lean_inc(x_182); +lean_dec(x_180); +x_183 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_183, 0, x_181); +x_134 = x_183; +x_135 = x_182; +goto block_168; +} +else +{ +lean_object* x_184; lean_object* x_185; lean_object* x_186; +x_184 = lean_ctor_get(x_180, 0); +lean_inc(x_184); +x_185 = lean_ctor_get(x_180, 1); +lean_inc(x_185); +lean_dec(x_180); +x_186 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_186, 0, x_184); +x_134 = x_186; +x_135 = x_185; +goto block_168; +} +block_168: +{ +if (lean_obj_tag(x_134) == 0) +{ +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; +x_136 = lean_ctor_get(x_135, 2); +lean_inc(x_136); +x_137 = lean_ctor_get(x_134, 0); +lean_inc(x_137); +lean_dec(x_134); +x_138 = lean_ctor_get(x_135, 0); +lean_inc(x_138); +x_139 = lean_ctor_get(x_135, 1); +lean_inc(x_139); +x_140 = lean_ctor_get(x_135, 3); +lean_inc(x_140); +x_141 = lean_ctor_get(x_135, 4); +lean_inc(x_141); +x_142 = lean_ctor_get(x_135, 5); +lean_inc(x_142); +if (lean_is_exclusive(x_135)) { + lean_ctor_release(x_135, 0); + lean_ctor_release(x_135, 1); + lean_ctor_release(x_135, 2); + lean_ctor_release(x_135, 3); + lean_ctor_release(x_135, 4); + lean_ctor_release(x_135, 5); + x_143 = x_135; +} else { + lean_dec_ref(x_135); + x_143 = lean_box(0); +} +x_144 = lean_ctor_get(x_136, 0); +lean_inc(x_144); +x_145 = lean_ctor_get(x_136, 1); +lean_inc(x_145); +x_146 = lean_ctor_get(x_136, 3); +lean_inc(x_146); +x_147 = lean_ctor_get(x_136, 4); +lean_inc(x_147); +if (lean_is_exclusive(x_136)) { + lean_ctor_release(x_136, 0); + lean_ctor_release(x_136, 1); + lean_ctor_release(x_136, 2); + lean_ctor_release(x_136, 3); + lean_ctor_release(x_136, 4); + x_148 = x_136; +} else { + lean_dec_ref(x_136); + x_148 = lean_box(0); +} +if (lean_is_scalar(x_148)) { + x_149 = lean_alloc_ctor(0, 5, 0); +} else { + x_149 = x_148; +} +lean_ctor_set(x_149, 0, x_144); +lean_ctor_set(x_149, 1, x_145); +lean_ctor_set(x_149, 2, x_131); +lean_ctor_set(x_149, 3, x_146); +lean_ctor_set(x_149, 4, x_147); +if (lean_is_scalar(x_143)) { + x_150 = lean_alloc_ctor(0, 6, 0); +} else { + x_150 = x_143; +} +lean_ctor_set(x_150, 0, x_138); +lean_ctor_set(x_150, 1, x_139); +lean_ctor_set(x_150, 2, x_149); +lean_ctor_set(x_150, 3, x_140); +lean_ctor_set(x_150, 4, x_141); +lean_ctor_set(x_150, 5, x_142); +if (lean_is_scalar(x_39)) { + x_151 = lean_alloc_ctor(1, 2, 0); +} else { + x_151 = x_39; + lean_ctor_set_tag(x_151, 1); +} +lean_ctor_set(x_151, 0, x_137); +lean_ctor_set(x_151, 1, x_150); +return x_151; +} +else +{ +lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; +x_152 = lean_ctor_get(x_135, 2); +lean_inc(x_152); +x_153 = lean_ctor_get(x_134, 0); +lean_inc(x_153); +lean_dec(x_134); +x_154 = lean_ctor_get(x_135, 0); +lean_inc(x_154); +x_155 = lean_ctor_get(x_135, 1); +lean_inc(x_155); +x_156 = lean_ctor_get(x_135, 3); +lean_inc(x_156); +x_157 = lean_ctor_get(x_135, 4); +lean_inc(x_157); +x_158 = lean_ctor_get(x_135, 5); +lean_inc(x_158); +if (lean_is_exclusive(x_135)) { + lean_ctor_release(x_135, 0); + lean_ctor_release(x_135, 1); + lean_ctor_release(x_135, 2); + lean_ctor_release(x_135, 3); + lean_ctor_release(x_135, 4); + lean_ctor_release(x_135, 5); + x_159 = x_135; +} else { + lean_dec_ref(x_135); + x_159 = lean_box(0); +} +x_160 = lean_ctor_get(x_152, 0); +lean_inc(x_160); +x_161 = lean_ctor_get(x_152, 1); +lean_inc(x_161); +x_162 = lean_ctor_get(x_152, 3); +lean_inc(x_162); +x_163 = lean_ctor_get(x_152, 4); +lean_inc(x_163); +if (lean_is_exclusive(x_152)) { + lean_ctor_release(x_152, 0); + lean_ctor_release(x_152, 1); + lean_ctor_release(x_152, 2); + lean_ctor_release(x_152, 3); + lean_ctor_release(x_152, 4); + x_164 = x_152; +} else { + lean_dec_ref(x_152); + x_164 = lean_box(0); +} +if (lean_is_scalar(x_164)) { + x_165 = lean_alloc_ctor(0, 5, 0); +} else { + x_165 = x_164; +} +lean_ctor_set(x_165, 0, x_160); +lean_ctor_set(x_165, 1, x_161); +lean_ctor_set(x_165, 2, x_131); +lean_ctor_set(x_165, 3, x_162); +lean_ctor_set(x_165, 4, x_163); +if (lean_is_scalar(x_159)) { + x_166 = lean_alloc_ctor(0, 6, 0); +} else { + x_166 = x_159; +} +lean_ctor_set(x_166, 0, x_154); +lean_ctor_set(x_166, 1, x_155); +lean_ctor_set(x_166, 2, x_165); +lean_ctor_set(x_166, 3, x_156); +lean_ctor_set(x_166, 4, x_157); +lean_ctor_set(x_166, 5, x_158); +if (lean_is_scalar(x_39)) { + x_167 = lean_alloc_ctor(0, 2, 0); +} else { + x_167 = x_39; +} +lean_ctor_set(x_167, 0, x_153); +lean_ctor_set(x_167, 1, x_166); +return x_167; +} +} +} +} +else +{ +lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_234; lean_object* x_235; lean_object* x_236; lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; lean_object* x_242; lean_object* x_243; lean_object* x_244; lean_object* x_245; lean_object* x_246; +x_187 = lean_ctor_get(x_38, 2); +x_188 = lean_ctor_get(x_38, 0); +x_189 = lean_ctor_get(x_38, 1); +x_190 = lean_ctor_get(x_38, 3); +x_191 = lean_ctor_get(x_38, 4); +x_192 = lean_ctor_get(x_38, 5); +lean_inc(x_192); +lean_inc(x_191); +lean_inc(x_190); +lean_inc(x_187); +lean_inc(x_189); +lean_inc(x_188); +lean_dec(x_38); +x_193 = lean_ctor_get(x_187, 0); +lean_inc(x_193); +x_194 = lean_ctor_get(x_187, 1); +lean_inc(x_194); +x_195 = lean_ctor_get(x_187, 2); +lean_inc(x_195); +x_196 = lean_ctor_get(x_187, 3); +lean_inc(x_196); +x_197 = lean_ctor_get(x_187, 4); +lean_inc(x_197); +if (lean_is_exclusive(x_187)) { + lean_ctor_release(x_187, 0); + lean_ctor_release(x_187, 1); + lean_ctor_release(x_187, 2); + lean_ctor_release(x_187, 3); + lean_ctor_release(x_187, 4); + x_198 = x_187; +} else { + lean_dec_ref(x_187); + x_198 = lean_box(0); +} +x_234 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_198)) { x_235 = lean_alloc_ctor(0, 5, 0); } else { - x_235 = x_232; + x_235 = x_198; } -lean_ctor_set(x_235, 0, x_227); -lean_ctor_set(x_235, 1, x_228); +lean_ctor_set(x_235, 0, x_193); +lean_ctor_set(x_235, 1, x_194); lean_ctor_set(x_235, 2, x_234); -lean_ctor_set(x_235, 3, x_230); -lean_ctor_set(x_235, 4, x_231); -x_236 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__6(x_1, x_2, x_3, x_4, x_42, x_235, x_226); -if (lean_obj_tag(x_236) == 0) -{ -lean_object* x_237; lean_object* x_238; lean_object* x_239; -x_237 = lean_ctor_get(x_236, 0); +lean_ctor_set(x_235, 3, x_196); +lean_ctor_set(x_235, 4, x_197); +x_236 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_236, 0, x_188); +lean_ctor_set(x_236, 1, x_189); +lean_ctor_set(x_236, 2, x_235); +lean_ctor_set(x_236, 3, x_190); +lean_ctor_set(x_236, 4, x_191); +lean_ctor_set(x_236, 5, x_192); +x_237 = lean_ctor_get(x_6, 0); lean_inc(x_237); -x_238 = lean_ctor_get(x_236, 1); +x_238 = lean_ctor_get(x_6, 1); lean_inc(x_238); -lean_dec(x_236); -x_239 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_239, 0, x_237); -x_191 = x_239; -x_192 = x_238; -goto block_223; -} -else -{ -lean_object* x_240; lean_object* x_241; lean_object* x_242; -x_240 = lean_ctor_get(x_236, 0); +x_239 = lean_ctor_get(x_6, 2); +lean_inc(x_239); +x_240 = lean_ctor_get(x_6, 3); lean_inc(x_240); -x_241 = lean_ctor_get(x_236, 1); +x_241 = lean_ctor_get(x_6, 4); lean_inc(x_241); -lean_dec(x_236); -x_242 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_242, 0, x_240); -x_191 = x_242; -x_192 = x_241; -goto block_223; +if (lean_is_exclusive(x_6)) { + lean_ctor_release(x_6, 0); + lean_ctor_release(x_6, 1); + lean_ctor_release(x_6, 2); + lean_ctor_release(x_6, 3); + lean_ctor_release(x_6, 4); + x_242 = x_6; +} else { + lean_dec_ref(x_6); + x_242 = lean_box(0); } -block_223: +x_243 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_243, 0, x_40); +lean_ctor_set(x_243, 1, x_27); +x_244 = lean_array_push(x_239, x_243); +if (lean_is_scalar(x_242)) { + x_245 = lean_alloc_ctor(0, 5, 0); +} else { + x_245 = x_242; +} +lean_ctor_set(x_245, 0, x_237); +lean_ctor_set(x_245, 1, x_238); +lean_ctor_set(x_245, 2, x_244); +lean_ctor_set(x_245, 3, x_240); +lean_ctor_set(x_245, 4, x_241); +x_246 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__6(x_1, x_2, x_3, x_4, x_42, x_245, x_236); +if (lean_obj_tag(x_246) == 0) { -if (lean_obj_tag(x_191) == 0) -{ -lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; -x_193 = lean_ctor_get(x_192, 2); -lean_inc(x_193); -x_194 = lean_ctor_get(x_191, 0); -lean_inc(x_194); -lean_dec(x_191); -x_195 = lean_ctor_get(x_192, 0); -lean_inc(x_195); -x_196 = lean_ctor_get(x_192, 1); -lean_inc(x_196); -x_197 = lean_ctor_get(x_192, 3); -lean_inc(x_197); -x_198 = lean_ctor_get(x_192, 4); -lean_inc(x_198); -x_199 = lean_ctor_get(x_192, 5); -lean_inc(x_199); -if (lean_is_exclusive(x_192)) { - lean_ctor_release(x_192, 0); - lean_ctor_release(x_192, 1); - lean_ctor_release(x_192, 2); - lean_ctor_release(x_192, 3); - lean_ctor_release(x_192, 4); - lean_ctor_release(x_192, 5); - x_200 = x_192; -} else { - lean_dec_ref(x_192); - x_200 = lean_box(0); -} -x_201 = lean_ctor_get(x_193, 0); -lean_inc(x_201); -x_202 = lean_ctor_get(x_193, 1); -lean_inc(x_202); -x_203 = lean_ctor_get(x_193, 3); -lean_inc(x_203); -if (lean_is_exclusive(x_193)) { - lean_ctor_release(x_193, 0); - lean_ctor_release(x_193, 1); - lean_ctor_release(x_193, 2); - lean_ctor_release(x_193, 3); - x_204 = x_193; -} else { - lean_dec_ref(x_193); - x_204 = lean_box(0); -} -if (lean_is_scalar(x_204)) { - x_205 = lean_alloc_ctor(0, 4, 0); -} else { - x_205 = x_204; -} -lean_ctor_set(x_205, 0, x_201); -lean_ctor_set(x_205, 1, x_202); -lean_ctor_set(x_205, 2, x_188); -lean_ctor_set(x_205, 3, x_203); -if (lean_is_scalar(x_200)) { - x_206 = lean_alloc_ctor(0, 6, 0); -} else { - x_206 = x_200; -} -lean_ctor_set(x_206, 0, x_195); -lean_ctor_set(x_206, 1, x_196); -lean_ctor_set(x_206, 2, x_205); -lean_ctor_set(x_206, 3, x_197); -lean_ctor_set(x_206, 4, x_198); -lean_ctor_set(x_206, 5, x_199); -if (lean_is_scalar(x_39)) { - x_207 = lean_alloc_ctor(1, 2, 0); -} else { - x_207 = x_39; - lean_ctor_set_tag(x_207, 1); -} -lean_ctor_set(x_207, 0, x_194); -lean_ctor_set(x_207, 1, x_206); -return x_207; +lean_object* x_247; lean_object* x_248; lean_object* x_249; +x_247 = lean_ctor_get(x_246, 0); +lean_inc(x_247); +x_248 = lean_ctor_get(x_246, 1); +lean_inc(x_248); +lean_dec(x_246); +x_249 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_249, 0, x_247); +x_199 = x_249; +x_200 = x_248; +goto block_233; } else { -lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; -x_208 = lean_ctor_get(x_192, 2); -lean_inc(x_208); -x_209 = lean_ctor_get(x_191, 0); +lean_object* x_250; lean_object* x_251; lean_object* x_252; +x_250 = lean_ctor_get(x_246, 0); +lean_inc(x_250); +x_251 = lean_ctor_get(x_246, 1); +lean_inc(x_251); +lean_dec(x_246); +x_252 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_252, 0, x_250); +x_199 = x_252; +x_200 = x_251; +goto block_233; +} +block_233: +{ +if (lean_obj_tag(x_199) == 0) +{ +lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; +x_201 = lean_ctor_get(x_200, 2); +lean_inc(x_201); +x_202 = lean_ctor_get(x_199, 0); +lean_inc(x_202); +lean_dec(x_199); +x_203 = lean_ctor_get(x_200, 0); +lean_inc(x_203); +x_204 = lean_ctor_get(x_200, 1); +lean_inc(x_204); +x_205 = lean_ctor_get(x_200, 3); +lean_inc(x_205); +x_206 = lean_ctor_get(x_200, 4); +lean_inc(x_206); +x_207 = lean_ctor_get(x_200, 5); +lean_inc(x_207); +if (lean_is_exclusive(x_200)) { + lean_ctor_release(x_200, 0); + lean_ctor_release(x_200, 1); + lean_ctor_release(x_200, 2); + lean_ctor_release(x_200, 3); + lean_ctor_release(x_200, 4); + lean_ctor_release(x_200, 5); + x_208 = x_200; +} else { + lean_dec_ref(x_200); + x_208 = lean_box(0); +} +x_209 = lean_ctor_get(x_201, 0); lean_inc(x_209); -lean_dec(x_191); -x_210 = lean_ctor_get(x_192, 0); +x_210 = lean_ctor_get(x_201, 1); lean_inc(x_210); -x_211 = lean_ctor_get(x_192, 1); +x_211 = lean_ctor_get(x_201, 3); lean_inc(x_211); -x_212 = lean_ctor_get(x_192, 3); +x_212 = lean_ctor_get(x_201, 4); lean_inc(x_212); -x_213 = lean_ctor_get(x_192, 4); -lean_inc(x_213); -x_214 = lean_ctor_get(x_192, 5); -lean_inc(x_214); -if (lean_is_exclusive(x_192)) { - lean_ctor_release(x_192, 0); - lean_ctor_release(x_192, 1); - lean_ctor_release(x_192, 2); - lean_ctor_release(x_192, 3); - lean_ctor_release(x_192, 4); - lean_ctor_release(x_192, 5); - x_215 = x_192; +if (lean_is_exclusive(x_201)) { + lean_ctor_release(x_201, 0); + lean_ctor_release(x_201, 1); + lean_ctor_release(x_201, 2); + lean_ctor_release(x_201, 3); + lean_ctor_release(x_201, 4); + x_213 = x_201; } else { - lean_dec_ref(x_192); - x_215 = lean_box(0); + lean_dec_ref(x_201); + x_213 = lean_box(0); } -x_216 = lean_ctor_get(x_208, 0); -lean_inc(x_216); -x_217 = lean_ctor_get(x_208, 1); -lean_inc(x_217); -x_218 = lean_ctor_get(x_208, 3); -lean_inc(x_218); -if (lean_is_exclusive(x_208)) { - lean_ctor_release(x_208, 0); - lean_ctor_release(x_208, 1); - lean_ctor_release(x_208, 2); - lean_ctor_release(x_208, 3); - x_219 = x_208; +if (lean_is_scalar(x_213)) { + x_214 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_208); - x_219 = lean_box(0); + x_214 = x_213; } -if (lean_is_scalar(x_219)) { - x_220 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_214, 0, x_209); +lean_ctor_set(x_214, 1, x_210); +lean_ctor_set(x_214, 2, x_195); +lean_ctor_set(x_214, 3, x_211); +lean_ctor_set(x_214, 4, x_212); +if (lean_is_scalar(x_208)) { + x_215 = lean_alloc_ctor(0, 6, 0); } else { - x_220 = x_219; + x_215 = x_208; } -lean_ctor_set(x_220, 0, x_216); -lean_ctor_set(x_220, 1, x_217); -lean_ctor_set(x_220, 2, x_188); -lean_ctor_set(x_220, 3, x_218); -if (lean_is_scalar(x_215)) { - x_221 = lean_alloc_ctor(0, 6, 0); -} else { - x_221 = x_215; -} -lean_ctor_set(x_221, 0, x_210); -lean_ctor_set(x_221, 1, x_211); -lean_ctor_set(x_221, 2, x_220); -lean_ctor_set(x_221, 3, x_212); -lean_ctor_set(x_221, 4, x_213); -lean_ctor_set(x_221, 5, x_214); +lean_ctor_set(x_215, 0, x_203); +lean_ctor_set(x_215, 1, x_204); +lean_ctor_set(x_215, 2, x_214); +lean_ctor_set(x_215, 3, x_205); +lean_ctor_set(x_215, 4, x_206); +lean_ctor_set(x_215, 5, x_207); if (lean_is_scalar(x_39)) { - x_222 = lean_alloc_ctor(0, 2, 0); + x_216 = lean_alloc_ctor(1, 2, 0); } else { - x_222 = x_39; + x_216 = x_39; + lean_ctor_set_tag(x_216, 1); } -lean_ctor_set(x_222, 0, x_209); -lean_ctor_set(x_222, 1, x_221); -return x_222; +lean_ctor_set(x_216, 0, x_202); +lean_ctor_set(x_216, 1, x_215); +return x_216; +} +else +{ +lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; lean_object* x_224; lean_object* x_225; lean_object* x_226; lean_object* x_227; lean_object* x_228; lean_object* x_229; lean_object* x_230; lean_object* x_231; lean_object* x_232; +x_217 = lean_ctor_get(x_200, 2); +lean_inc(x_217); +x_218 = lean_ctor_get(x_199, 0); +lean_inc(x_218); +lean_dec(x_199); +x_219 = lean_ctor_get(x_200, 0); +lean_inc(x_219); +x_220 = lean_ctor_get(x_200, 1); +lean_inc(x_220); +x_221 = lean_ctor_get(x_200, 3); +lean_inc(x_221); +x_222 = lean_ctor_get(x_200, 4); +lean_inc(x_222); +x_223 = lean_ctor_get(x_200, 5); +lean_inc(x_223); +if (lean_is_exclusive(x_200)) { + lean_ctor_release(x_200, 0); + lean_ctor_release(x_200, 1); + lean_ctor_release(x_200, 2); + lean_ctor_release(x_200, 3); + lean_ctor_release(x_200, 4); + lean_ctor_release(x_200, 5); + x_224 = x_200; +} else { + lean_dec_ref(x_200); + x_224 = lean_box(0); +} +x_225 = lean_ctor_get(x_217, 0); +lean_inc(x_225); +x_226 = lean_ctor_get(x_217, 1); +lean_inc(x_226); +x_227 = lean_ctor_get(x_217, 3); +lean_inc(x_227); +x_228 = lean_ctor_get(x_217, 4); +lean_inc(x_228); +if (lean_is_exclusive(x_217)) { + lean_ctor_release(x_217, 0); + lean_ctor_release(x_217, 1); + lean_ctor_release(x_217, 2); + lean_ctor_release(x_217, 3); + lean_ctor_release(x_217, 4); + x_229 = x_217; +} else { + lean_dec_ref(x_217); + x_229 = lean_box(0); +} +if (lean_is_scalar(x_229)) { + x_230 = lean_alloc_ctor(0, 5, 0); +} else { + x_230 = x_229; +} +lean_ctor_set(x_230, 0, x_225); +lean_ctor_set(x_230, 1, x_226); +lean_ctor_set(x_230, 2, x_195); +lean_ctor_set(x_230, 3, x_227); +lean_ctor_set(x_230, 4, x_228); +if (lean_is_scalar(x_224)) { + x_231 = lean_alloc_ctor(0, 6, 0); +} else { + x_231 = x_224; +} +lean_ctor_set(x_231, 0, x_219); +lean_ctor_set(x_231, 1, x_220); +lean_ctor_set(x_231, 2, x_230); +lean_ctor_set(x_231, 3, x_221); +lean_ctor_set(x_231, 4, x_222); +lean_ctor_set(x_231, 5, x_223); +if (lean_is_scalar(x_39)) { + x_232 = lean_alloc_ctor(0, 2, 0); +} else { + x_232 = x_39; +} +lean_ctor_set(x_232, 0, x_218); +lean_ctor_set(x_232, 1, x_231); +return x_232; } } } } default: { -lean_object* x_243; lean_object* x_244; -x_243 = lean_ctor_get(x_32, 1); -lean_inc(x_243); +lean_object* x_253; lean_object* x_254; +x_253 = lean_ctor_get(x_32, 1); +lean_inc(x_253); lean_dec(x_32); lean_inc(x_6); -x_244 = l_Lean_Meta_isClassExpensive___main(x_31, x_6, x_243); -if (lean_obj_tag(x_244) == 0) +x_254 = l_Lean_Meta_isClassExpensive___main(x_31, x_6, x_253); +if (lean_obj_tag(x_254) == 0) { -lean_object* x_245; -x_245 = lean_ctor_get(x_244, 0); -lean_inc(x_245); -if (lean_obj_tag(x_245) == 0) +lean_object* x_255; +x_255 = lean_ctor_get(x_254, 0); +lean_inc(x_255); +if (lean_obj_tag(x_255) == 0) { -lean_object* x_246; lean_object* x_247; lean_object* x_248; +lean_object* x_256; lean_object* x_257; lean_object* x_258; lean_dec(x_27); -x_246 = lean_ctor_get(x_244, 1); -lean_inc(x_246); -lean_dec(x_244); -x_247 = lean_unsigned_to_nat(1u); -x_248 = lean_nat_add(x_5, x_247); +x_256 = lean_ctor_get(x_254, 1); +lean_inc(x_256); +lean_dec(x_254); +x_257 = lean_unsigned_to_nat(1u); +x_258 = lean_nat_add(x_5, x_257); lean_dec(x_5); -x_5 = x_248; -x_7 = x_246; +x_5 = x_258; +x_7 = x_256; goto _start; } else { -lean_object* x_250; lean_object* x_251; lean_object* x_252; lean_object* x_253; lean_object* x_254; uint8_t x_255; -x_250 = lean_ctor_get(x_244, 1); -lean_inc(x_250); -if (lean_is_exclusive(x_244)) { - lean_ctor_release(x_244, 0); - lean_ctor_release(x_244, 1); - x_251 = x_244; +lean_object* x_260; lean_object* x_261; lean_object* x_262; lean_object* x_263; lean_object* x_264; uint8_t x_265; +x_260 = lean_ctor_get(x_254, 1); +lean_inc(x_260); +if (lean_is_exclusive(x_254)) { + lean_ctor_release(x_254, 0); + lean_ctor_release(x_254, 1); + x_261 = x_254; } else { - lean_dec_ref(x_244); - x_251 = lean_box(0); + lean_dec_ref(x_254); + x_261 = lean_box(0); } -x_252 = lean_ctor_get(x_245, 0); -lean_inc(x_252); -lean_dec(x_245); -x_253 = lean_unsigned_to_nat(1u); -x_254 = lean_nat_add(x_5, x_253); -lean_dec(x_5); -x_255 = !lean_is_exclusive(x_250); -if (x_255 == 0) -{ -lean_object* x_256; uint8_t x_257; -x_256 = lean_ctor_get(x_250, 2); -x_257 = !lean_is_exclusive(x_256); -if (x_257 == 0) -{ -lean_object* x_258; lean_object* x_259; lean_object* x_260; lean_object* x_310; uint8_t x_311; -x_258 = lean_ctor_get(x_256, 2); -x_310 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_256, 2, x_310); -x_311 = !lean_is_exclusive(x_6); -if (x_311 == 0) -{ -lean_object* x_312; lean_object* x_313; lean_object* x_314; lean_object* x_315; -x_312 = lean_ctor_get(x_6, 2); -x_313 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_313, 0, x_252); -lean_ctor_set(x_313, 1, x_27); -x_314 = lean_array_push(x_312, x_313); -lean_ctor_set(x_6, 2, x_314); -x_315 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__6(x_1, x_2, x_3, x_4, x_254, x_6, x_250); -if (lean_obj_tag(x_315) == 0) -{ -lean_object* x_316; lean_object* x_317; lean_object* x_318; -x_316 = lean_ctor_get(x_315, 0); -lean_inc(x_316); -x_317 = lean_ctor_get(x_315, 1); -lean_inc(x_317); -lean_dec(x_315); -x_318 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_318, 0, x_316); -x_259 = x_318; -x_260 = x_317; -goto block_309; -} -else -{ -lean_object* x_319; lean_object* x_320; lean_object* x_321; -x_319 = lean_ctor_get(x_315, 0); -lean_inc(x_319); -x_320 = lean_ctor_get(x_315, 1); -lean_inc(x_320); -lean_dec(x_315); -x_321 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_321, 0, x_319); -x_259 = x_321; -x_260 = x_320; -goto block_309; -} -} -else -{ -lean_object* x_322; lean_object* x_323; lean_object* x_324; lean_object* x_325; lean_object* x_326; lean_object* x_327; lean_object* x_328; lean_object* x_329; lean_object* x_330; -x_322 = lean_ctor_get(x_6, 0); -x_323 = lean_ctor_get(x_6, 1); -x_324 = lean_ctor_get(x_6, 2); -x_325 = lean_ctor_get(x_6, 3); -x_326 = lean_ctor_get(x_6, 4); -lean_inc(x_326); -lean_inc(x_325); -lean_inc(x_324); -lean_inc(x_323); -lean_inc(x_322); -lean_dec(x_6); -x_327 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_327, 0, x_252); -lean_ctor_set(x_327, 1, x_27); -x_328 = lean_array_push(x_324, x_327); -x_329 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_329, 0, x_322); -lean_ctor_set(x_329, 1, x_323); -lean_ctor_set(x_329, 2, x_328); -lean_ctor_set(x_329, 3, x_325); -lean_ctor_set(x_329, 4, x_326); -x_330 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__6(x_1, x_2, x_3, x_4, x_254, x_329, x_250); -if (lean_obj_tag(x_330) == 0) -{ -lean_object* x_331; lean_object* x_332; lean_object* x_333; -x_331 = lean_ctor_get(x_330, 0); -lean_inc(x_331); -x_332 = lean_ctor_get(x_330, 1); -lean_inc(x_332); -lean_dec(x_330); -x_333 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_333, 0, x_331); -x_259 = x_333; -x_260 = x_332; -goto block_309; -} -else -{ -lean_object* x_334; lean_object* x_335; lean_object* x_336; -x_334 = lean_ctor_get(x_330, 0); -lean_inc(x_334); -x_335 = lean_ctor_get(x_330, 1); -lean_inc(x_335); -lean_dec(x_330); -x_336 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_336, 0, x_334); -x_259 = x_336; -x_260 = x_335; -goto block_309; -} -} -block_309: -{ -if (lean_obj_tag(x_259) == 0) -{ -lean_object* x_261; lean_object* x_262; uint8_t x_263; -x_261 = lean_ctor_get(x_260, 2); -lean_inc(x_261); -x_262 = lean_ctor_get(x_259, 0); +x_262 = lean_ctor_get(x_255, 0); lean_inc(x_262); -lean_dec(x_259); -x_263 = !lean_is_exclusive(x_260); -if (x_263 == 0) -{ -lean_object* x_264; uint8_t x_265; -x_264 = lean_ctor_get(x_260, 2); -lean_dec(x_264); -x_265 = !lean_is_exclusive(x_261); +lean_dec(x_255); +x_263 = lean_unsigned_to_nat(1u); +x_264 = lean_nat_add(x_5, x_263); +lean_dec(x_5); +x_265 = !lean_is_exclusive(x_260); if (x_265 == 0) { -lean_object* x_266; lean_object* x_267; -x_266 = lean_ctor_get(x_261, 2); -lean_dec(x_266); -lean_ctor_set(x_261, 2, x_258); -if (lean_is_scalar(x_251)) { - x_267 = lean_alloc_ctor(1, 2, 0); -} else { - x_267 = x_251; - lean_ctor_set_tag(x_267, 1); -} -lean_ctor_set(x_267, 0, x_262); -lean_ctor_set(x_267, 1, x_260); -return x_267; +lean_object* x_266; uint8_t x_267; +x_266 = lean_ctor_get(x_260, 2); +x_267 = !lean_is_exclusive(x_266); +if (x_267 == 0) +{ +lean_object* x_268; lean_object* x_269; lean_object* x_270; lean_object* x_324; uint8_t x_325; +x_268 = lean_ctor_get(x_266, 2); +x_324 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_266, 2, x_324); +x_325 = !lean_is_exclusive(x_6); +if (x_325 == 0) +{ +lean_object* x_326; lean_object* x_327; lean_object* x_328; lean_object* x_329; +x_326 = lean_ctor_get(x_6, 2); +x_327 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_327, 0, x_262); +lean_ctor_set(x_327, 1, x_27); +x_328 = lean_array_push(x_326, x_327); +lean_ctor_set(x_6, 2, x_328); +x_329 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__6(x_1, x_2, x_3, x_4, x_264, x_6, x_260); +if (lean_obj_tag(x_329) == 0) +{ +lean_object* x_330; lean_object* x_331; lean_object* x_332; +x_330 = lean_ctor_get(x_329, 0); +lean_inc(x_330); +x_331 = lean_ctor_get(x_329, 1); +lean_inc(x_331); +lean_dec(x_329); +x_332 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_332, 0, x_330); +x_269 = x_332; +x_270 = x_331; +goto block_323; } else { -lean_object* x_268; lean_object* x_269; lean_object* x_270; lean_object* x_271; lean_object* x_272; -x_268 = lean_ctor_get(x_261, 0); -x_269 = lean_ctor_get(x_261, 1); -x_270 = lean_ctor_get(x_261, 3); -lean_inc(x_270); -lean_inc(x_269); -lean_inc(x_268); -lean_dec(x_261); -x_271 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_271, 0, x_268); -lean_ctor_set(x_271, 1, x_269); -lean_ctor_set(x_271, 2, x_258); -lean_ctor_set(x_271, 3, x_270); -lean_ctor_set(x_260, 2, x_271); -if (lean_is_scalar(x_251)) { - x_272 = lean_alloc_ctor(1, 2, 0); -} else { - x_272 = x_251; - lean_ctor_set_tag(x_272, 1); -} -lean_ctor_set(x_272, 0, x_262); -lean_ctor_set(x_272, 1, x_260); -return x_272; +lean_object* x_333; lean_object* x_334; lean_object* x_335; +x_333 = lean_ctor_get(x_329, 0); +lean_inc(x_333); +x_334 = lean_ctor_get(x_329, 1); +lean_inc(x_334); +lean_dec(x_329); +x_335 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_335, 0, x_333); +x_269 = x_335; +x_270 = x_334; +goto block_323; } } else { -lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_object* x_276; lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; lean_object* x_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; -x_273 = lean_ctor_get(x_260, 0); -x_274 = lean_ctor_get(x_260, 1); -x_275 = lean_ctor_get(x_260, 3); -x_276 = lean_ctor_get(x_260, 4); -x_277 = lean_ctor_get(x_260, 5); -lean_inc(x_277); -lean_inc(x_276); -lean_inc(x_275); -lean_inc(x_274); -lean_inc(x_273); -lean_dec(x_260); -x_278 = lean_ctor_get(x_261, 0); -lean_inc(x_278); -x_279 = lean_ctor_get(x_261, 1); -lean_inc(x_279); -x_280 = lean_ctor_get(x_261, 3); +lean_object* x_336; lean_object* x_337; lean_object* x_338; lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; +x_336 = lean_ctor_get(x_6, 0); +x_337 = lean_ctor_get(x_6, 1); +x_338 = lean_ctor_get(x_6, 2); +x_339 = lean_ctor_get(x_6, 3); +x_340 = lean_ctor_get(x_6, 4); +lean_inc(x_340); +lean_inc(x_339); +lean_inc(x_338); +lean_inc(x_337); +lean_inc(x_336); +lean_dec(x_6); +x_341 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_341, 0, x_262); +lean_ctor_set(x_341, 1, x_27); +x_342 = lean_array_push(x_338, x_341); +x_343 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_343, 0, x_336); +lean_ctor_set(x_343, 1, x_337); +lean_ctor_set(x_343, 2, x_342); +lean_ctor_set(x_343, 3, x_339); +lean_ctor_set(x_343, 4, x_340); +x_344 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__6(x_1, x_2, x_3, x_4, x_264, x_343, x_260); +if (lean_obj_tag(x_344) == 0) +{ +lean_object* x_345; lean_object* x_346; lean_object* x_347; +x_345 = lean_ctor_get(x_344, 0); +lean_inc(x_345); +x_346 = lean_ctor_get(x_344, 1); +lean_inc(x_346); +lean_dec(x_344); +x_347 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_347, 0, x_345); +x_269 = x_347; +x_270 = x_346; +goto block_323; +} +else +{ +lean_object* x_348; lean_object* x_349; lean_object* x_350; +x_348 = lean_ctor_get(x_344, 0); +lean_inc(x_348); +x_349 = lean_ctor_get(x_344, 1); +lean_inc(x_349); +lean_dec(x_344); +x_350 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_350, 0, x_348); +x_269 = x_350; +x_270 = x_349; +goto block_323; +} +} +block_323: +{ +if (lean_obj_tag(x_269) == 0) +{ +lean_object* x_271; lean_object* x_272; uint8_t x_273; +x_271 = lean_ctor_get(x_270, 2); +lean_inc(x_271); +x_272 = lean_ctor_get(x_269, 0); +lean_inc(x_272); +lean_dec(x_269); +x_273 = !lean_is_exclusive(x_270); +if (x_273 == 0) +{ +lean_object* x_274; uint8_t x_275; +x_274 = lean_ctor_get(x_270, 2); +lean_dec(x_274); +x_275 = !lean_is_exclusive(x_271); +if (x_275 == 0) +{ +lean_object* x_276; lean_object* x_277; +x_276 = lean_ctor_get(x_271, 2); +lean_dec(x_276); +lean_ctor_set(x_271, 2, x_268); +if (lean_is_scalar(x_261)) { + x_277 = lean_alloc_ctor(1, 2, 0); +} else { + x_277 = x_261; + lean_ctor_set_tag(x_277, 1); +} +lean_ctor_set(x_277, 0, x_272); +lean_ctor_set(x_277, 1, x_270); +return x_277; +} +else +{ +lean_object* x_278; lean_object* x_279; lean_object* x_280; lean_object* x_281; lean_object* x_282; lean_object* x_283; +x_278 = lean_ctor_get(x_271, 0); +x_279 = lean_ctor_get(x_271, 1); +x_280 = lean_ctor_get(x_271, 3); +x_281 = lean_ctor_get(x_271, 4); +lean_inc(x_281); lean_inc(x_280); -if (lean_is_exclusive(x_261)) { - lean_ctor_release(x_261, 0); - lean_ctor_release(x_261, 1); - lean_ctor_release(x_261, 2); - lean_ctor_release(x_261, 3); - x_281 = x_261; -} else { - lean_dec_ref(x_261); - x_281 = lean_box(0); -} -if (lean_is_scalar(x_281)) { - x_282 = lean_alloc_ctor(0, 4, 0); -} else { - x_282 = x_281; -} +lean_inc(x_279); +lean_inc(x_278); +lean_dec(x_271); +x_282 = lean_alloc_ctor(0, 5, 0); lean_ctor_set(x_282, 0, x_278); lean_ctor_set(x_282, 1, x_279); -lean_ctor_set(x_282, 2, x_258); +lean_ctor_set(x_282, 2, x_268); lean_ctor_set(x_282, 3, x_280); -x_283 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_283, 0, x_273); -lean_ctor_set(x_283, 1, x_274); -lean_ctor_set(x_283, 2, x_282); -lean_ctor_set(x_283, 3, x_275); -lean_ctor_set(x_283, 4, x_276); -lean_ctor_set(x_283, 5, x_277); -if (lean_is_scalar(x_251)) { - x_284 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_282, 4, x_281); +lean_ctor_set(x_270, 2, x_282); +if (lean_is_scalar(x_261)) { + x_283 = lean_alloc_ctor(1, 2, 0); } else { - x_284 = x_251; - lean_ctor_set_tag(x_284, 1); + x_283 = x_261; + lean_ctor_set_tag(x_283, 1); } -lean_ctor_set(x_284, 0, x_262); -lean_ctor_set(x_284, 1, x_283); -return x_284; +lean_ctor_set(x_283, 0, x_272); +lean_ctor_set(x_283, 1, x_270); +return x_283; } } else { -lean_object* x_285; lean_object* x_286; uint8_t x_287; -x_285 = lean_ctor_get(x_260, 2); -lean_inc(x_285); -x_286 = lean_ctor_get(x_259, 0); +lean_object* x_284; lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; lean_object* x_289; lean_object* x_290; lean_object* x_291; lean_object* x_292; lean_object* x_293; lean_object* x_294; lean_object* x_295; lean_object* x_296; +x_284 = lean_ctor_get(x_270, 0); +x_285 = lean_ctor_get(x_270, 1); +x_286 = lean_ctor_get(x_270, 3); +x_287 = lean_ctor_get(x_270, 4); +x_288 = lean_ctor_get(x_270, 5); +lean_inc(x_288); +lean_inc(x_287); lean_inc(x_286); -lean_dec(x_259); -x_287 = !lean_is_exclusive(x_260); -if (x_287 == 0) -{ -lean_object* x_288; uint8_t x_289; -x_288 = lean_ctor_get(x_260, 2); -lean_dec(x_288); -x_289 = !lean_is_exclusive(x_285); -if (x_289 == 0) -{ -lean_object* x_290; lean_object* x_291; -x_290 = lean_ctor_get(x_285, 2); -lean_dec(x_290); -lean_ctor_set(x_285, 2, x_258); -if (lean_is_scalar(x_251)) { - x_291 = lean_alloc_ctor(0, 2, 0); -} else { - x_291 = x_251; -} -lean_ctor_set(x_291, 0, x_286); -lean_ctor_set(x_291, 1, x_260); -return x_291; -} -else -{ -lean_object* x_292; lean_object* x_293; lean_object* x_294; lean_object* x_295; lean_object* x_296; -x_292 = lean_ctor_get(x_285, 0); -x_293 = lean_ctor_get(x_285, 1); -x_294 = lean_ctor_get(x_285, 3); -lean_inc(x_294); -lean_inc(x_293); +lean_inc(x_285); +lean_inc(x_284); +lean_dec(x_270); +x_289 = lean_ctor_get(x_271, 0); +lean_inc(x_289); +x_290 = lean_ctor_get(x_271, 1); +lean_inc(x_290); +x_291 = lean_ctor_get(x_271, 3); +lean_inc(x_291); +x_292 = lean_ctor_get(x_271, 4); lean_inc(x_292); -lean_dec(x_285); -x_295 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_295, 0, x_292); -lean_ctor_set(x_295, 1, x_293); -lean_ctor_set(x_295, 2, x_258); -lean_ctor_set(x_295, 3, x_294); -lean_ctor_set(x_260, 2, x_295); -if (lean_is_scalar(x_251)) { - x_296 = lean_alloc_ctor(0, 2, 0); +if (lean_is_exclusive(x_271)) { + lean_ctor_release(x_271, 0); + lean_ctor_release(x_271, 1); + lean_ctor_release(x_271, 2); + lean_ctor_release(x_271, 3); + lean_ctor_release(x_271, 4); + x_293 = x_271; } else { - x_296 = x_251; + lean_dec_ref(x_271); + x_293 = lean_box(0); } -lean_ctor_set(x_296, 0, x_286); -lean_ctor_set(x_296, 1, x_260); +if (lean_is_scalar(x_293)) { + x_294 = lean_alloc_ctor(0, 5, 0); +} else { + x_294 = x_293; +} +lean_ctor_set(x_294, 0, x_289); +lean_ctor_set(x_294, 1, x_290); +lean_ctor_set(x_294, 2, x_268); +lean_ctor_set(x_294, 3, x_291); +lean_ctor_set(x_294, 4, x_292); +x_295 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_295, 0, x_284); +lean_ctor_set(x_295, 1, x_285); +lean_ctor_set(x_295, 2, x_294); +lean_ctor_set(x_295, 3, x_286); +lean_ctor_set(x_295, 4, x_287); +lean_ctor_set(x_295, 5, x_288); +if (lean_is_scalar(x_261)) { + x_296 = lean_alloc_ctor(1, 2, 0); +} else { + x_296 = x_261; + lean_ctor_set_tag(x_296, 1); +} +lean_ctor_set(x_296, 0, x_272); +lean_ctor_set(x_296, 1, x_295); return x_296; } } else { -lean_object* x_297; lean_object* x_298; lean_object* x_299; lean_object* x_300; lean_object* x_301; lean_object* x_302; lean_object* x_303; lean_object* x_304; lean_object* x_305; lean_object* x_306; lean_object* x_307; lean_object* x_308; -x_297 = lean_ctor_get(x_260, 0); -x_298 = lean_ctor_get(x_260, 1); -x_299 = lean_ctor_get(x_260, 3); -x_300 = lean_ctor_get(x_260, 4); -x_301 = lean_ctor_get(x_260, 5); -lean_inc(x_301); -lean_inc(x_300); -lean_inc(x_299); -lean_inc(x_298); +lean_object* x_297; lean_object* x_298; uint8_t x_299; +x_297 = lean_ctor_get(x_270, 2); lean_inc(x_297); -lean_dec(x_260); -x_302 = lean_ctor_get(x_285, 0); -lean_inc(x_302); -x_303 = lean_ctor_get(x_285, 1); -lean_inc(x_303); -x_304 = lean_ctor_get(x_285, 3); +x_298 = lean_ctor_get(x_269, 0); +lean_inc(x_298); +lean_dec(x_269); +x_299 = !lean_is_exclusive(x_270); +if (x_299 == 0) +{ +lean_object* x_300; uint8_t x_301; +x_300 = lean_ctor_get(x_270, 2); +lean_dec(x_300); +x_301 = !lean_is_exclusive(x_297); +if (x_301 == 0) +{ +lean_object* x_302; lean_object* x_303; +x_302 = lean_ctor_get(x_297, 2); +lean_dec(x_302); +lean_ctor_set(x_297, 2, x_268); +if (lean_is_scalar(x_261)) { + x_303 = lean_alloc_ctor(0, 2, 0); +} else { + x_303 = x_261; +} +lean_ctor_set(x_303, 0, x_298); +lean_ctor_set(x_303, 1, x_270); +return x_303; +} +else +{ +lean_object* x_304; lean_object* x_305; lean_object* x_306; lean_object* x_307; lean_object* x_308; lean_object* x_309; +x_304 = lean_ctor_get(x_297, 0); +x_305 = lean_ctor_get(x_297, 1); +x_306 = lean_ctor_get(x_297, 3); +x_307 = lean_ctor_get(x_297, 4); +lean_inc(x_307); +lean_inc(x_306); +lean_inc(x_305); lean_inc(x_304); -if (lean_is_exclusive(x_285)) { - lean_ctor_release(x_285, 0); - lean_ctor_release(x_285, 1); - lean_ctor_release(x_285, 2); - lean_ctor_release(x_285, 3); - x_305 = x_285; +lean_dec(x_297); +x_308 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_308, 0, x_304); +lean_ctor_set(x_308, 1, x_305); +lean_ctor_set(x_308, 2, x_268); +lean_ctor_set(x_308, 3, x_306); +lean_ctor_set(x_308, 4, x_307); +lean_ctor_set(x_270, 2, x_308); +if (lean_is_scalar(x_261)) { + x_309 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_285); - x_305 = lean_box(0); + x_309 = x_261; } -if (lean_is_scalar(x_305)) { - x_306 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_309, 0, x_298); +lean_ctor_set(x_309, 1, x_270); +return x_309; +} +} +else +{ +lean_object* x_310; lean_object* x_311; lean_object* x_312; lean_object* x_313; lean_object* x_314; lean_object* x_315; lean_object* x_316; lean_object* x_317; lean_object* x_318; lean_object* x_319; lean_object* x_320; lean_object* x_321; lean_object* x_322; +x_310 = lean_ctor_get(x_270, 0); +x_311 = lean_ctor_get(x_270, 1); +x_312 = lean_ctor_get(x_270, 3); +x_313 = lean_ctor_get(x_270, 4); +x_314 = lean_ctor_get(x_270, 5); +lean_inc(x_314); +lean_inc(x_313); +lean_inc(x_312); +lean_inc(x_311); +lean_inc(x_310); +lean_dec(x_270); +x_315 = lean_ctor_get(x_297, 0); +lean_inc(x_315); +x_316 = lean_ctor_get(x_297, 1); +lean_inc(x_316); +x_317 = lean_ctor_get(x_297, 3); +lean_inc(x_317); +x_318 = lean_ctor_get(x_297, 4); +lean_inc(x_318); +if (lean_is_exclusive(x_297)) { + lean_ctor_release(x_297, 0); + lean_ctor_release(x_297, 1); + lean_ctor_release(x_297, 2); + lean_ctor_release(x_297, 3); + lean_ctor_release(x_297, 4); + x_319 = x_297; } else { - x_306 = x_305; + lean_dec_ref(x_297); + x_319 = lean_box(0); } -lean_ctor_set(x_306, 0, x_302); -lean_ctor_set(x_306, 1, x_303); -lean_ctor_set(x_306, 2, x_258); -lean_ctor_set(x_306, 3, x_304); -x_307 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_307, 0, x_297); -lean_ctor_set(x_307, 1, x_298); -lean_ctor_set(x_307, 2, x_306); -lean_ctor_set(x_307, 3, x_299); -lean_ctor_set(x_307, 4, x_300); -lean_ctor_set(x_307, 5, x_301); -if (lean_is_scalar(x_251)) { - x_308 = lean_alloc_ctor(0, 2, 0); +if (lean_is_scalar(x_319)) { + x_320 = lean_alloc_ctor(0, 5, 0); } else { - x_308 = x_251; + x_320 = x_319; } -lean_ctor_set(x_308, 0, x_286); -lean_ctor_set(x_308, 1, x_307); -return x_308; +lean_ctor_set(x_320, 0, x_315); +lean_ctor_set(x_320, 1, x_316); +lean_ctor_set(x_320, 2, x_268); +lean_ctor_set(x_320, 3, x_317); +lean_ctor_set(x_320, 4, x_318); +x_321 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_321, 0, x_310); +lean_ctor_set(x_321, 1, x_311); +lean_ctor_set(x_321, 2, x_320); +lean_ctor_set(x_321, 3, x_312); +lean_ctor_set(x_321, 4, x_313); +lean_ctor_set(x_321, 5, x_314); +if (lean_is_scalar(x_261)) { + x_322 = lean_alloc_ctor(0, 2, 0); +} else { + x_322 = x_261; +} +lean_ctor_set(x_322, 0, x_298); +lean_ctor_set(x_322, 1, x_321); +return x_322; } } } } else { -lean_object* x_337; lean_object* x_338; lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_374; lean_object* x_375; 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; -x_337 = lean_ctor_get(x_256, 0); -x_338 = lean_ctor_get(x_256, 1); -x_339 = lean_ctor_get(x_256, 2); -x_340 = lean_ctor_get(x_256, 3); -lean_inc(x_340); -lean_inc(x_339); -lean_inc(x_338); -lean_inc(x_337); -lean_dec(x_256); -x_374 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_375 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_375, 0, x_337); -lean_ctor_set(x_375, 1, x_338); -lean_ctor_set(x_375, 2, x_374); -lean_ctor_set(x_375, 3, x_340); -lean_ctor_set(x_250, 2, x_375); -x_376 = lean_ctor_get(x_6, 0); -lean_inc(x_376); -x_377 = lean_ctor_get(x_6, 1); -lean_inc(x_377); -x_378 = lean_ctor_get(x_6, 2); -lean_inc(x_378); -x_379 = lean_ctor_get(x_6, 3); -lean_inc(x_379); -x_380 = lean_ctor_get(x_6, 4); -lean_inc(x_380); +lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; lean_object* x_391; lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; lean_object* x_400; lean_object* x_401; lean_object* x_402; +x_351 = lean_ctor_get(x_266, 0); +x_352 = lean_ctor_get(x_266, 1); +x_353 = lean_ctor_get(x_266, 2); +x_354 = lean_ctor_get(x_266, 3); +x_355 = lean_ctor_get(x_266, 4); +lean_inc(x_355); +lean_inc(x_354); +lean_inc(x_353); +lean_inc(x_352); +lean_inc(x_351); +lean_dec(x_266); +x_391 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_392 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_392, 0, x_351); +lean_ctor_set(x_392, 1, x_352); +lean_ctor_set(x_392, 2, x_391); +lean_ctor_set(x_392, 3, x_354); +lean_ctor_set(x_392, 4, x_355); +lean_ctor_set(x_260, 2, x_392); +x_393 = lean_ctor_get(x_6, 0); +lean_inc(x_393); +x_394 = lean_ctor_get(x_6, 1); +lean_inc(x_394); +x_395 = lean_ctor_get(x_6, 2); +lean_inc(x_395); +x_396 = lean_ctor_get(x_6, 3); +lean_inc(x_396); +x_397 = lean_ctor_get(x_6, 4); +lean_inc(x_397); if (lean_is_exclusive(x_6)) { lean_ctor_release(x_6, 0); lean_ctor_release(x_6, 1); lean_ctor_release(x_6, 2); lean_ctor_release(x_6, 3); lean_ctor_release(x_6, 4); - x_381 = x_6; + x_398 = x_6; } else { lean_dec_ref(x_6); - x_381 = lean_box(0); + x_398 = lean_box(0); } -x_382 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_382, 0, x_252); -lean_ctor_set(x_382, 1, x_27); -x_383 = lean_array_push(x_378, x_382); -if (lean_is_scalar(x_381)) { - x_384 = lean_alloc_ctor(0, 5, 0); +x_399 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_399, 0, x_262); +lean_ctor_set(x_399, 1, x_27); +x_400 = lean_array_push(x_395, x_399); +if (lean_is_scalar(x_398)) { + x_401 = lean_alloc_ctor(0, 5, 0); } else { - x_384 = x_381; + x_401 = x_398; } -lean_ctor_set(x_384, 0, x_376); -lean_ctor_set(x_384, 1, x_377); -lean_ctor_set(x_384, 2, x_383); -lean_ctor_set(x_384, 3, x_379); -lean_ctor_set(x_384, 4, x_380); -x_385 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__6(x_1, x_2, x_3, x_4, x_254, x_384, x_250); -if (lean_obj_tag(x_385) == 0) +lean_ctor_set(x_401, 0, x_393); +lean_ctor_set(x_401, 1, x_394); +lean_ctor_set(x_401, 2, x_400); +lean_ctor_set(x_401, 3, x_396); +lean_ctor_set(x_401, 4, x_397); +x_402 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__6(x_1, x_2, x_3, x_4, x_264, x_401, x_260); +if (lean_obj_tag(x_402) == 0) { -lean_object* x_386; lean_object* x_387; lean_object* x_388; -x_386 = lean_ctor_get(x_385, 0); -lean_inc(x_386); -x_387 = lean_ctor_get(x_385, 1); -lean_inc(x_387); -lean_dec(x_385); -x_388 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_388, 0, x_386); -x_341 = x_388; -x_342 = x_387; -goto block_373; +lean_object* x_403; lean_object* x_404; lean_object* x_405; +x_403 = lean_ctor_get(x_402, 0); +lean_inc(x_403); +x_404 = lean_ctor_get(x_402, 1); +lean_inc(x_404); +lean_dec(x_402); +x_405 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_405, 0, x_403); +x_356 = x_405; +x_357 = x_404; +goto block_390; } else { -lean_object* x_389; lean_object* x_390; lean_object* x_391; -x_389 = lean_ctor_get(x_385, 0); -lean_inc(x_389); -x_390 = lean_ctor_get(x_385, 1); -lean_inc(x_390); -lean_dec(x_385); -x_391 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_391, 0, x_389); -x_341 = x_391; -x_342 = x_390; -goto block_373; +lean_object* x_406; lean_object* x_407; lean_object* x_408; +x_406 = lean_ctor_get(x_402, 0); +lean_inc(x_406); +x_407 = lean_ctor_get(x_402, 1); +lean_inc(x_407); +lean_dec(x_402); +x_408 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_408, 0, x_406); +x_356 = x_408; +x_357 = x_407; +goto block_390; } -block_373: +block_390: { -if (lean_obj_tag(x_341) == 0) +if (lean_obj_tag(x_356) == 0) { -lean_object* x_343; lean_object* x_344; lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; lean_object* x_350; lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; -x_343 = lean_ctor_get(x_342, 2); -lean_inc(x_343); -x_344 = lean_ctor_get(x_341, 0); -lean_inc(x_344); -lean_dec(x_341); -x_345 = lean_ctor_get(x_342, 0); -lean_inc(x_345); -x_346 = lean_ctor_get(x_342, 1); -lean_inc(x_346); -x_347 = lean_ctor_get(x_342, 3); -lean_inc(x_347); -x_348 = lean_ctor_get(x_342, 4); -lean_inc(x_348); -x_349 = lean_ctor_get(x_342, 5); -lean_inc(x_349); -if (lean_is_exclusive(x_342)) { - lean_ctor_release(x_342, 0); - lean_ctor_release(x_342, 1); - lean_ctor_release(x_342, 2); - lean_ctor_release(x_342, 3); - lean_ctor_release(x_342, 4); - lean_ctor_release(x_342, 5); - x_350 = x_342; -} else { - lean_dec_ref(x_342); - x_350 = lean_box(0); -} -x_351 = lean_ctor_get(x_343, 0); -lean_inc(x_351); -x_352 = lean_ctor_get(x_343, 1); -lean_inc(x_352); -x_353 = lean_ctor_get(x_343, 3); -lean_inc(x_353); -if (lean_is_exclusive(x_343)) { - lean_ctor_release(x_343, 0); - lean_ctor_release(x_343, 1); - lean_ctor_release(x_343, 2); - lean_ctor_release(x_343, 3); - x_354 = x_343; -} else { - lean_dec_ref(x_343); - x_354 = lean_box(0); -} -if (lean_is_scalar(x_354)) { - x_355 = lean_alloc_ctor(0, 4, 0); -} else { - x_355 = x_354; -} -lean_ctor_set(x_355, 0, x_351); -lean_ctor_set(x_355, 1, x_352); -lean_ctor_set(x_355, 2, x_339); -lean_ctor_set(x_355, 3, x_353); -if (lean_is_scalar(x_350)) { - x_356 = lean_alloc_ctor(0, 6, 0); -} else { - x_356 = x_350; -} -lean_ctor_set(x_356, 0, x_345); -lean_ctor_set(x_356, 1, x_346); -lean_ctor_set(x_356, 2, x_355); -lean_ctor_set(x_356, 3, x_347); -lean_ctor_set(x_356, 4, x_348); -lean_ctor_set(x_356, 5, x_349); -if (lean_is_scalar(x_251)) { - x_357 = lean_alloc_ctor(1, 2, 0); -} else { - x_357 = x_251; - lean_ctor_set_tag(x_357, 1); -} -lean_ctor_set(x_357, 0, x_344); -lean_ctor_set(x_357, 1, x_356); -return x_357; -} -else -{ -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; -x_358 = lean_ctor_get(x_342, 2); +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, 2); lean_inc(x_358); -x_359 = lean_ctor_get(x_341, 0); +x_359 = lean_ctor_get(x_356, 0); lean_inc(x_359); -lean_dec(x_341); -x_360 = lean_ctor_get(x_342, 0); +lean_dec(x_356); +x_360 = lean_ctor_get(x_357, 0); lean_inc(x_360); -x_361 = lean_ctor_get(x_342, 1); +x_361 = lean_ctor_get(x_357, 1); lean_inc(x_361); -x_362 = lean_ctor_get(x_342, 3); +x_362 = lean_ctor_get(x_357, 3); lean_inc(x_362); -x_363 = lean_ctor_get(x_342, 4); +x_363 = lean_ctor_get(x_357, 4); lean_inc(x_363); -x_364 = lean_ctor_get(x_342, 5); +x_364 = lean_ctor_get(x_357, 5); lean_inc(x_364); -if (lean_is_exclusive(x_342)) { - lean_ctor_release(x_342, 0); - lean_ctor_release(x_342, 1); - lean_ctor_release(x_342, 2); - lean_ctor_release(x_342, 3); - lean_ctor_release(x_342, 4); - lean_ctor_release(x_342, 5); - x_365 = x_342; +if (lean_is_exclusive(x_357)) { + lean_ctor_release(x_357, 0); + lean_ctor_release(x_357, 1); + lean_ctor_release(x_357, 2); + lean_ctor_release(x_357, 3); + lean_ctor_release(x_357, 4); + lean_ctor_release(x_357, 5); + x_365 = x_357; } else { - lean_dec_ref(x_342); + lean_dec_ref(x_357); x_365 = lean_box(0); } x_366 = lean_ctor_get(x_358, 0); @@ -8162,315 +8299,411 @@ x_367 = lean_ctor_get(x_358, 1); lean_inc(x_367); x_368 = lean_ctor_get(x_358, 3); lean_inc(x_368); +x_369 = lean_ctor_get(x_358, 4); +lean_inc(x_369); if (lean_is_exclusive(x_358)) { lean_ctor_release(x_358, 0); lean_ctor_release(x_358, 1); lean_ctor_release(x_358, 2); lean_ctor_release(x_358, 3); - x_369 = x_358; + lean_ctor_release(x_358, 4); + x_370 = x_358; } else { lean_dec_ref(x_358); - x_369 = lean_box(0); + x_370 = lean_box(0); } -if (lean_is_scalar(x_369)) { - x_370 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_370)) { + x_371 = lean_alloc_ctor(0, 5, 0); } else { - x_370 = x_369; + x_371 = x_370; } -lean_ctor_set(x_370, 0, x_366); -lean_ctor_set(x_370, 1, x_367); -lean_ctor_set(x_370, 2, x_339); -lean_ctor_set(x_370, 3, x_368); +lean_ctor_set(x_371, 0, x_366); +lean_ctor_set(x_371, 1, x_367); +lean_ctor_set(x_371, 2, x_353); +lean_ctor_set(x_371, 3, x_368); +lean_ctor_set(x_371, 4, x_369); if (lean_is_scalar(x_365)) { - x_371 = lean_alloc_ctor(0, 6, 0); + x_372 = lean_alloc_ctor(0, 6, 0); } else { - x_371 = x_365; + x_372 = x_365; } -lean_ctor_set(x_371, 0, x_360); -lean_ctor_set(x_371, 1, x_361); -lean_ctor_set(x_371, 2, x_370); -lean_ctor_set(x_371, 3, x_362); -lean_ctor_set(x_371, 4, x_363); -lean_ctor_set(x_371, 5, x_364); -if (lean_is_scalar(x_251)) { - x_372 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_372, 0, x_360); +lean_ctor_set(x_372, 1, x_361); +lean_ctor_set(x_372, 2, x_371); +lean_ctor_set(x_372, 3, x_362); +lean_ctor_set(x_372, 4, x_363); +lean_ctor_set(x_372, 5, x_364); +if (lean_is_scalar(x_261)) { + x_373 = lean_alloc_ctor(1, 2, 0); } else { - x_372 = x_251; + x_373 = x_261; + lean_ctor_set_tag(x_373, 1); } -lean_ctor_set(x_372, 0, x_359); -lean_ctor_set(x_372, 1, x_371); -return x_372; +lean_ctor_set(x_373, 0, x_359); +lean_ctor_set(x_373, 1, x_372); +return x_373; +} +else +{ +lean_object* x_374; lean_object* x_375; 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; +x_374 = lean_ctor_get(x_357, 2); +lean_inc(x_374); +x_375 = lean_ctor_get(x_356, 0); +lean_inc(x_375); +lean_dec(x_356); +x_376 = lean_ctor_get(x_357, 0); +lean_inc(x_376); +x_377 = lean_ctor_get(x_357, 1); +lean_inc(x_377); +x_378 = lean_ctor_get(x_357, 3); +lean_inc(x_378); +x_379 = lean_ctor_get(x_357, 4); +lean_inc(x_379); +x_380 = lean_ctor_get(x_357, 5); +lean_inc(x_380); +if (lean_is_exclusive(x_357)) { + lean_ctor_release(x_357, 0); + lean_ctor_release(x_357, 1); + lean_ctor_release(x_357, 2); + lean_ctor_release(x_357, 3); + lean_ctor_release(x_357, 4); + lean_ctor_release(x_357, 5); + x_381 = x_357; +} else { + lean_dec_ref(x_357); + x_381 = lean_box(0); +} +x_382 = lean_ctor_get(x_374, 0); +lean_inc(x_382); +x_383 = lean_ctor_get(x_374, 1); +lean_inc(x_383); +x_384 = lean_ctor_get(x_374, 3); +lean_inc(x_384); +x_385 = lean_ctor_get(x_374, 4); +lean_inc(x_385); +if (lean_is_exclusive(x_374)) { + lean_ctor_release(x_374, 0); + lean_ctor_release(x_374, 1); + lean_ctor_release(x_374, 2); + lean_ctor_release(x_374, 3); + lean_ctor_release(x_374, 4); + x_386 = x_374; +} else { + lean_dec_ref(x_374); + x_386 = lean_box(0); +} +if (lean_is_scalar(x_386)) { + x_387 = lean_alloc_ctor(0, 5, 0); +} else { + x_387 = x_386; +} +lean_ctor_set(x_387, 0, x_382); +lean_ctor_set(x_387, 1, x_383); +lean_ctor_set(x_387, 2, x_353); +lean_ctor_set(x_387, 3, x_384); +lean_ctor_set(x_387, 4, x_385); +if (lean_is_scalar(x_381)) { + x_388 = lean_alloc_ctor(0, 6, 0); +} else { + x_388 = x_381; +} +lean_ctor_set(x_388, 0, x_376); +lean_ctor_set(x_388, 1, x_377); +lean_ctor_set(x_388, 2, x_387); +lean_ctor_set(x_388, 3, x_378); +lean_ctor_set(x_388, 4, x_379); +lean_ctor_set(x_388, 5, x_380); +if (lean_is_scalar(x_261)) { + x_389 = lean_alloc_ctor(0, 2, 0); +} else { + x_389 = x_261; +} +lean_ctor_set(x_389, 0, x_375); +lean_ctor_set(x_389, 1, x_388); +return x_389; } } } } else { -lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; lean_object* x_400; lean_object* x_401; lean_object* x_402; lean_object* x_403; lean_object* x_404; 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; lean_object* x_445; lean_object* x_446; lean_object* x_447; lean_object* x_448; -x_392 = lean_ctor_get(x_250, 2); -x_393 = lean_ctor_get(x_250, 0); -x_394 = lean_ctor_get(x_250, 1); -x_395 = lean_ctor_get(x_250, 3); -x_396 = lean_ctor_get(x_250, 4); -x_397 = lean_ctor_get(x_250, 5); -lean_inc(x_397); -lean_inc(x_396); -lean_inc(x_395); -lean_inc(x_392); -lean_inc(x_394); -lean_inc(x_393); -lean_dec(x_250); -x_398 = lean_ctor_get(x_392, 0); -lean_inc(x_398); -x_399 = lean_ctor_get(x_392, 1); -lean_inc(x_399); -x_400 = lean_ctor_get(x_392, 2); -lean_inc(x_400); -x_401 = lean_ctor_get(x_392, 3); -lean_inc(x_401); -if (lean_is_exclusive(x_392)) { - lean_ctor_release(x_392, 0); - lean_ctor_release(x_392, 1); - lean_ctor_release(x_392, 2); - lean_ctor_release(x_392, 3); - x_402 = x_392; +lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_object* x_412; lean_object* x_413; lean_object* x_414; lean_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_456; lean_object* x_457; lean_object* x_458; lean_object* x_459; lean_object* x_460; lean_object* x_461; lean_object* x_462; lean_object* x_463; lean_object* x_464; lean_object* x_465; lean_object* x_466; lean_object* x_467; lean_object* x_468; +x_409 = lean_ctor_get(x_260, 2); +x_410 = lean_ctor_get(x_260, 0); +x_411 = lean_ctor_get(x_260, 1); +x_412 = lean_ctor_get(x_260, 3); +x_413 = lean_ctor_get(x_260, 4); +x_414 = lean_ctor_get(x_260, 5); +lean_inc(x_414); +lean_inc(x_413); +lean_inc(x_412); +lean_inc(x_409); +lean_inc(x_411); +lean_inc(x_410); +lean_dec(x_260); +x_415 = lean_ctor_get(x_409, 0); +lean_inc(x_415); +x_416 = lean_ctor_get(x_409, 1); +lean_inc(x_416); +x_417 = lean_ctor_get(x_409, 2); +lean_inc(x_417); +x_418 = lean_ctor_get(x_409, 3); +lean_inc(x_418); +x_419 = lean_ctor_get(x_409, 4); +lean_inc(x_419); +if (lean_is_exclusive(x_409)) { + lean_ctor_release(x_409, 0); + lean_ctor_release(x_409, 1); + lean_ctor_release(x_409, 2); + lean_ctor_release(x_409, 3); + lean_ctor_release(x_409, 4); + x_420 = x_409; } else { - lean_dec_ref(x_392); - x_402 = lean_box(0); + lean_dec_ref(x_409); + x_420 = lean_box(0); } -x_436 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_402)) { - x_437 = lean_alloc_ctor(0, 4, 0); +x_456 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_420)) { + x_457 = lean_alloc_ctor(0, 5, 0); } else { - x_437 = x_402; + x_457 = x_420; } -lean_ctor_set(x_437, 0, x_398); -lean_ctor_set(x_437, 1, x_399); -lean_ctor_set(x_437, 2, x_436); -lean_ctor_set(x_437, 3, x_401); -x_438 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_438, 0, x_393); -lean_ctor_set(x_438, 1, x_394); -lean_ctor_set(x_438, 2, x_437); -lean_ctor_set(x_438, 3, x_395); -lean_ctor_set(x_438, 4, x_396); -lean_ctor_set(x_438, 5, x_397); -x_439 = lean_ctor_get(x_6, 0); -lean_inc(x_439); -x_440 = lean_ctor_get(x_6, 1); -lean_inc(x_440); -x_441 = lean_ctor_get(x_6, 2); -lean_inc(x_441); -x_442 = lean_ctor_get(x_6, 3); -lean_inc(x_442); -x_443 = lean_ctor_get(x_6, 4); -lean_inc(x_443); +lean_ctor_set(x_457, 0, x_415); +lean_ctor_set(x_457, 1, x_416); +lean_ctor_set(x_457, 2, x_456); +lean_ctor_set(x_457, 3, x_418); +lean_ctor_set(x_457, 4, x_419); +x_458 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_458, 0, x_410); +lean_ctor_set(x_458, 1, x_411); +lean_ctor_set(x_458, 2, x_457); +lean_ctor_set(x_458, 3, x_412); +lean_ctor_set(x_458, 4, x_413); +lean_ctor_set(x_458, 5, x_414); +x_459 = lean_ctor_get(x_6, 0); +lean_inc(x_459); +x_460 = lean_ctor_get(x_6, 1); +lean_inc(x_460); +x_461 = lean_ctor_get(x_6, 2); +lean_inc(x_461); +x_462 = lean_ctor_get(x_6, 3); +lean_inc(x_462); +x_463 = lean_ctor_get(x_6, 4); +lean_inc(x_463); if (lean_is_exclusive(x_6)) { lean_ctor_release(x_6, 0); lean_ctor_release(x_6, 1); lean_ctor_release(x_6, 2); lean_ctor_release(x_6, 3); lean_ctor_release(x_6, 4); - x_444 = x_6; + x_464 = x_6; } else { lean_dec_ref(x_6); - x_444 = lean_box(0); + x_464 = lean_box(0); } -x_445 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_445, 0, x_252); -lean_ctor_set(x_445, 1, x_27); -x_446 = lean_array_push(x_441, x_445); -if (lean_is_scalar(x_444)) { - x_447 = lean_alloc_ctor(0, 5, 0); +x_465 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_465, 0, x_262); +lean_ctor_set(x_465, 1, x_27); +x_466 = lean_array_push(x_461, x_465); +if (lean_is_scalar(x_464)) { + x_467 = lean_alloc_ctor(0, 5, 0); } else { - x_447 = x_444; + x_467 = x_464; } -lean_ctor_set(x_447, 0, x_439); -lean_ctor_set(x_447, 1, x_440); -lean_ctor_set(x_447, 2, x_446); -lean_ctor_set(x_447, 3, x_442); -lean_ctor_set(x_447, 4, x_443); -x_448 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__6(x_1, x_2, x_3, x_4, x_254, x_447, x_438); -if (lean_obj_tag(x_448) == 0) +lean_ctor_set(x_467, 0, x_459); +lean_ctor_set(x_467, 1, x_460); +lean_ctor_set(x_467, 2, x_466); +lean_ctor_set(x_467, 3, x_462); +lean_ctor_set(x_467, 4, x_463); +x_468 = l_Lean_Meta_withNewLocalInstances___main___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__6(x_1, x_2, x_3, x_4, x_264, x_467, x_458); +if (lean_obj_tag(x_468) == 0) { -lean_object* x_449; lean_object* x_450; lean_object* x_451; -x_449 = lean_ctor_get(x_448, 0); -lean_inc(x_449); -x_450 = lean_ctor_get(x_448, 1); -lean_inc(x_450); -lean_dec(x_448); -x_451 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_451, 0, x_449); -x_403 = x_451; -x_404 = x_450; -goto block_435; +lean_object* x_469; lean_object* x_470; lean_object* x_471; +x_469 = lean_ctor_get(x_468, 0); +lean_inc(x_469); +x_470 = lean_ctor_get(x_468, 1); +lean_inc(x_470); +lean_dec(x_468); +x_471 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_471, 0, x_469); +x_421 = x_471; +x_422 = x_470; +goto block_455; } else { -lean_object* x_452; lean_object* x_453; lean_object* x_454; -x_452 = lean_ctor_get(x_448, 0); -lean_inc(x_452); -x_453 = lean_ctor_get(x_448, 1); -lean_inc(x_453); -lean_dec(x_448); -x_454 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_454, 0, x_452); -x_403 = x_454; -x_404 = x_453; -goto block_435; +lean_object* x_472; lean_object* x_473; lean_object* x_474; +x_472 = lean_ctor_get(x_468, 0); +lean_inc(x_472); +x_473 = lean_ctor_get(x_468, 1); +lean_inc(x_473); +lean_dec(x_468); +x_474 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_474, 0, x_472); +x_421 = x_474; +x_422 = x_473; +goto block_455; } -block_435: +block_455: { -if (lean_obj_tag(x_403) == 0) +if (lean_obj_tag(x_421) == 0) { -lean_object* x_405; lean_object* x_406; lean_object* x_407; lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_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; -x_405 = lean_ctor_get(x_404, 2); -lean_inc(x_405); -x_406 = lean_ctor_get(x_403, 0); -lean_inc(x_406); -lean_dec(x_403); -x_407 = lean_ctor_get(x_404, 0); -lean_inc(x_407); -x_408 = lean_ctor_get(x_404, 1); -lean_inc(x_408); -x_409 = lean_ctor_get(x_404, 3); -lean_inc(x_409); -x_410 = lean_ctor_get(x_404, 4); -lean_inc(x_410); -x_411 = lean_ctor_get(x_404, 5); -lean_inc(x_411); -if (lean_is_exclusive(x_404)) { - lean_ctor_release(x_404, 0); - lean_ctor_release(x_404, 1); - lean_ctor_release(x_404, 2); - lean_ctor_release(x_404, 3); - lean_ctor_release(x_404, 4); - lean_ctor_release(x_404, 5); - x_412 = x_404; -} else { - lean_dec_ref(x_404); - x_412 = lean_box(0); -} -x_413 = lean_ctor_get(x_405, 0); -lean_inc(x_413); -x_414 = lean_ctor_get(x_405, 1); -lean_inc(x_414); -x_415 = lean_ctor_get(x_405, 3); -lean_inc(x_415); -if (lean_is_exclusive(x_405)) { - lean_ctor_release(x_405, 0); - lean_ctor_release(x_405, 1); - lean_ctor_release(x_405, 2); - lean_ctor_release(x_405, 3); - x_416 = x_405; -} else { - lean_dec_ref(x_405); - x_416 = lean_box(0); -} -if (lean_is_scalar(x_416)) { - x_417 = lean_alloc_ctor(0, 4, 0); -} else { - x_417 = x_416; -} -lean_ctor_set(x_417, 0, x_413); -lean_ctor_set(x_417, 1, x_414); -lean_ctor_set(x_417, 2, x_400); -lean_ctor_set(x_417, 3, x_415); -if (lean_is_scalar(x_412)) { - x_418 = lean_alloc_ctor(0, 6, 0); -} else { - x_418 = x_412; -} -lean_ctor_set(x_418, 0, x_407); -lean_ctor_set(x_418, 1, x_408); -lean_ctor_set(x_418, 2, x_417); -lean_ctor_set(x_418, 3, x_409); -lean_ctor_set(x_418, 4, x_410); -lean_ctor_set(x_418, 5, x_411); -if (lean_is_scalar(x_251)) { - x_419 = lean_alloc_ctor(1, 2, 0); -} else { - x_419 = x_251; - lean_ctor_set_tag(x_419, 1); -} -lean_ctor_set(x_419, 0, x_406); -lean_ctor_set(x_419, 1, x_418); -return x_419; -} -else -{ -lean_object* x_420; lean_object* x_421; lean_object* x_422; lean_object* x_423; lean_object* x_424; lean_object* x_425; lean_object* x_426; lean_object* x_427; 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; -x_420 = lean_ctor_get(x_404, 2); -lean_inc(x_420); -x_421 = lean_ctor_get(x_403, 0); -lean_inc(x_421); -lean_dec(x_403); -x_422 = lean_ctor_get(x_404, 0); -lean_inc(x_422); -x_423 = lean_ctor_get(x_404, 1); +lean_object* x_423; lean_object* x_424; lean_object* x_425; lean_object* x_426; lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; 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; +x_423 = lean_ctor_get(x_422, 2); lean_inc(x_423); -x_424 = lean_ctor_get(x_404, 3); +x_424 = lean_ctor_get(x_421, 0); lean_inc(x_424); -x_425 = lean_ctor_get(x_404, 4); +lean_dec(x_421); +x_425 = lean_ctor_get(x_422, 0); lean_inc(x_425); -x_426 = lean_ctor_get(x_404, 5); +x_426 = lean_ctor_get(x_422, 1); lean_inc(x_426); -if (lean_is_exclusive(x_404)) { - lean_ctor_release(x_404, 0); - lean_ctor_release(x_404, 1); - lean_ctor_release(x_404, 2); - lean_ctor_release(x_404, 3); - lean_ctor_release(x_404, 4); - lean_ctor_release(x_404, 5); - x_427 = x_404; -} else { - lean_dec_ref(x_404); - x_427 = lean_box(0); -} -x_428 = lean_ctor_get(x_420, 0); +x_427 = lean_ctor_get(x_422, 3); +lean_inc(x_427); +x_428 = lean_ctor_get(x_422, 4); lean_inc(x_428); -x_429 = lean_ctor_get(x_420, 1); +x_429 = lean_ctor_get(x_422, 5); lean_inc(x_429); -x_430 = lean_ctor_get(x_420, 3); -lean_inc(x_430); -if (lean_is_exclusive(x_420)) { - lean_ctor_release(x_420, 0); - lean_ctor_release(x_420, 1); - lean_ctor_release(x_420, 2); - lean_ctor_release(x_420, 3); - x_431 = x_420; +if (lean_is_exclusive(x_422)) { + lean_ctor_release(x_422, 0); + lean_ctor_release(x_422, 1); + lean_ctor_release(x_422, 2); + lean_ctor_release(x_422, 3); + lean_ctor_release(x_422, 4); + lean_ctor_release(x_422, 5); + x_430 = x_422; } else { - lean_dec_ref(x_420); - x_431 = lean_box(0); + lean_dec_ref(x_422); + x_430 = lean_box(0); } -if (lean_is_scalar(x_431)) { - x_432 = lean_alloc_ctor(0, 4, 0); +x_431 = lean_ctor_get(x_423, 0); +lean_inc(x_431); +x_432 = lean_ctor_get(x_423, 1); +lean_inc(x_432); +x_433 = lean_ctor_get(x_423, 3); +lean_inc(x_433); +x_434 = lean_ctor_get(x_423, 4); +lean_inc(x_434); +if (lean_is_exclusive(x_423)) { + lean_ctor_release(x_423, 0); + lean_ctor_release(x_423, 1); + lean_ctor_release(x_423, 2); + lean_ctor_release(x_423, 3); + lean_ctor_release(x_423, 4); + x_435 = x_423; } else { - x_432 = x_431; + lean_dec_ref(x_423); + x_435 = lean_box(0); } -lean_ctor_set(x_432, 0, x_428); -lean_ctor_set(x_432, 1, x_429); -lean_ctor_set(x_432, 2, x_400); -lean_ctor_set(x_432, 3, x_430); -if (lean_is_scalar(x_427)) { - x_433 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_435)) { + x_436 = lean_alloc_ctor(0, 5, 0); } else { - x_433 = x_427; + x_436 = x_435; } -lean_ctor_set(x_433, 0, x_422); -lean_ctor_set(x_433, 1, x_423); -lean_ctor_set(x_433, 2, x_432); -lean_ctor_set(x_433, 3, x_424); -lean_ctor_set(x_433, 4, x_425); -lean_ctor_set(x_433, 5, x_426); -if (lean_is_scalar(x_251)) { - x_434 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_436, 0, x_431); +lean_ctor_set(x_436, 1, x_432); +lean_ctor_set(x_436, 2, x_417); +lean_ctor_set(x_436, 3, x_433); +lean_ctor_set(x_436, 4, x_434); +if (lean_is_scalar(x_430)) { + x_437 = lean_alloc_ctor(0, 6, 0); } else { - x_434 = x_251; + x_437 = x_430; } -lean_ctor_set(x_434, 0, x_421); -lean_ctor_set(x_434, 1, x_433); -return x_434; +lean_ctor_set(x_437, 0, x_425); +lean_ctor_set(x_437, 1, x_426); +lean_ctor_set(x_437, 2, x_436); +lean_ctor_set(x_437, 3, x_427); +lean_ctor_set(x_437, 4, x_428); +lean_ctor_set(x_437, 5, x_429); +if (lean_is_scalar(x_261)) { + x_438 = lean_alloc_ctor(1, 2, 0); +} else { + x_438 = x_261; + lean_ctor_set_tag(x_438, 1); +} +lean_ctor_set(x_438, 0, x_424); +lean_ctor_set(x_438, 1, x_437); +return x_438; +} +else +{ +lean_object* x_439; lean_object* x_440; lean_object* x_441; lean_object* x_442; lean_object* x_443; lean_object* x_444; lean_object* x_445; lean_object* x_446; lean_object* x_447; lean_object* x_448; lean_object* x_449; lean_object* x_450; lean_object* x_451; lean_object* x_452; lean_object* x_453; lean_object* x_454; +x_439 = lean_ctor_get(x_422, 2); +lean_inc(x_439); +x_440 = lean_ctor_get(x_421, 0); +lean_inc(x_440); +lean_dec(x_421); +x_441 = lean_ctor_get(x_422, 0); +lean_inc(x_441); +x_442 = lean_ctor_get(x_422, 1); +lean_inc(x_442); +x_443 = lean_ctor_get(x_422, 3); +lean_inc(x_443); +x_444 = lean_ctor_get(x_422, 4); +lean_inc(x_444); +x_445 = lean_ctor_get(x_422, 5); +lean_inc(x_445); +if (lean_is_exclusive(x_422)) { + lean_ctor_release(x_422, 0); + lean_ctor_release(x_422, 1); + lean_ctor_release(x_422, 2); + lean_ctor_release(x_422, 3); + lean_ctor_release(x_422, 4); + lean_ctor_release(x_422, 5); + x_446 = x_422; +} else { + lean_dec_ref(x_422); + x_446 = lean_box(0); +} +x_447 = lean_ctor_get(x_439, 0); +lean_inc(x_447); +x_448 = lean_ctor_get(x_439, 1); +lean_inc(x_448); +x_449 = lean_ctor_get(x_439, 3); +lean_inc(x_449); +x_450 = lean_ctor_get(x_439, 4); +lean_inc(x_450); +if (lean_is_exclusive(x_439)) { + lean_ctor_release(x_439, 0); + lean_ctor_release(x_439, 1); + lean_ctor_release(x_439, 2); + lean_ctor_release(x_439, 3); + lean_ctor_release(x_439, 4); + x_451 = x_439; +} else { + lean_dec_ref(x_439); + x_451 = lean_box(0); +} +if (lean_is_scalar(x_451)) { + x_452 = lean_alloc_ctor(0, 5, 0); +} else { + x_452 = x_451; +} +lean_ctor_set(x_452, 0, x_447); +lean_ctor_set(x_452, 1, x_448); +lean_ctor_set(x_452, 2, x_417); +lean_ctor_set(x_452, 3, x_449); +lean_ctor_set(x_452, 4, x_450); +if (lean_is_scalar(x_446)) { + x_453 = lean_alloc_ctor(0, 6, 0); +} else { + x_453 = x_446; +} +lean_ctor_set(x_453, 0, x_441); +lean_ctor_set(x_453, 1, x_442); +lean_ctor_set(x_453, 2, x_452); +lean_ctor_set(x_453, 3, x_443); +lean_ctor_set(x_453, 4, x_444); +lean_ctor_set(x_453, 5, x_445); +if (lean_is_scalar(x_261)) { + x_454 = lean_alloc_ctor(0, 2, 0); +} else { + x_454 = x_261; +} +lean_ctor_set(x_454, 0, x_440); +lean_ctor_set(x_454, 1, x_453); +return x_454; } } } @@ -8478,28 +8711,28 @@ return x_434; } else { -uint8_t x_455; +uint8_t x_475; lean_dec(x_27); lean_dec(x_6); lean_dec(x_5); lean_dec(x_2); -x_455 = !lean_is_exclusive(x_244); -if (x_455 == 0) +x_475 = !lean_is_exclusive(x_254); +if (x_475 == 0) { -return x_244; +return x_254; } else { -lean_object* x_456; lean_object* x_457; lean_object* x_458; -x_456 = lean_ctor_get(x_244, 0); -x_457 = lean_ctor_get(x_244, 1); -lean_inc(x_457); -lean_inc(x_456); -lean_dec(x_244); -x_458 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_458, 0, x_456); -lean_ctor_set(x_458, 1, x_457); -return x_458; +lean_object* x_476; lean_object* x_477; lean_object* x_478; +x_476 = lean_ctor_get(x_254, 0); +x_477 = lean_ctor_get(x_254, 1); +lean_inc(x_477); +lean_inc(x_476); +lean_dec(x_254); +x_478 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_478, 0, x_476); +lean_ctor_set(x_478, 1, x_477); +return x_478; } } } @@ -8507,56 +8740,56 @@ return x_458; } else { -uint8_t x_459; +uint8_t x_479; lean_dec(x_31); lean_dec(x_27); lean_dec(x_6); lean_dec(x_5); lean_dec(x_2); -x_459 = !lean_is_exclusive(x_32); -if (x_459 == 0) +x_479 = !lean_is_exclusive(x_32); +if (x_479 == 0) { return x_32; } else { -lean_object* x_460; lean_object* x_461; lean_object* x_462; -x_460 = lean_ctor_get(x_32, 0); -x_461 = lean_ctor_get(x_32, 1); -lean_inc(x_461); -lean_inc(x_460); +lean_object* x_480; lean_object* x_481; lean_object* x_482; +x_480 = lean_ctor_get(x_32, 0); +x_481 = lean_ctor_get(x_32, 1); +lean_inc(x_481); +lean_inc(x_480); lean_dec(x_32); -x_462 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_462, 0, x_460); -lean_ctor_set(x_462, 1, x_461); -return x_462; +x_482 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_482, 0, x_480); +lean_ctor_set(x_482, 1, x_481); +return x_482; } } } else { -uint8_t x_463; +uint8_t x_483; lean_dec(x_27); lean_dec(x_6); lean_dec(x_5); lean_dec(x_2); -x_463 = !lean_is_exclusive(x_28); -if (x_463 == 0) +x_483 = !lean_is_exclusive(x_28); +if (x_483 == 0) { return x_28; } else { -lean_object* x_464; lean_object* x_465; lean_object* x_466; -x_464 = lean_ctor_get(x_28, 0); -x_465 = lean_ctor_get(x_28, 1); -lean_inc(x_465); -lean_inc(x_464); +lean_object* x_484; lean_object* x_485; lean_object* x_486; +x_484 = lean_ctor_get(x_28, 0); +x_485 = lean_ctor_get(x_28, 1); +lean_inc(x_485); +lean_inc(x_484); lean_dec(x_28); -x_466 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_466, 0, x_464); -lean_ctor_set(x_466, 1, x_465); -return x_466; +x_486 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_486, 0, x_484); +lean_ctor_set(x_486, 1, x_485); +return x_486; } } } @@ -9003,97 +9236,104 @@ return x_27; } else { -lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; +lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; x_38 = lean_ctor_get(x_29, 0); x_39 = lean_ctor_get(x_29, 1); x_40 = lean_ctor_get(x_29, 2); x_41 = lean_ctor_get(x_29, 3); +x_42 = lean_ctor_get(x_29, 4); +lean_inc(x_42); lean_inc(x_41); lean_inc(x_40); lean_inc(x_39); lean_inc(x_38); lean_dec(x_29); lean_inc(x_31); -x_42 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4(x_39, x_15, x_31); -x_43 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_43, 0, x_38); -lean_ctor_set(x_43, 1, x_42); -lean_ctor_set(x_43, 2, x_40); -lean_ctor_set(x_43, 3, x_41); -lean_ctor_set(x_28, 2, x_43); +x_43 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4(x_39, x_15, x_31); +x_44 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_44, 0, x_38); +lean_ctor_set(x_44, 1, x_43); +lean_ctor_set(x_44, 2, x_40); +lean_ctor_set(x_44, 3, x_41); +lean_ctor_set(x_44, 4, x_42); +lean_ctor_set(x_28, 2, x_44); return x_27; } } 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; -x_44 = lean_ctor_get(x_28, 0); -x_45 = lean_ctor_get(x_28, 1); -x_46 = lean_ctor_get(x_28, 3); -x_47 = lean_ctor_get(x_28, 4); -x_48 = lean_ctor_get(x_28, 5); +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; +x_45 = lean_ctor_get(x_28, 0); +x_46 = lean_ctor_get(x_28, 1); +x_47 = lean_ctor_get(x_28, 3); +x_48 = lean_ctor_get(x_28, 4); +x_49 = lean_ctor_get(x_28, 5); +lean_inc(x_49); lean_inc(x_48); lean_inc(x_47); lean_inc(x_46); lean_inc(x_45); -lean_inc(x_44); lean_dec(x_28); -x_49 = lean_ctor_get(x_29, 0); -lean_inc(x_49); -x_50 = lean_ctor_get(x_29, 1); +x_50 = lean_ctor_get(x_29, 0); lean_inc(x_50); -x_51 = lean_ctor_get(x_29, 2); +x_51 = lean_ctor_get(x_29, 1); lean_inc(x_51); -x_52 = lean_ctor_get(x_29, 3); +x_52 = lean_ctor_get(x_29, 2); lean_inc(x_52); +x_53 = lean_ctor_get(x_29, 3); +lean_inc(x_53); +x_54 = lean_ctor_get(x_29, 4); +lean_inc(x_54); if (lean_is_exclusive(x_29)) { lean_ctor_release(x_29, 0); lean_ctor_release(x_29, 1); lean_ctor_release(x_29, 2); lean_ctor_release(x_29, 3); - x_53 = x_29; + lean_ctor_release(x_29, 4); + x_55 = x_29; } else { lean_dec_ref(x_29); - x_53 = lean_box(0); + x_55 = lean_box(0); } lean_inc(x_31); -x_54 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4(x_50, x_15, x_31); -if (lean_is_scalar(x_53)) { - x_55 = lean_alloc_ctor(0, 4, 0); +x_56 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4(x_51, x_15, x_31); +if (lean_is_scalar(x_55)) { + x_57 = lean_alloc_ctor(0, 5, 0); } else { - x_55 = x_53; + x_57 = x_55; } -lean_ctor_set(x_55, 0, x_49); -lean_ctor_set(x_55, 1, x_54); -lean_ctor_set(x_55, 2, x_51); -lean_ctor_set(x_55, 3, x_52); -x_56 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_56, 0, x_44); -lean_ctor_set(x_56, 1, x_45); -lean_ctor_set(x_56, 2, x_55); -lean_ctor_set(x_56, 3, x_46); -lean_ctor_set(x_56, 4, x_47); -lean_ctor_set(x_56, 5, x_48); -lean_ctor_set(x_27, 1, x_56); +lean_ctor_set(x_57, 0, x_50); +lean_ctor_set(x_57, 1, x_56); +lean_ctor_set(x_57, 2, x_52); +lean_ctor_set(x_57, 3, x_53); +lean_ctor_set(x_57, 4, x_54); +x_58 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_58, 0, x_45); +lean_ctor_set(x_58, 1, x_46); +lean_ctor_set(x_58, 2, x_57); +lean_ctor_set(x_58, 3, x_47); +lean_ctor_set(x_58, 4, x_48); +lean_ctor_set(x_58, 5, x_49); +lean_ctor_set(x_27, 1, x_58); return x_27; } } else { -lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; -x_57 = lean_ctor_get(x_27, 0); -lean_inc(x_57); -lean_dec(x_27); -x_58 = lean_ctor_get(x_28, 0); -lean_inc(x_58); -x_59 = lean_ctor_get(x_28, 1); +lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; +x_59 = lean_ctor_get(x_27, 0); lean_inc(x_59); -x_60 = lean_ctor_get(x_28, 3); +lean_dec(x_27); +x_60 = lean_ctor_get(x_28, 0); lean_inc(x_60); -x_61 = lean_ctor_get(x_28, 4); +x_61 = lean_ctor_get(x_28, 1); lean_inc(x_61); -x_62 = lean_ctor_get(x_28, 5); +x_62 = lean_ctor_get(x_28, 3); lean_inc(x_62); +x_63 = lean_ctor_get(x_28, 4); +lean_inc(x_63); +x_64 = lean_ctor_get(x_28, 5); +lean_inc(x_64); if (lean_is_exclusive(x_28)) { lean_ctor_release(x_28, 0); lean_ctor_release(x_28, 1); @@ -9101,84 +9341,88 @@ if (lean_is_exclusive(x_28)) { lean_ctor_release(x_28, 3); lean_ctor_release(x_28, 4); lean_ctor_release(x_28, 5); - x_63 = x_28; + x_65 = x_28; } else { lean_dec_ref(x_28); - x_63 = lean_box(0); + x_65 = lean_box(0); } -x_64 = lean_ctor_get(x_29, 0); -lean_inc(x_64); -x_65 = lean_ctor_get(x_29, 1); -lean_inc(x_65); -x_66 = lean_ctor_get(x_29, 2); +x_66 = lean_ctor_get(x_29, 0); lean_inc(x_66); -x_67 = lean_ctor_get(x_29, 3); +x_67 = lean_ctor_get(x_29, 1); lean_inc(x_67); +x_68 = lean_ctor_get(x_29, 2); +lean_inc(x_68); +x_69 = lean_ctor_get(x_29, 3); +lean_inc(x_69); +x_70 = lean_ctor_get(x_29, 4); +lean_inc(x_70); if (lean_is_exclusive(x_29)) { lean_ctor_release(x_29, 0); lean_ctor_release(x_29, 1); lean_ctor_release(x_29, 2); lean_ctor_release(x_29, 3); - x_68 = x_29; + lean_ctor_release(x_29, 4); + x_71 = x_29; } else { lean_dec_ref(x_29); - x_68 = lean_box(0); + x_71 = lean_box(0); } -lean_inc(x_57); -x_69 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4(x_65, x_15, x_57); -if (lean_is_scalar(x_68)) { - x_70 = lean_alloc_ctor(0, 4, 0); +lean_inc(x_59); +x_72 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4(x_67, x_15, x_59); +if (lean_is_scalar(x_71)) { + x_73 = lean_alloc_ctor(0, 5, 0); } else { - x_70 = x_68; + x_73 = x_71; } -lean_ctor_set(x_70, 0, x_64); -lean_ctor_set(x_70, 1, x_69); -lean_ctor_set(x_70, 2, x_66); -lean_ctor_set(x_70, 3, x_67); -if (lean_is_scalar(x_63)) { - x_71 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_73, 0, x_66); +lean_ctor_set(x_73, 1, x_72); +lean_ctor_set(x_73, 2, x_68); +lean_ctor_set(x_73, 3, x_69); +lean_ctor_set(x_73, 4, x_70); +if (lean_is_scalar(x_65)) { + x_74 = lean_alloc_ctor(0, 6, 0); } else { - x_71 = x_63; + x_74 = x_65; } -lean_ctor_set(x_71, 0, x_58); -lean_ctor_set(x_71, 1, x_59); -lean_ctor_set(x_71, 2, x_70); -lean_ctor_set(x_71, 3, x_60); -lean_ctor_set(x_71, 4, x_61); -lean_ctor_set(x_71, 5, x_62); -x_72 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_72, 0, x_57); -lean_ctor_set(x_72, 1, x_71); -return x_72; +lean_ctor_set(x_74, 0, x_60); +lean_ctor_set(x_74, 1, x_61); +lean_ctor_set(x_74, 2, x_73); +lean_ctor_set(x_74, 3, x_62); +lean_ctor_set(x_74, 4, x_63); +lean_ctor_set(x_74, 5, x_64); +x_75 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_75, 0, x_59); +lean_ctor_set(x_75, 1, x_74); +return x_75; } } else { -uint8_t x_73; +uint8_t x_76; lean_dec(x_15); -x_73 = !lean_is_exclusive(x_27); -if (x_73 == 0) +x_76 = !lean_is_exclusive(x_27); +if (x_76 == 0) { return x_27; } else { -lean_object* x_74; lean_object* x_75; lean_object* x_76; -x_74 = lean_ctor_get(x_27, 0); -x_75 = lean_ctor_get(x_27, 1); -lean_inc(x_75); -lean_inc(x_74); +lean_object* x_77; lean_object* x_78; lean_object* x_79; +x_77 = lean_ctor_get(x_27, 0); +x_78 = lean_ctor_get(x_27, 1); +lean_inc(x_78); +lean_inc(x_77); lean_dec(x_27); -x_76 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_76, 0, x_74); -lean_ctor_set(x_76, 1, x_75); -return x_76; +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_77; +uint8_t x_80; lean_free_object(x_3); lean_dec(x_15); lean_free_object(x_5); @@ -9188,23 +9432,23 @@ lean_dec(x_8); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); -x_77 = !lean_is_exclusive(x_17); -if (x_77 == 0) +x_80 = !lean_is_exclusive(x_17); +if (x_80 == 0) { return x_17; } else { -lean_object* x_78; lean_object* x_79; lean_object* x_80; -x_78 = lean_ctor_get(x_17, 0); -x_79 = lean_ctor_get(x_17, 1); -lean_inc(x_79); -lean_inc(x_78); +lean_object* x_81; lean_object* x_82; lean_object* x_83; +x_81 = lean_ctor_get(x_17, 0); +x_82 = lean_ctor_get(x_17, 1); +lean_inc(x_82); +lean_inc(x_81); lean_dec(x_17); -x_80 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_80, 0, x_78); -lean_ctor_set(x_80, 1, x_79); -return x_80; +x_83 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_83, 0, x_81); +lean_ctor_set(x_83, 1, x_82); +return x_83; } } } @@ -9213,156 +9457,127 @@ else lean_dec(x_3); if (lean_obj_tag(x_17) == 0) { -lean_object* x_81; lean_object* x_82; uint8_t x_83; lean_object* x_84; lean_object* x_85; -x_81 = lean_ctor_get(x_17, 0); -lean_inc(x_81); -x_82 = lean_ctor_get(x_17, 1); -lean_inc(x_82); +lean_object* x_84; lean_object* x_85; uint8_t x_86; lean_object* x_87; lean_object* x_88; +x_84 = lean_ctor_get(x_17, 0); +lean_inc(x_84); +x_85 = lean_ctor_get(x_17, 1); +lean_inc(x_85); lean_dec(x_17); -x_83 = 1; -lean_ctor_set_uint8(x_5, sizeof(void*)*1 + 6, x_83); -x_84 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_84, 0, x_5); -lean_ctor_set(x_84, 1, x_6); -lean_ctor_set(x_84, 2, x_7); -lean_ctor_set(x_84, 3, x_8); -lean_ctor_set(x_84, 4, x_9); -x_85 = l___private_Lean_Meta_Basic_5__forallTelescopeReducingAux___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__2(x_81, x_2, x_84, x_82); -if (lean_obj_tag(x_85) == 0) +x_86 = 1; +lean_ctor_set_uint8(x_5, sizeof(void*)*1 + 6, x_86); +x_87 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_87, 0, x_5); +lean_ctor_set(x_87, 1, x_6); +lean_ctor_set(x_87, 2, x_7); +lean_ctor_set(x_87, 3, x_8); +lean_ctor_set(x_87, 4, x_9); +x_88 = l___private_Lean_Meta_Basic_5__forallTelescopeReducingAux___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__2(x_84, x_2, x_87, x_85); +if (lean_obj_tag(x_88) == 0) { -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; -x_86 = lean_ctor_get(x_85, 1); -lean_inc(x_86); -x_87 = lean_ctor_get(x_86, 2); -lean_inc(x_87); -x_88 = lean_ctor_get(x_85, 0); -lean_inc(x_88); -if (lean_is_exclusive(x_85)) { - lean_ctor_release(x_85, 0); - lean_ctor_release(x_85, 1); - x_89 = x_85; -} else { - lean_dec_ref(x_85); - x_89 = lean_box(0); -} -x_90 = lean_ctor_get(x_86, 0); +lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; +x_89 = lean_ctor_get(x_88, 1); +lean_inc(x_89); +x_90 = lean_ctor_get(x_89, 2); lean_inc(x_90); -x_91 = lean_ctor_get(x_86, 1); +x_91 = lean_ctor_get(x_88, 0); lean_inc(x_91); -x_92 = lean_ctor_get(x_86, 3); -lean_inc(x_92); -x_93 = lean_ctor_get(x_86, 4); +if (lean_is_exclusive(x_88)) { + lean_ctor_release(x_88, 0); + lean_ctor_release(x_88, 1); + x_92 = x_88; +} else { + lean_dec_ref(x_88); + x_92 = lean_box(0); +} +x_93 = lean_ctor_get(x_89, 0); lean_inc(x_93); -x_94 = lean_ctor_get(x_86, 5); +x_94 = lean_ctor_get(x_89, 1); lean_inc(x_94); -if (lean_is_exclusive(x_86)) { - lean_ctor_release(x_86, 0); - lean_ctor_release(x_86, 1); - lean_ctor_release(x_86, 2); - lean_ctor_release(x_86, 3); - lean_ctor_release(x_86, 4); - lean_ctor_release(x_86, 5); - x_95 = x_86; -} else { - lean_dec_ref(x_86); - x_95 = lean_box(0); -} -x_96 = lean_ctor_get(x_87, 0); +x_95 = lean_ctor_get(x_89, 3); +lean_inc(x_95); +x_96 = lean_ctor_get(x_89, 4); lean_inc(x_96); -x_97 = lean_ctor_get(x_87, 1); +x_97 = lean_ctor_get(x_89, 5); lean_inc(x_97); -x_98 = lean_ctor_get(x_87, 2); -lean_inc(x_98); -x_99 = lean_ctor_get(x_87, 3); +if (lean_is_exclusive(x_89)) { + lean_ctor_release(x_89, 0); + lean_ctor_release(x_89, 1); + lean_ctor_release(x_89, 2); + lean_ctor_release(x_89, 3); + lean_ctor_release(x_89, 4); + lean_ctor_release(x_89, 5); + x_98 = x_89; +} else { + lean_dec_ref(x_89); + x_98 = lean_box(0); +} +x_99 = lean_ctor_get(x_90, 0); lean_inc(x_99); -if (lean_is_exclusive(x_87)) { - lean_ctor_release(x_87, 0); - lean_ctor_release(x_87, 1); - lean_ctor_release(x_87, 2); - lean_ctor_release(x_87, 3); - x_100 = x_87; +x_100 = lean_ctor_get(x_90, 1); +lean_inc(x_100); +x_101 = lean_ctor_get(x_90, 2); +lean_inc(x_101); +x_102 = lean_ctor_get(x_90, 3); +lean_inc(x_102); +x_103 = lean_ctor_get(x_90, 4); +lean_inc(x_103); +if (lean_is_exclusive(x_90)) { + lean_ctor_release(x_90, 0); + lean_ctor_release(x_90, 1); + lean_ctor_release(x_90, 2); + lean_ctor_release(x_90, 3); + lean_ctor_release(x_90, 4); + x_104 = x_90; } else { - lean_dec_ref(x_87); - x_100 = lean_box(0); + lean_dec_ref(x_90); + x_104 = lean_box(0); } -lean_inc(x_88); -x_101 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4(x_97, x_15, x_88); -if (lean_is_scalar(x_100)) { - x_102 = lean_alloc_ctor(0, 4, 0); +lean_inc(x_91); +x_105 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4(x_100, x_15, x_91); +if (lean_is_scalar(x_104)) { + x_106 = lean_alloc_ctor(0, 5, 0); } else { - x_102 = x_100; + x_106 = x_104; } -lean_ctor_set(x_102, 0, x_96); -lean_ctor_set(x_102, 1, x_101); -lean_ctor_set(x_102, 2, x_98); -lean_ctor_set(x_102, 3, x_99); -if (lean_is_scalar(x_95)) { - x_103 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_106, 0, x_99); +lean_ctor_set(x_106, 1, x_105); +lean_ctor_set(x_106, 2, x_101); +lean_ctor_set(x_106, 3, x_102); +lean_ctor_set(x_106, 4, x_103); +if (lean_is_scalar(x_98)) { + x_107 = lean_alloc_ctor(0, 6, 0); } else { - x_103 = x_95; + x_107 = x_98; } -lean_ctor_set(x_103, 0, x_90); -lean_ctor_set(x_103, 1, x_91); -lean_ctor_set(x_103, 2, x_102); -lean_ctor_set(x_103, 3, x_92); -lean_ctor_set(x_103, 4, x_93); -lean_ctor_set(x_103, 5, x_94); -if (lean_is_scalar(x_89)) { - x_104 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_107, 0, x_93); +lean_ctor_set(x_107, 1, x_94); +lean_ctor_set(x_107, 2, x_106); +lean_ctor_set(x_107, 3, x_95); +lean_ctor_set(x_107, 4, x_96); +lean_ctor_set(x_107, 5, x_97); +if (lean_is_scalar(x_92)) { + x_108 = lean_alloc_ctor(0, 2, 0); } else { - x_104 = x_89; + x_108 = x_92; } -lean_ctor_set(x_104, 0, x_88); -lean_ctor_set(x_104, 1, x_103); -return x_104; -} -else -{ -lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; -lean_dec(x_15); -x_105 = lean_ctor_get(x_85, 0); -lean_inc(x_105); -x_106 = lean_ctor_get(x_85, 1); -lean_inc(x_106); -if (lean_is_exclusive(x_85)) { - lean_ctor_release(x_85, 0); - lean_ctor_release(x_85, 1); - x_107 = x_85; -} else { - lean_dec_ref(x_85); - x_107 = lean_box(0); -} -if (lean_is_scalar(x_107)) { - x_108 = lean_alloc_ctor(1, 2, 0); -} else { - x_108 = x_107; -} -lean_ctor_set(x_108, 0, x_105); -lean_ctor_set(x_108, 1, x_106); +lean_ctor_set(x_108, 0, x_91); +lean_ctor_set(x_108, 1, x_107); return x_108; } -} else { lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_dec(x_15); -lean_free_object(x_5); -lean_dec(x_11); -lean_dec(x_9); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_2); -x_109 = lean_ctor_get(x_17, 0); +x_109 = lean_ctor_get(x_88, 0); lean_inc(x_109); -x_110 = lean_ctor_get(x_17, 1); +x_110 = lean_ctor_get(x_88, 1); lean_inc(x_110); -if (lean_is_exclusive(x_17)) { - lean_ctor_release(x_17, 0); - lean_ctor_release(x_17, 1); - x_111 = x_17; +if (lean_is_exclusive(x_88)) { + lean_ctor_release(x_88, 0); + lean_ctor_release(x_88, 1); + x_111 = x_88; } else { - lean_dec_ref(x_17); + lean_dec_ref(x_88); x_111 = lean_box(0); } if (lean_is_scalar(x_111)) { @@ -9375,10 +9590,43 @@ lean_ctor_set(x_112, 1, x_110); return x_112; } } +else +{ +lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; +lean_dec(x_15); +lean_free_object(x_5); +lean_dec(x_11); +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_2); +x_113 = lean_ctor_get(x_17, 0); +lean_inc(x_113); +x_114 = lean_ctor_get(x_17, 1); +lean_inc(x_114); +if (lean_is_exclusive(x_17)) { + lean_ctor_release(x_17, 0); + lean_ctor_release(x_17, 1); + x_115 = x_17; +} else { + lean_dec_ref(x_17); + x_115 = lean_box(0); +} +if (lean_is_scalar(x_115)) { + x_116 = lean_alloc_ctor(1, 2, 0); +} else { + x_116 = x_115; +} +lean_ctor_set(x_116, 0, x_113); +lean_ctor_set(x_116, 1, x_114); +return x_116; +} +} } else { -lean_object* x_113; lean_object* x_114; +lean_object* x_117; lean_object* x_118; lean_dec(x_15); lean_free_object(x_5); lean_dec(x_11); @@ -9389,237 +9637,241 @@ lean_dec(x_6); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_113 = lean_ctor_get(x_16, 0); -lean_inc(x_113); +x_117 = lean_ctor_get(x_16, 0); +lean_inc(x_117); lean_dec(x_16); -x_114 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_114, 0, x_113); -lean_ctor_set(x_114, 1, x_4); -return x_114; +x_118 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_118, 0, x_117); +lean_ctor_set(x_118, 1, x_4); +return x_118; } } else { -lean_object* x_115; uint8_t x_116; uint8_t x_117; uint8_t x_118; uint8_t x_119; uint8_t x_120; uint8_t x_121; uint8_t x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; -x_115 = lean_ctor_get(x_5, 0); -x_116 = lean_ctor_get_uint8(x_5, sizeof(void*)*1); -x_117 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 1); -x_118 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 2); -x_119 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 3); -x_120 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 4); -x_121 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 5); -x_122 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 6); -lean_inc(x_115); +lean_object* x_119; uint8_t x_120; uint8_t x_121; uint8_t x_122; uint8_t x_123; uint8_t x_124; uint8_t x_125; uint8_t x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; +x_119 = lean_ctor_get(x_5, 0); +x_120 = lean_ctor_get_uint8(x_5, sizeof(void*)*1); +x_121 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 1); +x_122 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 2); +x_123 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 3); +x_124 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 4); +x_125 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 5); +x_126 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 6); +lean_inc(x_119); lean_dec(x_5); -x_123 = lean_ctor_get(x_4, 2); -lean_inc(x_123); -x_124 = lean_ctor_get(x_123, 1); -lean_inc(x_124); -lean_dec(x_123); +x_127 = lean_ctor_get(x_4, 2); +lean_inc(x_127); +x_128 = lean_ctor_get(x_127, 1); +lean_inc(x_128); +lean_dec(x_127); lean_inc(x_2); lean_inc(x_1); -x_125 = lean_alloc_ctor(0, 2, 1); -lean_ctor_set(x_125, 0, x_1); -lean_ctor_set(x_125, 1, x_2); -lean_ctor_set_uint8(x_125, sizeof(void*)*2, x_122); -x_126 = l_Std_PersistentHashMap_find_x3f___at___private_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__1(x_124, x_125); -if (lean_obj_tag(x_126) == 0) +x_129 = lean_alloc_ctor(0, 2, 1); +lean_ctor_set(x_129, 0, x_1); +lean_ctor_set(x_129, 1, x_2); +lean_ctor_set_uint8(x_129, sizeof(void*)*2, x_126); +x_130 = l_Std_PersistentHashMap_find_x3f___at___private_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__1(x_128, x_129); +if (lean_obj_tag(x_130) == 0) { -lean_object* x_127; lean_object* x_128; +lean_object* x_131; lean_object* x_132; lean_inc(x_3); -x_127 = l_Lean_Meta_inferType(x_1, x_3, x_4); +x_131 = l_Lean_Meta_inferType(x_1, x_3, x_4); if (lean_is_exclusive(x_3)) { lean_ctor_release(x_3, 0); lean_ctor_release(x_3, 1); lean_ctor_release(x_3, 2); lean_ctor_release(x_3, 3); lean_ctor_release(x_3, 4); - x_128 = x_3; + x_132 = x_3; } else { lean_dec_ref(x_3); - x_128 = lean_box(0); + x_132 = lean_box(0); } -if (lean_obj_tag(x_127) == 0) +if (lean_obj_tag(x_131) == 0) { -lean_object* x_129; lean_object* x_130; uint8_t x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; -x_129 = lean_ctor_get(x_127, 0); -lean_inc(x_129); -x_130 = lean_ctor_get(x_127, 1); -lean_inc(x_130); -lean_dec(x_127); -x_131 = 1; -x_132 = lean_alloc_ctor(0, 1, 7); -lean_ctor_set(x_132, 0, x_115); -lean_ctor_set_uint8(x_132, sizeof(void*)*1, x_116); -lean_ctor_set_uint8(x_132, sizeof(void*)*1 + 1, x_117); -lean_ctor_set_uint8(x_132, sizeof(void*)*1 + 2, x_118); -lean_ctor_set_uint8(x_132, sizeof(void*)*1 + 3, x_119); -lean_ctor_set_uint8(x_132, sizeof(void*)*1 + 4, x_120); -lean_ctor_set_uint8(x_132, sizeof(void*)*1 + 5, x_121); -lean_ctor_set_uint8(x_132, sizeof(void*)*1 + 6, x_131); -if (lean_is_scalar(x_128)) { - x_133 = lean_alloc_ctor(0, 5, 0); +lean_object* x_133; lean_object* x_134; uint8_t x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; +x_133 = lean_ctor_get(x_131, 0); +lean_inc(x_133); +x_134 = lean_ctor_get(x_131, 1); +lean_inc(x_134); +lean_dec(x_131); +x_135 = 1; +x_136 = lean_alloc_ctor(0, 1, 7); +lean_ctor_set(x_136, 0, x_119); +lean_ctor_set_uint8(x_136, sizeof(void*)*1, x_120); +lean_ctor_set_uint8(x_136, sizeof(void*)*1 + 1, x_121); +lean_ctor_set_uint8(x_136, sizeof(void*)*1 + 2, x_122); +lean_ctor_set_uint8(x_136, sizeof(void*)*1 + 3, x_123); +lean_ctor_set_uint8(x_136, sizeof(void*)*1 + 4, x_124); +lean_ctor_set_uint8(x_136, sizeof(void*)*1 + 5, x_125); +lean_ctor_set_uint8(x_136, sizeof(void*)*1 + 6, x_135); +if (lean_is_scalar(x_132)) { + x_137 = lean_alloc_ctor(0, 5, 0); } else { - x_133 = x_128; + x_137 = x_132; } -lean_ctor_set(x_133, 0, x_132); -lean_ctor_set(x_133, 1, x_6); -lean_ctor_set(x_133, 2, x_7); -lean_ctor_set(x_133, 3, x_8); -lean_ctor_set(x_133, 4, x_9); -x_134 = l___private_Lean_Meta_Basic_5__forallTelescopeReducingAux___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__2(x_129, x_2, x_133, x_130); -if (lean_obj_tag(x_134) == 0) +lean_ctor_set(x_137, 0, x_136); +lean_ctor_set(x_137, 1, x_6); +lean_ctor_set(x_137, 2, x_7); +lean_ctor_set(x_137, 3, x_8); +lean_ctor_set(x_137, 4, x_9); +x_138 = l___private_Lean_Meta_Basic_5__forallTelescopeReducingAux___at___private_Lean_Meta_FunInfo_6__getFunInfoAux___spec__2(x_133, x_2, x_137, x_134); +if (lean_obj_tag(x_138) == 0) { -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; -x_135 = lean_ctor_get(x_134, 1); -lean_inc(x_135); -x_136 = lean_ctor_get(x_135, 2); -lean_inc(x_136); -x_137 = lean_ctor_get(x_134, 0); -lean_inc(x_137); -if (lean_is_exclusive(x_134)) { - lean_ctor_release(x_134, 0); - lean_ctor_release(x_134, 1); - x_138 = x_134; -} else { - lean_dec_ref(x_134); - x_138 = lean_box(0); -} -x_139 = lean_ctor_get(x_135, 0); +lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; 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; +x_139 = lean_ctor_get(x_138, 1); lean_inc(x_139); -x_140 = lean_ctor_get(x_135, 1); +x_140 = lean_ctor_get(x_139, 2); lean_inc(x_140); -x_141 = lean_ctor_get(x_135, 3); +x_141 = lean_ctor_get(x_138, 0); lean_inc(x_141); -x_142 = lean_ctor_get(x_135, 4); -lean_inc(x_142); -x_143 = lean_ctor_get(x_135, 5); +if (lean_is_exclusive(x_138)) { + lean_ctor_release(x_138, 0); + lean_ctor_release(x_138, 1); + x_142 = x_138; +} else { + lean_dec_ref(x_138); + x_142 = lean_box(0); +} +x_143 = lean_ctor_get(x_139, 0); lean_inc(x_143); -if (lean_is_exclusive(x_135)) { - lean_ctor_release(x_135, 0); - lean_ctor_release(x_135, 1); - lean_ctor_release(x_135, 2); - lean_ctor_release(x_135, 3); - lean_ctor_release(x_135, 4); - lean_ctor_release(x_135, 5); - x_144 = x_135; -} else { - lean_dec_ref(x_135); - x_144 = lean_box(0); -} -x_145 = lean_ctor_get(x_136, 0); +x_144 = lean_ctor_get(x_139, 1); +lean_inc(x_144); +x_145 = lean_ctor_get(x_139, 3); lean_inc(x_145); -x_146 = lean_ctor_get(x_136, 1); +x_146 = lean_ctor_get(x_139, 4); lean_inc(x_146); -x_147 = lean_ctor_get(x_136, 2); +x_147 = lean_ctor_get(x_139, 5); lean_inc(x_147); -x_148 = lean_ctor_get(x_136, 3); -lean_inc(x_148); -if (lean_is_exclusive(x_136)) { - lean_ctor_release(x_136, 0); - lean_ctor_release(x_136, 1); - lean_ctor_release(x_136, 2); - lean_ctor_release(x_136, 3); - x_149 = x_136; +if (lean_is_exclusive(x_139)) { + lean_ctor_release(x_139, 0); + lean_ctor_release(x_139, 1); + lean_ctor_release(x_139, 2); + lean_ctor_release(x_139, 3); + lean_ctor_release(x_139, 4); + lean_ctor_release(x_139, 5); + x_148 = x_139; } else { - lean_dec_ref(x_136); - x_149 = lean_box(0); + lean_dec_ref(x_139); + x_148 = lean_box(0); } -lean_inc(x_137); -x_150 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4(x_146, x_125, x_137); -if (lean_is_scalar(x_149)) { - x_151 = lean_alloc_ctor(0, 4, 0); +x_149 = lean_ctor_get(x_140, 0); +lean_inc(x_149); +x_150 = lean_ctor_get(x_140, 1); +lean_inc(x_150); +x_151 = lean_ctor_get(x_140, 2); +lean_inc(x_151); +x_152 = lean_ctor_get(x_140, 3); +lean_inc(x_152); +x_153 = lean_ctor_get(x_140, 4); +lean_inc(x_153); +if (lean_is_exclusive(x_140)) { + lean_ctor_release(x_140, 0); + lean_ctor_release(x_140, 1); + lean_ctor_release(x_140, 2); + lean_ctor_release(x_140, 3); + lean_ctor_release(x_140, 4); + x_154 = x_140; } else { - x_151 = x_149; + lean_dec_ref(x_140); + x_154 = lean_box(0); } -lean_ctor_set(x_151, 0, x_145); -lean_ctor_set(x_151, 1, x_150); -lean_ctor_set(x_151, 2, x_147); -lean_ctor_set(x_151, 3, x_148); -if (lean_is_scalar(x_144)) { - x_152 = lean_alloc_ctor(0, 6, 0); +lean_inc(x_141); +x_155 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4(x_150, x_129, x_141); +if (lean_is_scalar(x_154)) { + x_156 = lean_alloc_ctor(0, 5, 0); } else { - x_152 = x_144; + x_156 = x_154; } -lean_ctor_set(x_152, 0, x_139); -lean_ctor_set(x_152, 1, x_140); -lean_ctor_set(x_152, 2, x_151); -lean_ctor_set(x_152, 3, x_141); -lean_ctor_set(x_152, 4, x_142); -lean_ctor_set(x_152, 5, x_143); -if (lean_is_scalar(x_138)) { - x_153 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_156, 0, x_149); +lean_ctor_set(x_156, 1, x_155); +lean_ctor_set(x_156, 2, x_151); +lean_ctor_set(x_156, 3, x_152); +lean_ctor_set(x_156, 4, x_153); +if (lean_is_scalar(x_148)) { + x_157 = lean_alloc_ctor(0, 6, 0); } else { - x_153 = x_138; + x_157 = x_148; } -lean_ctor_set(x_153, 0, x_137); -lean_ctor_set(x_153, 1, x_152); -return x_153; +lean_ctor_set(x_157, 0, x_143); +lean_ctor_set(x_157, 1, x_144); +lean_ctor_set(x_157, 2, x_156); +lean_ctor_set(x_157, 3, x_145); +lean_ctor_set(x_157, 4, x_146); +lean_ctor_set(x_157, 5, x_147); +if (lean_is_scalar(x_142)) { + x_158 = lean_alloc_ctor(0, 2, 0); +} else { + x_158 = x_142; +} +lean_ctor_set(x_158, 0, x_141); +lean_ctor_set(x_158, 1, x_157); +return x_158; } else { -lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; -lean_dec(x_125); -x_154 = lean_ctor_get(x_134, 0); -lean_inc(x_154); -x_155 = lean_ctor_get(x_134, 1); -lean_inc(x_155); -if (lean_is_exclusive(x_134)) { - lean_ctor_release(x_134, 0); - lean_ctor_release(x_134, 1); - x_156 = x_134; +lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; +lean_dec(x_129); +x_159 = lean_ctor_get(x_138, 0); +lean_inc(x_159); +x_160 = lean_ctor_get(x_138, 1); +lean_inc(x_160); +if (lean_is_exclusive(x_138)) { + lean_ctor_release(x_138, 0); + lean_ctor_release(x_138, 1); + x_161 = x_138; } else { - lean_dec_ref(x_134); - x_156 = lean_box(0); + lean_dec_ref(x_138); + x_161 = lean_box(0); } -if (lean_is_scalar(x_156)) { - x_157 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_161)) { + x_162 = lean_alloc_ctor(1, 2, 0); } else { - x_157 = x_156; + x_162 = x_161; } -lean_ctor_set(x_157, 0, x_154); -lean_ctor_set(x_157, 1, x_155); -return x_157; +lean_ctor_set(x_162, 0, x_159); +lean_ctor_set(x_162, 1, x_160); +return x_162; } } else { -lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; -lean_dec(x_128); -lean_dec(x_125); -lean_dec(x_115); +lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; +lean_dec(x_132); +lean_dec(x_129); +lean_dec(x_119); lean_dec(x_9); lean_dec(x_8); lean_dec(x_7); lean_dec(x_6); lean_dec(x_2); -x_158 = lean_ctor_get(x_127, 0); -lean_inc(x_158); -x_159 = lean_ctor_get(x_127, 1); -lean_inc(x_159); -if (lean_is_exclusive(x_127)) { - lean_ctor_release(x_127, 0); - lean_ctor_release(x_127, 1); - x_160 = x_127; +x_163 = lean_ctor_get(x_131, 0); +lean_inc(x_163); +x_164 = lean_ctor_get(x_131, 1); +lean_inc(x_164); +if (lean_is_exclusive(x_131)) { + lean_ctor_release(x_131, 0); + lean_ctor_release(x_131, 1); + x_165 = x_131; } else { - lean_dec_ref(x_127); - x_160 = lean_box(0); + lean_dec_ref(x_131); + x_165 = lean_box(0); } -if (lean_is_scalar(x_160)) { - x_161 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_165)) { + x_166 = lean_alloc_ctor(1, 2, 0); } else { - x_161 = x_160; + x_166 = x_165; } -lean_ctor_set(x_161, 0, x_158); -lean_ctor_set(x_161, 1, x_159); -return x_161; +lean_ctor_set(x_166, 0, x_163); +lean_ctor_set(x_166, 1, x_164); +return x_166; } } else { -lean_object* x_162; lean_object* x_163; -lean_dec(x_125); -lean_dec(x_115); +lean_object* x_167; lean_object* x_168; +lean_dec(x_129); +lean_dec(x_119); lean_dec(x_9); lean_dec(x_8); lean_dec(x_7); @@ -9627,13 +9879,13 @@ lean_dec(x_6); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_162 = lean_ctor_get(x_126, 0); -lean_inc(x_162); -lean_dec(x_126); -x_163 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_163, 0, x_162); -lean_ctor_set(x_163, 1, x_4); -return x_163; +x_167 = lean_ctor_get(x_130, 0); +lean_inc(x_167); +lean_dec(x_130); +x_168 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_168, 0, x_167); +lean_ctor_set(x_168, 1, x_4); +return x_168; } } } diff --git a/stage0/stdlib/Lean/Meta/InferType.c b/stage0/stdlib/Lean/Meta/InferType.c index 702126e85e..d050985228 100644 --- a/stage0/stdlib/Lean/Meta/InferType.c +++ b/stage0/stdlib/Lean/Meta/InferType.c @@ -3625,97 +3625,104 @@ return x_8; } else { -lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; +lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; x_19 = lean_ctor_get(x_10, 0); x_20 = lean_ctor_get(x_10, 1); x_21 = lean_ctor_get(x_10, 2); x_22 = lean_ctor_get(x_10, 3); +x_23 = lean_ctor_get(x_10, 4); +lean_inc(x_23); lean_inc(x_22); lean_inc(x_21); lean_inc(x_20); lean_inc(x_19); lean_dec(x_10); lean_inc(x_12); -x_23 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_19, x_1, x_12); -x_24 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_24, 0, x_23); -lean_ctor_set(x_24, 1, x_20); -lean_ctor_set(x_24, 2, x_21); -lean_ctor_set(x_24, 3, x_22); -lean_ctor_set(x_9, 2, x_24); +x_24 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_19, x_1, x_12); +x_25 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_25, 0, x_24); +lean_ctor_set(x_25, 1, x_20); +lean_ctor_set(x_25, 2, x_21); +lean_ctor_set(x_25, 3, x_22); +lean_ctor_set(x_25, 4, x_23); +lean_ctor_set(x_9, 2, x_25); return x_8; } } else { -lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; -x_25 = lean_ctor_get(x_9, 0); -x_26 = lean_ctor_get(x_9, 1); -x_27 = lean_ctor_get(x_9, 3); -x_28 = lean_ctor_get(x_9, 4); -x_29 = lean_ctor_get(x_9, 5); +lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; +x_26 = lean_ctor_get(x_9, 0); +x_27 = lean_ctor_get(x_9, 1); +x_28 = lean_ctor_get(x_9, 3); +x_29 = lean_ctor_get(x_9, 4); +x_30 = lean_ctor_get(x_9, 5); +lean_inc(x_30); lean_inc(x_29); lean_inc(x_28); lean_inc(x_27); lean_inc(x_26); -lean_inc(x_25); lean_dec(x_9); -x_30 = lean_ctor_get(x_10, 0); -lean_inc(x_30); -x_31 = lean_ctor_get(x_10, 1); +x_31 = lean_ctor_get(x_10, 0); lean_inc(x_31); -x_32 = lean_ctor_get(x_10, 2); +x_32 = lean_ctor_get(x_10, 1); lean_inc(x_32); -x_33 = lean_ctor_get(x_10, 3); +x_33 = lean_ctor_get(x_10, 2); lean_inc(x_33); +x_34 = lean_ctor_get(x_10, 3); +lean_inc(x_34); +x_35 = lean_ctor_get(x_10, 4); +lean_inc(x_35); if (lean_is_exclusive(x_10)) { lean_ctor_release(x_10, 0); lean_ctor_release(x_10, 1); lean_ctor_release(x_10, 2); lean_ctor_release(x_10, 3); - x_34 = x_10; + lean_ctor_release(x_10, 4); + x_36 = x_10; } else { lean_dec_ref(x_10); - x_34 = lean_box(0); + x_36 = lean_box(0); } lean_inc(x_12); -x_35 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_30, x_1, x_12); -if (lean_is_scalar(x_34)) { - x_36 = lean_alloc_ctor(0, 4, 0); +x_37 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_31, x_1, x_12); +if (lean_is_scalar(x_36)) { + x_38 = lean_alloc_ctor(0, 5, 0); } else { - x_36 = x_34; + x_38 = x_36; } -lean_ctor_set(x_36, 0, x_35); -lean_ctor_set(x_36, 1, x_31); -lean_ctor_set(x_36, 2, x_32); -lean_ctor_set(x_36, 3, x_33); -x_37 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_37, 0, x_25); -lean_ctor_set(x_37, 1, x_26); -lean_ctor_set(x_37, 2, x_36); -lean_ctor_set(x_37, 3, x_27); -lean_ctor_set(x_37, 4, x_28); -lean_ctor_set(x_37, 5, x_29); -lean_ctor_set(x_8, 1, x_37); +lean_ctor_set(x_38, 0, x_37); +lean_ctor_set(x_38, 1, x_32); +lean_ctor_set(x_38, 2, x_33); +lean_ctor_set(x_38, 3, x_34); +lean_ctor_set(x_38, 4, x_35); +x_39 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_39, 0, x_26); +lean_ctor_set(x_39, 1, x_27); +lean_ctor_set(x_39, 2, x_38); +lean_ctor_set(x_39, 3, x_28); +lean_ctor_set(x_39, 4, x_29); +lean_ctor_set(x_39, 5, x_30); +lean_ctor_set(x_8, 1, x_39); return x_8; } } else { -lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; -x_38 = lean_ctor_get(x_8, 0); -lean_inc(x_38); -lean_dec(x_8); -x_39 = lean_ctor_get(x_9, 0); -lean_inc(x_39); -x_40 = lean_ctor_get(x_9, 1); +lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; +x_40 = lean_ctor_get(x_8, 0); lean_inc(x_40); -x_41 = lean_ctor_get(x_9, 3); +lean_dec(x_8); +x_41 = lean_ctor_get(x_9, 0); lean_inc(x_41); -x_42 = lean_ctor_get(x_9, 4); +x_42 = lean_ctor_get(x_9, 1); lean_inc(x_42); -x_43 = lean_ctor_get(x_9, 5); +x_43 = lean_ctor_get(x_9, 3); lean_inc(x_43); +x_44 = lean_ctor_get(x_9, 4); +lean_inc(x_44); +x_45 = lean_ctor_get(x_9, 5); +lean_inc(x_45); if (lean_is_exclusive(x_9)) { lean_ctor_release(x_9, 0); lean_ctor_release(x_9, 1); @@ -3723,94 +3730,98 @@ if (lean_is_exclusive(x_9)) { lean_ctor_release(x_9, 3); lean_ctor_release(x_9, 4); lean_ctor_release(x_9, 5); - x_44 = x_9; + x_46 = x_9; } else { lean_dec_ref(x_9); - x_44 = lean_box(0); + x_46 = lean_box(0); } -x_45 = lean_ctor_get(x_10, 0); -lean_inc(x_45); -x_46 = lean_ctor_get(x_10, 1); -lean_inc(x_46); -x_47 = lean_ctor_get(x_10, 2); +x_47 = lean_ctor_get(x_10, 0); lean_inc(x_47); -x_48 = lean_ctor_get(x_10, 3); +x_48 = lean_ctor_get(x_10, 1); lean_inc(x_48); +x_49 = lean_ctor_get(x_10, 2); +lean_inc(x_49); +x_50 = lean_ctor_get(x_10, 3); +lean_inc(x_50); +x_51 = lean_ctor_get(x_10, 4); +lean_inc(x_51); if (lean_is_exclusive(x_10)) { lean_ctor_release(x_10, 0); lean_ctor_release(x_10, 1); lean_ctor_release(x_10, 2); lean_ctor_release(x_10, 3); - x_49 = x_10; + lean_ctor_release(x_10, 4); + x_52 = x_10; } else { lean_dec_ref(x_10); - x_49 = lean_box(0); + x_52 = lean_box(0); } -lean_inc(x_38); -x_50 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_45, x_1, x_38); -if (lean_is_scalar(x_49)) { - x_51 = lean_alloc_ctor(0, 4, 0); +lean_inc(x_40); +x_53 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_47, x_1, x_40); +if (lean_is_scalar(x_52)) { + x_54 = lean_alloc_ctor(0, 5, 0); } else { - x_51 = x_49; + x_54 = x_52; } -lean_ctor_set(x_51, 0, x_50); -lean_ctor_set(x_51, 1, x_46); -lean_ctor_set(x_51, 2, x_47); -lean_ctor_set(x_51, 3, x_48); -if (lean_is_scalar(x_44)) { - x_52 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_54, 0, x_53); +lean_ctor_set(x_54, 1, x_48); +lean_ctor_set(x_54, 2, x_49); +lean_ctor_set(x_54, 3, x_50); +lean_ctor_set(x_54, 4, x_51); +if (lean_is_scalar(x_46)) { + x_55 = lean_alloc_ctor(0, 6, 0); } else { - x_52 = x_44; + x_55 = x_46; } -lean_ctor_set(x_52, 0, x_39); -lean_ctor_set(x_52, 1, x_40); -lean_ctor_set(x_52, 2, x_51); -lean_ctor_set(x_52, 3, x_41); -lean_ctor_set(x_52, 4, x_42); -lean_ctor_set(x_52, 5, x_43); -x_53 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_53, 0, x_38); -lean_ctor_set(x_53, 1, x_52); -return x_53; +lean_ctor_set(x_55, 0, x_41); +lean_ctor_set(x_55, 1, x_42); +lean_ctor_set(x_55, 2, x_54); +lean_ctor_set(x_55, 3, x_43); +lean_ctor_set(x_55, 4, x_44); +lean_ctor_set(x_55, 5, x_45); +x_56 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_56, 0, x_40); +lean_ctor_set(x_56, 1, x_55); +return x_56; } } else { -uint8_t x_54; +uint8_t x_57; lean_dec(x_1); -x_54 = !lean_is_exclusive(x_8); -if (x_54 == 0) +x_57 = !lean_is_exclusive(x_8); +if (x_57 == 0) { return x_8; } else { -lean_object* x_55; lean_object* x_56; lean_object* x_57; -x_55 = lean_ctor_get(x_8, 0); -x_56 = lean_ctor_get(x_8, 1); -lean_inc(x_56); -lean_inc(x_55); +lean_object* x_58; lean_object* x_59; lean_object* x_60; +x_58 = lean_ctor_get(x_8, 0); +x_59 = lean_ctor_get(x_8, 1); +lean_inc(x_59); +lean_inc(x_58); lean_dec(x_8); -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; +x_60 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_60, 0, x_58); +lean_ctor_set(x_60, 1, x_59); +return x_60; } } } else { -lean_object* x_58; lean_object* x_59; +lean_object* x_61; lean_object* x_62; lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_58 = lean_ctor_get(x_7, 0); -lean_inc(x_58); +x_61 = lean_ctor_get(x_7, 0); +lean_inc(x_61); lean_dec(x_7); -x_59 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_59, 0, x_58); -lean_ctor_set(x_59, 1, x_4); -return x_59; +x_62 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_62, 0, x_61); +lean_ctor_set(x_62, 1, x_4); +return x_62; } } } @@ -3993,97 +4004,104 @@ return x_30; } else { -lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; +lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; x_41 = lean_ctor_get(x_32, 0); x_42 = lean_ctor_get(x_32, 1); x_43 = lean_ctor_get(x_32, 2); x_44 = lean_ctor_get(x_32, 3); +x_45 = lean_ctor_get(x_32, 4); +lean_inc(x_45); lean_inc(x_44); lean_inc(x_43); lean_inc(x_42); lean_inc(x_41); lean_dec(x_32); lean_inc(x_34); -x_45 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_41, x_1, x_34); -x_46 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_46, 0, x_45); -lean_ctor_set(x_46, 1, x_42); -lean_ctor_set(x_46, 2, x_43); -lean_ctor_set(x_46, 3, x_44); -lean_ctor_set(x_31, 2, x_46); +x_46 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_41, x_1, x_34); +x_47 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_47, 0, x_46); +lean_ctor_set(x_47, 1, x_42); +lean_ctor_set(x_47, 2, x_43); +lean_ctor_set(x_47, 3, x_44); +lean_ctor_set(x_47, 4, x_45); +lean_ctor_set(x_31, 2, x_47); return x_30; } } else { -lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; -x_47 = lean_ctor_get(x_31, 0); -x_48 = lean_ctor_get(x_31, 1); -x_49 = lean_ctor_get(x_31, 3); -x_50 = lean_ctor_get(x_31, 4); -x_51 = lean_ctor_get(x_31, 5); +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; +x_48 = lean_ctor_get(x_31, 0); +x_49 = lean_ctor_get(x_31, 1); +x_50 = lean_ctor_get(x_31, 3); +x_51 = lean_ctor_get(x_31, 4); +x_52 = lean_ctor_get(x_31, 5); +lean_inc(x_52); lean_inc(x_51); lean_inc(x_50); lean_inc(x_49); lean_inc(x_48); -lean_inc(x_47); lean_dec(x_31); -x_52 = lean_ctor_get(x_32, 0); -lean_inc(x_52); -x_53 = lean_ctor_get(x_32, 1); +x_53 = lean_ctor_get(x_32, 0); lean_inc(x_53); -x_54 = lean_ctor_get(x_32, 2); +x_54 = lean_ctor_get(x_32, 1); lean_inc(x_54); -x_55 = lean_ctor_get(x_32, 3); +x_55 = lean_ctor_get(x_32, 2); lean_inc(x_55); +x_56 = lean_ctor_get(x_32, 3); +lean_inc(x_56); +x_57 = lean_ctor_get(x_32, 4); +lean_inc(x_57); if (lean_is_exclusive(x_32)) { lean_ctor_release(x_32, 0); lean_ctor_release(x_32, 1); lean_ctor_release(x_32, 2); lean_ctor_release(x_32, 3); - x_56 = x_32; + lean_ctor_release(x_32, 4); + x_58 = x_32; } else { lean_dec_ref(x_32); - x_56 = lean_box(0); + x_58 = lean_box(0); } lean_inc(x_34); -x_57 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_52, x_1, x_34); -if (lean_is_scalar(x_56)) { - x_58 = lean_alloc_ctor(0, 4, 0); +x_59 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_53, x_1, x_34); +if (lean_is_scalar(x_58)) { + x_60 = lean_alloc_ctor(0, 5, 0); } else { - x_58 = x_56; + x_60 = x_58; } -lean_ctor_set(x_58, 0, x_57); -lean_ctor_set(x_58, 1, x_53); -lean_ctor_set(x_58, 2, x_54); -lean_ctor_set(x_58, 3, x_55); -x_59 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_59, 0, x_47); -lean_ctor_set(x_59, 1, x_48); -lean_ctor_set(x_59, 2, x_58); -lean_ctor_set(x_59, 3, x_49); -lean_ctor_set(x_59, 4, x_50); -lean_ctor_set(x_59, 5, x_51); -lean_ctor_set(x_30, 1, x_59); +lean_ctor_set(x_60, 0, x_59); +lean_ctor_set(x_60, 1, x_54); +lean_ctor_set(x_60, 2, x_55); +lean_ctor_set(x_60, 3, x_56); +lean_ctor_set(x_60, 4, x_57); +x_61 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_61, 0, x_48); +lean_ctor_set(x_61, 1, x_49); +lean_ctor_set(x_61, 2, x_60); +lean_ctor_set(x_61, 3, x_50); +lean_ctor_set(x_61, 4, x_51); +lean_ctor_set(x_61, 5, x_52); +lean_ctor_set(x_30, 1, x_61); return x_30; } } else { -lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; -x_60 = lean_ctor_get(x_30, 0); -lean_inc(x_60); -lean_dec(x_30); -x_61 = lean_ctor_get(x_31, 0); -lean_inc(x_61); -x_62 = lean_ctor_get(x_31, 1); +lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; +x_62 = lean_ctor_get(x_30, 0); lean_inc(x_62); -x_63 = lean_ctor_get(x_31, 3); +lean_dec(x_30); +x_63 = lean_ctor_get(x_31, 0); lean_inc(x_63); -x_64 = lean_ctor_get(x_31, 4); +x_64 = lean_ctor_get(x_31, 1); lean_inc(x_64); -x_65 = lean_ctor_get(x_31, 5); +x_65 = lean_ctor_get(x_31, 3); lean_inc(x_65); +x_66 = lean_ctor_get(x_31, 4); +lean_inc(x_66); +x_67 = lean_ctor_get(x_31, 5); +lean_inc(x_67); if (lean_is_exclusive(x_31)) { lean_ctor_release(x_31, 0); lean_ctor_release(x_31, 1); @@ -4091,836 +4109,873 @@ if (lean_is_exclusive(x_31)) { lean_ctor_release(x_31, 3); lean_ctor_release(x_31, 4); lean_ctor_release(x_31, 5); - x_66 = x_31; + x_68 = x_31; } else { lean_dec_ref(x_31); - x_66 = lean_box(0); + x_68 = lean_box(0); } -x_67 = lean_ctor_get(x_32, 0); -lean_inc(x_67); -x_68 = lean_ctor_get(x_32, 1); -lean_inc(x_68); -x_69 = lean_ctor_get(x_32, 2); +x_69 = lean_ctor_get(x_32, 0); lean_inc(x_69); -x_70 = lean_ctor_get(x_32, 3); +x_70 = lean_ctor_get(x_32, 1); lean_inc(x_70); +x_71 = lean_ctor_get(x_32, 2); +lean_inc(x_71); +x_72 = lean_ctor_get(x_32, 3); +lean_inc(x_72); +x_73 = lean_ctor_get(x_32, 4); +lean_inc(x_73); if (lean_is_exclusive(x_32)) { lean_ctor_release(x_32, 0); lean_ctor_release(x_32, 1); lean_ctor_release(x_32, 2); lean_ctor_release(x_32, 3); - x_71 = x_32; + lean_ctor_release(x_32, 4); + x_74 = x_32; } else { lean_dec_ref(x_32); - x_71 = lean_box(0); + x_74 = lean_box(0); } -lean_inc(x_60); -x_72 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_67, x_1, x_60); -if (lean_is_scalar(x_71)) { - x_73 = lean_alloc_ctor(0, 4, 0); +lean_inc(x_62); +x_75 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_69, x_1, x_62); +if (lean_is_scalar(x_74)) { + x_76 = lean_alloc_ctor(0, 5, 0); } else { - x_73 = x_71; + x_76 = x_74; } -lean_ctor_set(x_73, 0, x_72); -lean_ctor_set(x_73, 1, x_68); -lean_ctor_set(x_73, 2, x_69); -lean_ctor_set(x_73, 3, x_70); -if (lean_is_scalar(x_66)) { - x_74 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_76, 0, x_75); +lean_ctor_set(x_76, 1, x_70); +lean_ctor_set(x_76, 2, x_71); +lean_ctor_set(x_76, 3, x_72); +lean_ctor_set(x_76, 4, x_73); +if (lean_is_scalar(x_68)) { + x_77 = lean_alloc_ctor(0, 6, 0); } else { - x_74 = x_66; + x_77 = x_68; } -lean_ctor_set(x_74, 0, x_61); -lean_ctor_set(x_74, 1, x_62); -lean_ctor_set(x_74, 2, x_73); -lean_ctor_set(x_74, 3, x_63); -lean_ctor_set(x_74, 4, x_64); -lean_ctor_set(x_74, 5, x_65); -x_75 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_75, 0, x_60); -lean_ctor_set(x_75, 1, x_74); -return x_75; +lean_ctor_set(x_77, 0, x_63); +lean_ctor_set(x_77, 1, x_64); +lean_ctor_set(x_77, 2, x_76); +lean_ctor_set(x_77, 3, x_65); +lean_ctor_set(x_77, 4, x_66); +lean_ctor_set(x_77, 5, x_67); +x_78 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_78, 0, x_62); +lean_ctor_set(x_78, 1, x_77); +return x_78; } } else { -uint8_t x_76; +uint8_t x_79; lean_dec(x_1); -x_76 = !lean_is_exclusive(x_30); -if (x_76 == 0) +x_79 = !lean_is_exclusive(x_30); +if (x_79 == 0) { return x_30; } else { -lean_object* x_77; lean_object* x_78; lean_object* x_79; -x_77 = lean_ctor_get(x_30, 0); -x_78 = lean_ctor_get(x_30, 1); -lean_inc(x_78); -lean_inc(x_77); +lean_object* x_80; lean_object* x_81; lean_object* x_82; +x_80 = lean_ctor_get(x_30, 0); +x_81 = lean_ctor_get(x_30, 1); +lean_inc(x_81); +lean_inc(x_80); lean_dec(x_30); -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; +x_82 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_82, 0, x_80); +lean_ctor_set(x_82, 1, x_81); +return x_82; } } } else { -lean_object* x_80; lean_object* x_81; +lean_object* x_83; lean_object* x_84; lean_dec(x_26); lean_dec(x_19); lean_dec(x_2); lean_dec(x_1); -x_80 = lean_ctor_get(x_29, 0); -lean_inc(x_80); +x_83 = lean_ctor_get(x_29, 0); +lean_inc(x_83); lean_dec(x_29); -x_81 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_81, 0, x_80); -lean_ctor_set(x_81, 1, x_3); -return x_81; +x_84 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_84, 0, x_83); +lean_ctor_set(x_84, 1, x_3); +return x_84; } } case 7: { -lean_object* x_82; lean_object* x_83; lean_object* x_84; -x_82 = lean_ctor_get(x_3, 2); -lean_inc(x_82); -x_83 = lean_ctor_get(x_82, 0); -lean_inc(x_83); -lean_dec(x_82); -x_84 = l_Std_PersistentHashMap_find_x3f___at___private_Lean_Meta_InferType_9__checkInferTypeCache___spec__1(x_83, x_1); -if (lean_obj_tag(x_84) == 0) +lean_object* x_85; lean_object* x_86; lean_object* x_87; +x_85 = lean_ctor_get(x_3, 2); +lean_inc(x_85); +x_86 = lean_ctor_get(x_85, 0); +lean_inc(x_86); +lean_dec(x_85); +x_87 = l_Std_PersistentHashMap_find_x3f___at___private_Lean_Meta_InferType_9__checkInferTypeCache___spec__1(x_86, x_1); +if (lean_obj_tag(x_87) == 0) { -lean_object* x_85; lean_object* x_86; -x_85 = l___private_Lean_Meta_InferType_4__inferForallType___closed__1; +lean_object* x_88; lean_object* x_89; +x_88 = l___private_Lean_Meta_InferType_4__inferForallType___closed__1; lean_inc(x_1); -x_86 = l_Lean_Meta_forallTelescope___rarg(x_1, x_85, x_2, x_3); -if (lean_obj_tag(x_86) == 0) -{ -lean_object* x_87; lean_object* x_88; uint8_t x_89; -x_87 = lean_ctor_get(x_86, 1); -lean_inc(x_87); -x_88 = lean_ctor_get(x_87, 2); -lean_inc(x_88); -x_89 = !lean_is_exclusive(x_86); -if (x_89 == 0) +x_89 = l_Lean_Meta_forallTelescope___rarg(x_1, x_88, x_2, x_3); +if (lean_obj_tag(x_89) == 0) { lean_object* x_90; lean_object* x_91; uint8_t x_92; -x_90 = lean_ctor_get(x_86, 0); -x_91 = lean_ctor_get(x_86, 1); -lean_dec(x_91); -x_92 = !lean_is_exclusive(x_87); +x_90 = lean_ctor_get(x_89, 1); +lean_inc(x_90); +x_91 = lean_ctor_get(x_90, 2); +lean_inc(x_91); +x_92 = !lean_is_exclusive(x_89); if (x_92 == 0) { -lean_object* x_93; uint8_t x_94; -x_93 = lean_ctor_get(x_87, 2); -lean_dec(x_93); -x_94 = !lean_is_exclusive(x_88); -if (x_94 == 0) +lean_object* x_93; lean_object* x_94; uint8_t x_95; +x_93 = lean_ctor_get(x_89, 0); +x_94 = lean_ctor_get(x_89, 1); +lean_dec(x_94); +x_95 = !lean_is_exclusive(x_90); +if (x_95 == 0) { -lean_object* x_95; lean_object* x_96; -x_95 = lean_ctor_get(x_88, 0); -lean_inc(x_90); -x_96 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_95, x_1, x_90); -lean_ctor_set(x_88, 0, x_96); -return x_86; +lean_object* x_96; uint8_t x_97; +x_96 = lean_ctor_get(x_90, 2); +lean_dec(x_96); +x_97 = !lean_is_exclusive(x_91); +if (x_97 == 0) +{ +lean_object* x_98; lean_object* x_99; +x_98 = lean_ctor_get(x_91, 0); +lean_inc(x_93); +x_99 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_98, x_1, x_93); +lean_ctor_set(x_91, 0, x_99); +return x_89; } else { -lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; -x_97 = lean_ctor_get(x_88, 0); -x_98 = lean_ctor_get(x_88, 1); -x_99 = lean_ctor_get(x_88, 2); -x_100 = lean_ctor_get(x_88, 3); -lean_inc(x_100); -lean_inc(x_99); -lean_inc(x_98); -lean_inc(x_97); -lean_dec(x_88); -lean_inc(x_90); -x_101 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_97, x_1, x_90); -x_102 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_102, 0, x_101); -lean_ctor_set(x_102, 1, x_98); -lean_ctor_set(x_102, 2, x_99); -lean_ctor_set(x_102, 3, x_100); -lean_ctor_set(x_87, 2, x_102); -return x_86; -} -} -else -{ -lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; -x_103 = lean_ctor_get(x_87, 0); -x_104 = lean_ctor_get(x_87, 1); -x_105 = lean_ctor_get(x_87, 3); -x_106 = lean_ctor_get(x_87, 4); -x_107 = lean_ctor_get(x_87, 5); -lean_inc(x_107); -lean_inc(x_106); -lean_inc(x_105); +lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; +x_100 = lean_ctor_get(x_91, 0); +x_101 = lean_ctor_get(x_91, 1); +x_102 = lean_ctor_get(x_91, 2); +x_103 = lean_ctor_get(x_91, 3); +x_104 = lean_ctor_get(x_91, 4); lean_inc(x_104); lean_inc(x_103); -lean_dec(x_87); -x_108 = lean_ctor_get(x_88, 0); -lean_inc(x_108); -x_109 = lean_ctor_get(x_88, 1); -lean_inc(x_109); -x_110 = lean_ctor_get(x_88, 2); -lean_inc(x_110); -x_111 = lean_ctor_get(x_88, 3); -lean_inc(x_111); -if (lean_is_exclusive(x_88)) { - lean_ctor_release(x_88, 0); - lean_ctor_release(x_88, 1); - lean_ctor_release(x_88, 2); - lean_ctor_release(x_88, 3); - x_112 = x_88; -} else { - lean_dec_ref(x_88); - x_112 = lean_box(0); -} -lean_inc(x_90); -x_113 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_108, x_1, x_90); -if (lean_is_scalar(x_112)) { - x_114 = lean_alloc_ctor(0, 4, 0); -} else { - x_114 = x_112; -} -lean_ctor_set(x_114, 0, x_113); -lean_ctor_set(x_114, 1, x_109); -lean_ctor_set(x_114, 2, x_110); -lean_ctor_set(x_114, 3, x_111); -x_115 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_115, 0, x_103); -lean_ctor_set(x_115, 1, x_104); -lean_ctor_set(x_115, 2, x_114); -lean_ctor_set(x_115, 3, x_105); -lean_ctor_set(x_115, 4, x_106); -lean_ctor_set(x_115, 5, x_107); -lean_ctor_set(x_86, 1, x_115); -return x_86; +lean_inc(x_102); +lean_inc(x_101); +lean_inc(x_100); +lean_dec(x_91); +lean_inc(x_93); +x_105 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_100, x_1, x_93); +x_106 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_106, 0, x_105); +lean_ctor_set(x_106, 1, x_101); +lean_ctor_set(x_106, 2, x_102); +lean_ctor_set(x_106, 3, x_103); +lean_ctor_set(x_106, 4, x_104); +lean_ctor_set(x_90, 2, x_106); +return x_89; } } else { -lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; -x_116 = lean_ctor_get(x_86, 0); +lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; +x_107 = lean_ctor_get(x_90, 0); +x_108 = lean_ctor_get(x_90, 1); +x_109 = lean_ctor_get(x_90, 3); +x_110 = lean_ctor_get(x_90, 4); +x_111 = lean_ctor_get(x_90, 5); +lean_inc(x_111); +lean_inc(x_110); +lean_inc(x_109); +lean_inc(x_108); +lean_inc(x_107); +lean_dec(x_90); +x_112 = lean_ctor_get(x_91, 0); +lean_inc(x_112); +x_113 = lean_ctor_get(x_91, 1); +lean_inc(x_113); +x_114 = lean_ctor_get(x_91, 2); +lean_inc(x_114); +x_115 = lean_ctor_get(x_91, 3); +lean_inc(x_115); +x_116 = lean_ctor_get(x_91, 4); lean_inc(x_116); -lean_dec(x_86); -x_117 = lean_ctor_get(x_87, 0); -lean_inc(x_117); -x_118 = lean_ctor_get(x_87, 1); -lean_inc(x_118); -x_119 = lean_ctor_get(x_87, 3); -lean_inc(x_119); -x_120 = lean_ctor_get(x_87, 4); -lean_inc(x_120); -x_121 = lean_ctor_get(x_87, 5); -lean_inc(x_121); -if (lean_is_exclusive(x_87)) { - lean_ctor_release(x_87, 0); - lean_ctor_release(x_87, 1); - lean_ctor_release(x_87, 2); - lean_ctor_release(x_87, 3); - lean_ctor_release(x_87, 4); - lean_ctor_release(x_87, 5); - x_122 = x_87; +if (lean_is_exclusive(x_91)) { + lean_ctor_release(x_91, 0); + lean_ctor_release(x_91, 1); + lean_ctor_release(x_91, 2); + lean_ctor_release(x_91, 3); + lean_ctor_release(x_91, 4); + x_117 = x_91; } else { - lean_dec_ref(x_87); - x_122 = lean_box(0); + lean_dec_ref(x_91); + x_117 = lean_box(0); } -x_123 = lean_ctor_get(x_88, 0); -lean_inc(x_123); -x_124 = lean_ctor_get(x_88, 1); -lean_inc(x_124); -x_125 = lean_ctor_get(x_88, 2); -lean_inc(x_125); -x_126 = lean_ctor_get(x_88, 3); -lean_inc(x_126); -if (lean_is_exclusive(x_88)) { - lean_ctor_release(x_88, 0); - lean_ctor_release(x_88, 1); - lean_ctor_release(x_88, 2); - lean_ctor_release(x_88, 3); - x_127 = x_88; +lean_inc(x_93); +x_118 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_112, x_1, x_93); +if (lean_is_scalar(x_117)) { + x_119 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_88); + x_119 = x_117; +} +lean_ctor_set(x_119, 0, x_118); +lean_ctor_set(x_119, 1, x_113); +lean_ctor_set(x_119, 2, x_114); +lean_ctor_set(x_119, 3, x_115); +lean_ctor_set(x_119, 4, x_116); +x_120 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_120, 0, x_107); +lean_ctor_set(x_120, 1, x_108); +lean_ctor_set(x_120, 2, x_119); +lean_ctor_set(x_120, 3, x_109); +lean_ctor_set(x_120, 4, x_110); +lean_ctor_set(x_120, 5, x_111); +lean_ctor_set(x_89, 1, x_120); +return x_89; +} +} +else +{ +lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; 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; +x_121 = lean_ctor_get(x_89, 0); +lean_inc(x_121); +lean_dec(x_89); +x_122 = lean_ctor_get(x_90, 0); +lean_inc(x_122); +x_123 = lean_ctor_get(x_90, 1); +lean_inc(x_123); +x_124 = lean_ctor_get(x_90, 3); +lean_inc(x_124); +x_125 = lean_ctor_get(x_90, 4); +lean_inc(x_125); +x_126 = lean_ctor_get(x_90, 5); +lean_inc(x_126); +if (lean_is_exclusive(x_90)) { + lean_ctor_release(x_90, 0); + lean_ctor_release(x_90, 1); + lean_ctor_release(x_90, 2); + lean_ctor_release(x_90, 3); + lean_ctor_release(x_90, 4); + lean_ctor_release(x_90, 5); + x_127 = x_90; +} else { + lean_dec_ref(x_90); x_127 = lean_box(0); } -lean_inc(x_116); -x_128 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_123, x_1, x_116); +x_128 = lean_ctor_get(x_91, 0); +lean_inc(x_128); +x_129 = lean_ctor_get(x_91, 1); +lean_inc(x_129); +x_130 = lean_ctor_get(x_91, 2); +lean_inc(x_130); +x_131 = lean_ctor_get(x_91, 3); +lean_inc(x_131); +x_132 = lean_ctor_get(x_91, 4); +lean_inc(x_132); +if (lean_is_exclusive(x_91)) { + lean_ctor_release(x_91, 0); + lean_ctor_release(x_91, 1); + lean_ctor_release(x_91, 2); + lean_ctor_release(x_91, 3); + lean_ctor_release(x_91, 4); + x_133 = x_91; +} else { + lean_dec_ref(x_91); + x_133 = lean_box(0); +} +lean_inc(x_121); +x_134 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_128, x_1, x_121); +if (lean_is_scalar(x_133)) { + x_135 = lean_alloc_ctor(0, 5, 0); +} else { + x_135 = x_133; +} +lean_ctor_set(x_135, 0, x_134); +lean_ctor_set(x_135, 1, x_129); +lean_ctor_set(x_135, 2, x_130); +lean_ctor_set(x_135, 3, x_131); +lean_ctor_set(x_135, 4, x_132); if (lean_is_scalar(x_127)) { - x_129 = lean_alloc_ctor(0, 4, 0); + x_136 = lean_alloc_ctor(0, 6, 0); } else { - x_129 = x_127; + x_136 = x_127; } -lean_ctor_set(x_129, 0, x_128); -lean_ctor_set(x_129, 1, x_124); -lean_ctor_set(x_129, 2, x_125); -lean_ctor_set(x_129, 3, x_126); -if (lean_is_scalar(x_122)) { - x_130 = lean_alloc_ctor(0, 6, 0); -} else { - x_130 = x_122; -} -lean_ctor_set(x_130, 0, x_117); -lean_ctor_set(x_130, 1, x_118); -lean_ctor_set(x_130, 2, x_129); -lean_ctor_set(x_130, 3, x_119); -lean_ctor_set(x_130, 4, x_120); -lean_ctor_set(x_130, 5, x_121); -x_131 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_131, 0, x_116); -lean_ctor_set(x_131, 1, x_130); -return x_131; +lean_ctor_set(x_136, 0, x_122); +lean_ctor_set(x_136, 1, x_123); +lean_ctor_set(x_136, 2, x_135); +lean_ctor_set(x_136, 3, x_124); +lean_ctor_set(x_136, 4, x_125); +lean_ctor_set(x_136, 5, x_126); +x_137 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_137, 0, x_121); +lean_ctor_set(x_137, 1, x_136); +return x_137; } } else { -uint8_t x_132; +uint8_t x_138; lean_dec(x_1); -x_132 = !lean_is_exclusive(x_86); -if (x_132 == 0) +x_138 = !lean_is_exclusive(x_89); +if (x_138 == 0) { -return x_86; +return x_89; } else { -lean_object* x_133; lean_object* x_134; lean_object* x_135; -x_133 = lean_ctor_get(x_86, 0); -x_134 = lean_ctor_get(x_86, 1); -lean_inc(x_134); -lean_inc(x_133); -lean_dec(x_86); -x_135 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_135, 0, x_133); -lean_ctor_set(x_135, 1, x_134); -return x_135; +lean_object* x_139; lean_object* x_140; lean_object* x_141; +x_139 = lean_ctor_get(x_89, 0); +x_140 = lean_ctor_get(x_89, 1); +lean_inc(x_140); +lean_inc(x_139); +lean_dec(x_89); +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; } } } else { -lean_object* x_136; lean_object* x_137; +lean_object* x_142; lean_object* x_143; lean_dec(x_2); lean_dec(x_1); -x_136 = lean_ctor_get(x_84, 0); -lean_inc(x_136); -lean_dec(x_84); -x_137 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_137, 0, x_136); -lean_ctor_set(x_137, 1, x_3); -return x_137; +x_142 = lean_ctor_get(x_87, 0); +lean_inc(x_142); +lean_dec(x_87); +x_143 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_143, 0, x_142); +lean_ctor_set(x_143, 1, x_3); +return x_143; } } case 9: { -lean_object* x_138; lean_object* x_139; lean_object* x_140; +lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_dec(x_2); -x_138 = lean_ctor_get(x_1, 0); -lean_inc(x_138); +x_144 = lean_ctor_get(x_1, 0); +lean_inc(x_144); lean_dec(x_1); -x_139 = l_Lean_Literal_type(x_138); -lean_dec(x_138); -x_140 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_140, 0, x_139); -lean_ctor_set(x_140, 1, x_3); -return x_140; +x_145 = l_Lean_Literal_type(x_144); +lean_dec(x_144); +x_146 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_146, 0, x_145); +lean_ctor_set(x_146, 1, x_3); +return x_146; } case 10: { -lean_object* x_141; -x_141 = lean_ctor_get(x_1, 1); -lean_inc(x_141); +lean_object* x_147; +x_147 = lean_ctor_get(x_1, 1); +lean_inc(x_147); lean_dec(x_1); -x_1 = x_141; +x_1 = x_147; goto _start; } case 11: { -lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; -x_143 = lean_ctor_get(x_1, 0); -lean_inc(x_143); -x_144 = lean_ctor_get(x_1, 1); -lean_inc(x_144); -x_145 = lean_ctor_get(x_1, 2); -lean_inc(x_145); -x_146 = lean_ctor_get(x_3, 2); -lean_inc(x_146); -x_147 = lean_ctor_get(x_146, 0); -lean_inc(x_147); -lean_dec(x_146); -x_148 = l_Std_PersistentHashMap_find_x3f___at___private_Lean_Meta_InferType_9__checkInferTypeCache___spec__1(x_147, x_1); -if (lean_obj_tag(x_148) == 0) -{ -lean_object* x_149; -x_149 = l___private_Lean_Meta_InferType_3__inferProjType(x_143, x_144, x_145, x_2, x_3); -if (lean_obj_tag(x_149) == 0) -{ -lean_object* x_150; lean_object* x_151; uint8_t x_152; -x_150 = lean_ctor_get(x_149, 1); +lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; +x_149 = lean_ctor_get(x_1, 0); +lean_inc(x_149); +x_150 = lean_ctor_get(x_1, 1); lean_inc(x_150); -x_151 = lean_ctor_get(x_150, 2); +x_151 = lean_ctor_get(x_1, 2); lean_inc(x_151); -x_152 = !lean_is_exclusive(x_149); -if (x_152 == 0) -{ -lean_object* x_153; lean_object* x_154; uint8_t x_155; -x_153 = lean_ctor_get(x_149, 0); -x_154 = lean_ctor_get(x_149, 1); -lean_dec(x_154); -x_155 = !lean_is_exclusive(x_150); -if (x_155 == 0) -{ -lean_object* x_156; uint8_t x_157; -x_156 = lean_ctor_get(x_150, 2); -lean_dec(x_156); -x_157 = !lean_is_exclusive(x_151); -if (x_157 == 0) -{ -lean_object* x_158; lean_object* x_159; -x_158 = lean_ctor_get(x_151, 0); +x_152 = lean_ctor_get(x_3, 2); +lean_inc(x_152); +x_153 = lean_ctor_get(x_152, 0); lean_inc(x_153); -x_159 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_158, x_1, x_153); -lean_ctor_set(x_151, 0, x_159); -return x_149; +lean_dec(x_152); +x_154 = l_Std_PersistentHashMap_find_x3f___at___private_Lean_Meta_InferType_9__checkInferTypeCache___spec__1(x_153, x_1); +if (lean_obj_tag(x_154) == 0) +{ +lean_object* x_155; +x_155 = l___private_Lean_Meta_InferType_3__inferProjType(x_149, x_150, x_151, x_2, x_3); +if (lean_obj_tag(x_155) == 0) +{ +lean_object* x_156; lean_object* x_157; uint8_t x_158; +x_156 = lean_ctor_get(x_155, 1); +lean_inc(x_156); +x_157 = lean_ctor_get(x_156, 2); +lean_inc(x_157); +x_158 = !lean_is_exclusive(x_155); +if (x_158 == 0) +{ +lean_object* x_159; lean_object* x_160; uint8_t x_161; +x_159 = lean_ctor_get(x_155, 0); +x_160 = lean_ctor_get(x_155, 1); +lean_dec(x_160); +x_161 = !lean_is_exclusive(x_156); +if (x_161 == 0) +{ +lean_object* x_162; uint8_t x_163; +x_162 = lean_ctor_get(x_156, 2); +lean_dec(x_162); +x_163 = !lean_is_exclusive(x_157); +if (x_163 == 0) +{ +lean_object* x_164; lean_object* x_165; +x_164 = lean_ctor_get(x_157, 0); +lean_inc(x_159); +x_165 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_164, x_1, x_159); +lean_ctor_set(x_157, 0, x_165); +return x_155; } else { -lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; -x_160 = lean_ctor_get(x_151, 0); -x_161 = lean_ctor_get(x_151, 1); -x_162 = lean_ctor_get(x_151, 2); -x_163 = lean_ctor_get(x_151, 3); -lean_inc(x_163); -lean_inc(x_162); -lean_inc(x_161); -lean_inc(x_160); -lean_dec(x_151); -lean_inc(x_153); -x_164 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_160, x_1, x_153); -x_165 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_165, 0, x_164); -lean_ctor_set(x_165, 1, x_161); -lean_ctor_set(x_165, 2, x_162); -lean_ctor_set(x_165, 3, x_163); -lean_ctor_set(x_150, 2, x_165); -return x_149; -} -} -else -{ -lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; lean_object* x_173; lean_object* x_174; lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; -x_166 = lean_ctor_get(x_150, 0); -x_167 = lean_ctor_get(x_150, 1); -x_168 = lean_ctor_get(x_150, 3); -x_169 = lean_ctor_get(x_150, 4); -x_170 = lean_ctor_get(x_150, 5); +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; +x_166 = lean_ctor_get(x_157, 0); +x_167 = lean_ctor_get(x_157, 1); +x_168 = lean_ctor_get(x_157, 2); +x_169 = lean_ctor_get(x_157, 3); +x_170 = lean_ctor_get(x_157, 4); lean_inc(x_170); lean_inc(x_169); lean_inc(x_168); lean_inc(x_167); lean_inc(x_166); -lean_dec(x_150); -x_171 = lean_ctor_get(x_151, 0); -lean_inc(x_171); -x_172 = lean_ctor_get(x_151, 1); -lean_inc(x_172); -x_173 = lean_ctor_get(x_151, 2); -lean_inc(x_173); -x_174 = lean_ctor_get(x_151, 3); +lean_dec(x_157); +lean_inc(x_159); +x_171 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_166, x_1, x_159); +x_172 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_172, 0, x_171); +lean_ctor_set(x_172, 1, x_167); +lean_ctor_set(x_172, 2, x_168); +lean_ctor_set(x_172, 3, x_169); +lean_ctor_set(x_172, 4, x_170); +lean_ctor_set(x_156, 2, x_172); +return x_155; +} +} +else +{ +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; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; +x_173 = lean_ctor_get(x_156, 0); +x_174 = lean_ctor_get(x_156, 1); +x_175 = lean_ctor_get(x_156, 3); +x_176 = lean_ctor_get(x_156, 4); +x_177 = lean_ctor_get(x_156, 5); +lean_inc(x_177); +lean_inc(x_176); +lean_inc(x_175); lean_inc(x_174); -if (lean_is_exclusive(x_151)) { - lean_ctor_release(x_151, 0); - lean_ctor_release(x_151, 1); - lean_ctor_release(x_151, 2); - lean_ctor_release(x_151, 3); - x_175 = x_151; -} else { - lean_dec_ref(x_151); - x_175 = lean_box(0); -} -lean_inc(x_153); -x_176 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_171, x_1, x_153); -if (lean_is_scalar(x_175)) { - x_177 = lean_alloc_ctor(0, 4, 0); -} else { - x_177 = x_175; -} -lean_ctor_set(x_177, 0, x_176); -lean_ctor_set(x_177, 1, x_172); -lean_ctor_set(x_177, 2, x_173); -lean_ctor_set(x_177, 3, x_174); -x_178 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_178, 0, x_166); -lean_ctor_set(x_178, 1, x_167); -lean_ctor_set(x_178, 2, x_177); -lean_ctor_set(x_178, 3, x_168); -lean_ctor_set(x_178, 4, x_169); -lean_ctor_set(x_178, 5, x_170); -lean_ctor_set(x_149, 1, x_178); -return x_149; -} -} -else -{ -lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; -x_179 = lean_ctor_get(x_149, 0); +lean_inc(x_173); +lean_dec(x_156); +x_178 = lean_ctor_get(x_157, 0); +lean_inc(x_178); +x_179 = lean_ctor_get(x_157, 1); lean_inc(x_179); -lean_dec(x_149); -x_180 = lean_ctor_get(x_150, 0); +x_180 = lean_ctor_get(x_157, 2); lean_inc(x_180); -x_181 = lean_ctor_get(x_150, 1); +x_181 = lean_ctor_get(x_157, 3); lean_inc(x_181); -x_182 = lean_ctor_get(x_150, 3); +x_182 = lean_ctor_get(x_157, 4); lean_inc(x_182); -x_183 = lean_ctor_get(x_150, 4); -lean_inc(x_183); -x_184 = lean_ctor_get(x_150, 5); -lean_inc(x_184); -if (lean_is_exclusive(x_150)) { - lean_ctor_release(x_150, 0); - lean_ctor_release(x_150, 1); - lean_ctor_release(x_150, 2); - lean_ctor_release(x_150, 3); - lean_ctor_release(x_150, 4); - lean_ctor_release(x_150, 5); - x_185 = x_150; +if (lean_is_exclusive(x_157)) { + lean_ctor_release(x_157, 0); + lean_ctor_release(x_157, 1); + lean_ctor_release(x_157, 2); + lean_ctor_release(x_157, 3); + lean_ctor_release(x_157, 4); + x_183 = x_157; } else { - lean_dec_ref(x_150); - x_185 = lean_box(0); + lean_dec_ref(x_157); + x_183 = lean_box(0); } -x_186 = lean_ctor_get(x_151, 0); -lean_inc(x_186); -x_187 = lean_ctor_get(x_151, 1); +lean_inc(x_159); +x_184 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_178, x_1, x_159); +if (lean_is_scalar(x_183)) { + x_185 = lean_alloc_ctor(0, 5, 0); +} else { + x_185 = x_183; +} +lean_ctor_set(x_185, 0, x_184); +lean_ctor_set(x_185, 1, x_179); +lean_ctor_set(x_185, 2, x_180); +lean_ctor_set(x_185, 3, x_181); +lean_ctor_set(x_185, 4, x_182); +x_186 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_186, 0, x_173); +lean_ctor_set(x_186, 1, x_174); +lean_ctor_set(x_186, 2, x_185); +lean_ctor_set(x_186, 3, x_175); +lean_ctor_set(x_186, 4, x_176); +lean_ctor_set(x_186, 5, x_177); +lean_ctor_set(x_155, 1, x_186); +return x_155; +} +} +else +{ +lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; +x_187 = lean_ctor_get(x_155, 0); lean_inc(x_187); -x_188 = lean_ctor_get(x_151, 2); +lean_dec(x_155); +x_188 = lean_ctor_get(x_156, 0); lean_inc(x_188); -x_189 = lean_ctor_get(x_151, 3); +x_189 = lean_ctor_get(x_156, 1); lean_inc(x_189); -if (lean_is_exclusive(x_151)) { - lean_ctor_release(x_151, 0); - lean_ctor_release(x_151, 1); - lean_ctor_release(x_151, 2); - lean_ctor_release(x_151, 3); - x_190 = x_151; +x_190 = lean_ctor_get(x_156, 3); +lean_inc(x_190); +x_191 = lean_ctor_get(x_156, 4); +lean_inc(x_191); +x_192 = lean_ctor_get(x_156, 5); +lean_inc(x_192); +if (lean_is_exclusive(x_156)) { + lean_ctor_release(x_156, 0); + lean_ctor_release(x_156, 1); + lean_ctor_release(x_156, 2); + lean_ctor_release(x_156, 3); + lean_ctor_release(x_156, 4); + lean_ctor_release(x_156, 5); + x_193 = x_156; } else { - lean_dec_ref(x_151); - x_190 = lean_box(0); + lean_dec_ref(x_156); + x_193 = lean_box(0); } -lean_inc(x_179); -x_191 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_186, x_1, x_179); -if (lean_is_scalar(x_190)) { - x_192 = lean_alloc_ctor(0, 4, 0); -} else { - x_192 = x_190; -} -lean_ctor_set(x_192, 0, x_191); -lean_ctor_set(x_192, 1, x_187); -lean_ctor_set(x_192, 2, x_188); -lean_ctor_set(x_192, 3, x_189); -if (lean_is_scalar(x_185)) { - x_193 = lean_alloc_ctor(0, 6, 0); -} else { - x_193 = x_185; -} -lean_ctor_set(x_193, 0, x_180); -lean_ctor_set(x_193, 1, x_181); -lean_ctor_set(x_193, 2, x_192); -lean_ctor_set(x_193, 3, x_182); -lean_ctor_set(x_193, 4, x_183); -lean_ctor_set(x_193, 5, x_184); -x_194 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_194, 0, x_179); -lean_ctor_set(x_194, 1, x_193); -return x_194; -} -} -else -{ -uint8_t x_195; -lean_dec(x_1); -x_195 = !lean_is_exclusive(x_149); -if (x_195 == 0) -{ -return x_149; -} -else -{ -lean_object* x_196; lean_object* x_197; lean_object* x_198; -x_196 = lean_ctor_get(x_149, 0); -x_197 = lean_ctor_get(x_149, 1); -lean_inc(x_197); +x_194 = lean_ctor_get(x_157, 0); +lean_inc(x_194); +x_195 = lean_ctor_get(x_157, 1); +lean_inc(x_195); +x_196 = lean_ctor_get(x_157, 2); lean_inc(x_196); -lean_dec(x_149); -x_198 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_198, 0, x_196); -lean_ctor_set(x_198, 1, x_197); -return x_198; +x_197 = lean_ctor_get(x_157, 3); +lean_inc(x_197); +x_198 = lean_ctor_get(x_157, 4); +lean_inc(x_198); +if (lean_is_exclusive(x_157)) { + lean_ctor_release(x_157, 0); + lean_ctor_release(x_157, 1); + lean_ctor_release(x_157, 2); + lean_ctor_release(x_157, 3); + lean_ctor_release(x_157, 4); + x_199 = x_157; +} else { + lean_dec_ref(x_157); + x_199 = lean_box(0); +} +lean_inc(x_187); +x_200 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_194, x_1, x_187); +if (lean_is_scalar(x_199)) { + x_201 = lean_alloc_ctor(0, 5, 0); +} else { + x_201 = x_199; +} +lean_ctor_set(x_201, 0, x_200); +lean_ctor_set(x_201, 1, x_195); +lean_ctor_set(x_201, 2, x_196); +lean_ctor_set(x_201, 3, x_197); +lean_ctor_set(x_201, 4, x_198); +if (lean_is_scalar(x_193)) { + x_202 = lean_alloc_ctor(0, 6, 0); +} else { + x_202 = x_193; +} +lean_ctor_set(x_202, 0, x_188); +lean_ctor_set(x_202, 1, x_189); +lean_ctor_set(x_202, 2, x_201); +lean_ctor_set(x_202, 3, x_190); +lean_ctor_set(x_202, 4, x_191); +lean_ctor_set(x_202, 5, x_192); +x_203 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_203, 0, x_187); +lean_ctor_set(x_203, 1, x_202); +return x_203; +} +} +else +{ +uint8_t x_204; +lean_dec(x_1); +x_204 = !lean_is_exclusive(x_155); +if (x_204 == 0) +{ +return x_155; +} +else +{ +lean_object* x_205; lean_object* x_206; lean_object* x_207; +x_205 = lean_ctor_get(x_155, 0); +x_206 = lean_ctor_get(x_155, 1); +lean_inc(x_206); +lean_inc(x_205); +lean_dec(x_155); +x_207 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_207, 0, x_205); +lean_ctor_set(x_207, 1, x_206); +return x_207; } } } else { -lean_object* x_199; lean_object* x_200; -lean_dec(x_145); -lean_dec(x_144); -lean_dec(x_143); +lean_object* x_208; lean_object* x_209; +lean_dec(x_151); +lean_dec(x_150); +lean_dec(x_149); lean_dec(x_2); lean_dec(x_1); -x_199 = lean_ctor_get(x_148, 0); -lean_inc(x_199); -lean_dec(x_148); -x_200 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_200, 0, x_199); -lean_ctor_set(x_200, 1, x_3); -return x_200; +x_208 = lean_ctor_get(x_154, 0); +lean_inc(x_208); +lean_dec(x_154); +x_209 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_209, 0, x_208); +lean_ctor_set(x_209, 1, x_3); +return x_209; } } case 12: { -lean_object* x_201; lean_object* x_202; lean_object* x_203; +lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_dec(x_1); -x_201 = l_Lean_Meta_isClassQuick___main___closed__1; -x_202 = l_unreachable_x21___rarg(x_201); -x_203 = lean_apply_2(x_202, x_2, x_3); -return x_203; +x_210 = l_Lean_Meta_isClassQuick___main___closed__1; +x_211 = l_unreachable_x21___rarg(x_210); +x_212 = lean_apply_2(x_211, x_2, x_3); +return x_212; } default: { -lean_object* x_204; lean_object* x_205; lean_object* x_206; -x_204 = lean_ctor_get(x_3, 2); -lean_inc(x_204); -x_205 = lean_ctor_get(x_204, 0); -lean_inc(x_205); -lean_dec(x_204); -x_206 = l_Std_PersistentHashMap_find_x3f___at___private_Lean_Meta_InferType_9__checkInferTypeCache___spec__1(x_205, x_1); -if (lean_obj_tag(x_206) == 0) -{ -lean_object* x_207; lean_object* x_208; -x_207 = l___private_Lean_Meta_InferType_5__inferLambdaType___closed__1; -lean_inc(x_1); -x_208 = l_Lean_Meta_lambdaTelescope___rarg(x_1, x_207, x_2, x_3); -if (lean_obj_tag(x_208) == 0) -{ -lean_object* x_209; lean_object* x_210; uint8_t x_211; -x_209 = lean_ctor_get(x_208, 1); -lean_inc(x_209); -x_210 = lean_ctor_get(x_209, 2); -lean_inc(x_210); -x_211 = !lean_is_exclusive(x_208); -if (x_211 == 0) -{ -lean_object* x_212; lean_object* x_213; uint8_t x_214; -x_212 = lean_ctor_get(x_208, 0); -x_213 = lean_ctor_get(x_208, 1); +lean_object* x_213; lean_object* x_214; lean_object* x_215; +x_213 = lean_ctor_get(x_3, 2); +lean_inc(x_213); +x_214 = lean_ctor_get(x_213, 0); +lean_inc(x_214); lean_dec(x_213); -x_214 = !lean_is_exclusive(x_209); -if (x_214 == 0) +x_215 = l_Std_PersistentHashMap_find_x3f___at___private_Lean_Meta_InferType_9__checkInferTypeCache___spec__1(x_214, x_1); +if (lean_obj_tag(x_215) == 0) { -lean_object* x_215; uint8_t x_216; -x_215 = lean_ctor_get(x_209, 2); -lean_dec(x_215); -x_216 = !lean_is_exclusive(x_210); -if (x_216 == 0) +lean_object* x_216; lean_object* x_217; +x_216 = l___private_Lean_Meta_InferType_5__inferLambdaType___closed__1; +lean_inc(x_1); +x_217 = l_Lean_Meta_lambdaTelescope___rarg(x_1, x_216, x_2, x_3); +if (lean_obj_tag(x_217) == 0) { -lean_object* x_217; lean_object* x_218; -x_217 = lean_ctor_get(x_210, 0); -lean_inc(x_212); -x_218 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_217, x_1, x_212); -lean_ctor_set(x_210, 0, x_218); -return x_208; -} -else -{ -lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; lean_object* x_224; -x_219 = lean_ctor_get(x_210, 0); -x_220 = lean_ctor_get(x_210, 1); -x_221 = lean_ctor_get(x_210, 2); -x_222 = lean_ctor_get(x_210, 3); -lean_inc(x_222); -lean_inc(x_221); -lean_inc(x_220); +lean_object* x_218; lean_object* x_219; uint8_t x_220; +x_218 = lean_ctor_get(x_217, 1); +lean_inc(x_218); +x_219 = lean_ctor_get(x_218, 2); lean_inc(x_219); -lean_dec(x_210); -lean_inc(x_212); -x_223 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_219, x_1, x_212); -x_224 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_224, 0, x_223); -lean_ctor_set(x_224, 1, x_220); -lean_ctor_set(x_224, 2, x_221); -lean_ctor_set(x_224, 3, x_222); -lean_ctor_set(x_209, 2, x_224); -return x_208; -} +x_220 = !lean_is_exclusive(x_217); +if (x_220 == 0) +{ +lean_object* x_221; lean_object* x_222; uint8_t x_223; +x_221 = lean_ctor_get(x_217, 0); +x_222 = lean_ctor_get(x_217, 1); +lean_dec(x_222); +x_223 = !lean_is_exclusive(x_218); +if (x_223 == 0) +{ +lean_object* x_224; uint8_t x_225; +x_224 = lean_ctor_get(x_218, 2); +lean_dec(x_224); +x_225 = !lean_is_exclusive(x_219); +if (x_225 == 0) +{ +lean_object* x_226; lean_object* x_227; +x_226 = lean_ctor_get(x_219, 0); +lean_inc(x_221); +x_227 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_226, x_1, x_221); +lean_ctor_set(x_219, 0, x_227); +return x_217; } else { -lean_object* x_225; lean_object* x_226; lean_object* x_227; lean_object* x_228; lean_object* x_229; lean_object* x_230; lean_object* x_231; lean_object* x_232; lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_object* x_236; lean_object* x_237; -x_225 = lean_ctor_get(x_209, 0); -x_226 = lean_ctor_get(x_209, 1); -x_227 = lean_ctor_get(x_209, 3); -x_228 = lean_ctor_get(x_209, 4); -x_229 = lean_ctor_get(x_209, 5); +lean_object* x_228; lean_object* x_229; lean_object* x_230; lean_object* x_231; lean_object* x_232; lean_object* x_233; lean_object* x_234; +x_228 = lean_ctor_get(x_219, 0); +x_229 = lean_ctor_get(x_219, 1); +x_230 = lean_ctor_get(x_219, 2); +x_231 = lean_ctor_get(x_219, 3); +x_232 = lean_ctor_get(x_219, 4); +lean_inc(x_232); +lean_inc(x_231); +lean_inc(x_230); lean_inc(x_229); lean_inc(x_228); -lean_inc(x_227); -lean_inc(x_226); -lean_inc(x_225); -lean_dec(x_209); -x_230 = lean_ctor_get(x_210, 0); -lean_inc(x_230); -x_231 = lean_ctor_get(x_210, 1); -lean_inc(x_231); -x_232 = lean_ctor_get(x_210, 2); -lean_inc(x_232); -x_233 = lean_ctor_get(x_210, 3); -lean_inc(x_233); -if (lean_is_exclusive(x_210)) { - lean_ctor_release(x_210, 0); - lean_ctor_release(x_210, 1); - lean_ctor_release(x_210, 2); - lean_ctor_release(x_210, 3); - x_234 = x_210; -} else { - lean_dec_ref(x_210); - x_234 = lean_box(0); -} -lean_inc(x_212); -x_235 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_230, x_1, x_212); -if (lean_is_scalar(x_234)) { - x_236 = lean_alloc_ctor(0, 4, 0); -} else { - x_236 = x_234; -} -lean_ctor_set(x_236, 0, x_235); -lean_ctor_set(x_236, 1, x_231); -lean_ctor_set(x_236, 2, x_232); -lean_ctor_set(x_236, 3, x_233); -x_237 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_237, 0, x_225); -lean_ctor_set(x_237, 1, x_226); -lean_ctor_set(x_237, 2, x_236); -lean_ctor_set(x_237, 3, x_227); -lean_ctor_set(x_237, 4, x_228); -lean_ctor_set(x_237, 5, x_229); -lean_ctor_set(x_208, 1, x_237); -return x_208; +lean_dec(x_219); +lean_inc(x_221); +x_233 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_228, x_1, x_221); +x_234 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_234, 0, x_233); +lean_ctor_set(x_234, 1, x_229); +lean_ctor_set(x_234, 2, x_230); +lean_ctor_set(x_234, 3, x_231); +lean_ctor_set(x_234, 4, x_232); +lean_ctor_set(x_218, 2, x_234); +return x_217; } } 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; lean_object* x_252; lean_object* x_253; -x_238 = lean_ctor_get(x_208, 0); -lean_inc(x_238); -lean_dec(x_208); -x_239 = lean_ctor_get(x_209, 0); +lean_object* x_235; lean_object* x_236; lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; lean_object* x_242; lean_object* x_243; lean_object* x_244; lean_object* x_245; lean_object* x_246; lean_object* x_247; lean_object* x_248; +x_235 = lean_ctor_get(x_218, 0); +x_236 = lean_ctor_get(x_218, 1); +x_237 = lean_ctor_get(x_218, 3); +x_238 = lean_ctor_get(x_218, 4); +x_239 = lean_ctor_get(x_218, 5); lean_inc(x_239); -x_240 = lean_ctor_get(x_209, 1); -lean_inc(x_240); -x_241 = lean_ctor_get(x_209, 3); -lean_inc(x_241); -x_242 = lean_ctor_get(x_209, 4); -lean_inc(x_242); -x_243 = lean_ctor_get(x_209, 5); -lean_inc(x_243); -if (lean_is_exclusive(x_209)) { - lean_ctor_release(x_209, 0); - lean_ctor_release(x_209, 1); - lean_ctor_release(x_209, 2); - lean_ctor_release(x_209, 3); - lean_ctor_release(x_209, 4); - lean_ctor_release(x_209, 5); - x_244 = x_209; -} else { - lean_dec_ref(x_209); - x_244 = lean_box(0); -} -x_245 = lean_ctor_get(x_210, 0); -lean_inc(x_245); -x_246 = lean_ctor_get(x_210, 1); -lean_inc(x_246); -x_247 = lean_ctor_get(x_210, 2); -lean_inc(x_247); -x_248 = lean_ctor_get(x_210, 3); -lean_inc(x_248); -if (lean_is_exclusive(x_210)) { - lean_ctor_release(x_210, 0); - lean_ctor_release(x_210, 1); - lean_ctor_release(x_210, 2); - lean_ctor_release(x_210, 3); - x_249 = x_210; -} else { - lean_dec_ref(x_210); - x_249 = lean_box(0); -} lean_inc(x_238); -x_250 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_245, x_1, x_238); -if (lean_is_scalar(x_249)) { - x_251 = lean_alloc_ctor(0, 4, 0); +lean_inc(x_237); +lean_inc(x_236); +lean_inc(x_235); +lean_dec(x_218); +x_240 = lean_ctor_get(x_219, 0); +lean_inc(x_240); +x_241 = lean_ctor_get(x_219, 1); +lean_inc(x_241); +x_242 = lean_ctor_get(x_219, 2); +lean_inc(x_242); +x_243 = lean_ctor_get(x_219, 3); +lean_inc(x_243); +x_244 = lean_ctor_get(x_219, 4); +lean_inc(x_244); +if (lean_is_exclusive(x_219)) { + lean_ctor_release(x_219, 0); + lean_ctor_release(x_219, 1); + lean_ctor_release(x_219, 2); + lean_ctor_release(x_219, 3); + lean_ctor_release(x_219, 4); + x_245 = x_219; } else { - x_251 = x_249; + lean_dec_ref(x_219); + x_245 = lean_box(0); } -lean_ctor_set(x_251, 0, x_250); -lean_ctor_set(x_251, 1, x_246); -lean_ctor_set(x_251, 2, x_247); -lean_ctor_set(x_251, 3, x_248); -if (lean_is_scalar(x_244)) { - x_252 = lean_alloc_ctor(0, 6, 0); +lean_inc(x_221); +x_246 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_240, x_1, x_221); +if (lean_is_scalar(x_245)) { + x_247 = lean_alloc_ctor(0, 5, 0); } else { - x_252 = x_244; + x_247 = x_245; } -lean_ctor_set(x_252, 0, x_239); -lean_ctor_set(x_252, 1, x_240); -lean_ctor_set(x_252, 2, x_251); -lean_ctor_set(x_252, 3, x_241); -lean_ctor_set(x_252, 4, x_242); -lean_ctor_set(x_252, 5, x_243); -x_253 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_253, 0, x_238); -lean_ctor_set(x_253, 1, x_252); -return x_253; +lean_ctor_set(x_247, 0, x_246); +lean_ctor_set(x_247, 1, x_241); +lean_ctor_set(x_247, 2, x_242); +lean_ctor_set(x_247, 3, x_243); +lean_ctor_set(x_247, 4, x_244); +x_248 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_248, 0, x_235); +lean_ctor_set(x_248, 1, x_236); +lean_ctor_set(x_248, 2, x_247); +lean_ctor_set(x_248, 3, x_237); +lean_ctor_set(x_248, 4, x_238); +lean_ctor_set(x_248, 5, x_239); +lean_ctor_set(x_217, 1, x_248); +return x_217; } } else { -uint8_t x_254; -lean_dec(x_1); -x_254 = !lean_is_exclusive(x_208); -if (x_254 == 0) -{ -return x_208; +lean_object* x_249; lean_object* x_250; lean_object* x_251; lean_object* x_252; lean_object* x_253; lean_object* x_254; lean_object* x_255; lean_object* x_256; lean_object* x_257; lean_object* x_258; 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; +x_249 = lean_ctor_get(x_217, 0); +lean_inc(x_249); +lean_dec(x_217); +x_250 = lean_ctor_get(x_218, 0); +lean_inc(x_250); +x_251 = lean_ctor_get(x_218, 1); +lean_inc(x_251); +x_252 = lean_ctor_get(x_218, 3); +lean_inc(x_252); +x_253 = lean_ctor_get(x_218, 4); +lean_inc(x_253); +x_254 = lean_ctor_get(x_218, 5); +lean_inc(x_254); +if (lean_is_exclusive(x_218)) { + lean_ctor_release(x_218, 0); + lean_ctor_release(x_218, 1); + lean_ctor_release(x_218, 2); + lean_ctor_release(x_218, 3); + lean_ctor_release(x_218, 4); + lean_ctor_release(x_218, 5); + x_255 = x_218; +} else { + lean_dec_ref(x_218); + x_255 = lean_box(0); } -else -{ -lean_object* x_255; lean_object* x_256; lean_object* x_257; -x_255 = lean_ctor_get(x_208, 0); -x_256 = lean_ctor_get(x_208, 1); +x_256 = lean_ctor_get(x_219, 0); lean_inc(x_256); -lean_inc(x_255); -lean_dec(x_208); -x_257 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_257, 0, x_255); -lean_ctor_set(x_257, 1, x_256); -return x_257; +x_257 = lean_ctor_get(x_219, 1); +lean_inc(x_257); +x_258 = lean_ctor_get(x_219, 2); +lean_inc(x_258); +x_259 = lean_ctor_get(x_219, 3); +lean_inc(x_259); +x_260 = lean_ctor_get(x_219, 4); +lean_inc(x_260); +if (lean_is_exclusive(x_219)) { + lean_ctor_release(x_219, 0); + lean_ctor_release(x_219, 1); + lean_ctor_release(x_219, 2); + lean_ctor_release(x_219, 3); + lean_ctor_release(x_219, 4); + x_261 = x_219; +} else { + lean_dec_ref(x_219); + x_261 = lean_box(0); +} +lean_inc(x_249); +x_262 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_256, x_1, x_249); +if (lean_is_scalar(x_261)) { + x_263 = lean_alloc_ctor(0, 5, 0); +} else { + x_263 = x_261; +} +lean_ctor_set(x_263, 0, x_262); +lean_ctor_set(x_263, 1, x_257); +lean_ctor_set(x_263, 2, x_258); +lean_ctor_set(x_263, 3, x_259); +lean_ctor_set(x_263, 4, x_260); +if (lean_is_scalar(x_255)) { + x_264 = lean_alloc_ctor(0, 6, 0); +} else { + x_264 = x_255; +} +lean_ctor_set(x_264, 0, x_250); +lean_ctor_set(x_264, 1, x_251); +lean_ctor_set(x_264, 2, x_263); +lean_ctor_set(x_264, 3, x_252); +lean_ctor_set(x_264, 4, x_253); +lean_ctor_set(x_264, 5, x_254); +x_265 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_265, 0, x_249); +lean_ctor_set(x_265, 1, x_264); +return x_265; +} +} +else +{ +uint8_t x_266; +lean_dec(x_1); +x_266 = !lean_is_exclusive(x_217); +if (x_266 == 0) +{ +return x_217; +} +else +{ +lean_object* x_267; lean_object* x_268; lean_object* x_269; +x_267 = lean_ctor_get(x_217, 0); +x_268 = lean_ctor_get(x_217, 1); +lean_inc(x_268); +lean_inc(x_267); +lean_dec(x_217); +x_269 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_269, 0, x_267); +lean_ctor_set(x_269, 1, x_268); +return x_269; } } } else { -lean_object* x_258; lean_object* x_259; +lean_object* x_270; lean_object* x_271; lean_dec(x_2); lean_dec(x_1); -x_258 = lean_ctor_get(x_206, 0); -lean_inc(x_258); -lean_dec(x_206); -x_259 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_259, 0, x_258); -lean_ctor_set(x_259, 1, x_3); -return x_259; +x_270 = lean_ctor_get(x_215, 0); +lean_inc(x_270); +lean_dec(x_215); +x_271 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_271, 0, x_270); +lean_ctor_set(x_271, 1, x_3); +return x_271; } } } diff --git a/stage0/stdlib/Lean/Meta/SynthInstance.c b/stage0/stdlib/Lean/Meta/SynthInstance.c index d0ca6bc45d..4ab79dbdd2 100644 --- a/stage0/stdlib/Lean/Meta/SynthInstance.c +++ b/stage0/stdlib/Lean/Meta/SynthInstance.c @@ -22376,7 +22376,7 @@ lean_inc(x_2); x_24 = l_Lean_Meta_forallTelescopeReducing___rarg(x_20, x_23, x_2, x_21); if (lean_obj_tag(x_24) == 0) { -lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; +lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; x_25 = lean_ctor_get(x_24, 0); lean_inc(x_25); x_26 = lean_ctor_get(x_24, 1); @@ -22389,241 +22389,241 @@ if (lean_is_exclusive(x_24)) { lean_dec_ref(x_24); x_27 = lean_box(0); } -x_61 = lean_ctor_get(x_26, 0); -lean_inc(x_61); -x_62 = lean_ctor_get(x_26, 1); -lean_inc(x_62); -x_63 = lean_ctor_get(x_26, 2); +x_63 = lean_ctor_get(x_26, 0); lean_inc(x_63); -x_64 = lean_ctor_get(x_26, 3); +x_64 = lean_ctor_get(x_26, 1); lean_inc(x_64); -x_65 = lean_ctor_get(x_26, 4); +x_65 = lean_ctor_get(x_26, 2); lean_inc(x_65); -x_66 = lean_ctor_get(x_26, 5); +x_66 = lean_ctor_get(x_26, 3); lean_inc(x_66); -x_67 = lean_ctor_get(x_63, 2); +x_67 = lean_ctor_get(x_26, 4); lean_inc(x_67); -x_68 = l_Std_PersistentHashMap_find_x3f___at_Lean_Meta_synthInstance_x3f___spec__5(x_67, x_25); -if (lean_obj_tag(x_68) == 0) +x_68 = lean_ctor_get(x_26, 5); +lean_inc(x_68); +x_69 = lean_ctor_get(x_65, 2); +lean_inc(x_69); +x_70 = l_Std_PersistentHashMap_find_x3f___at_Lean_Meta_synthInstance_x3f___spec__5(x_69, x_25); +if (lean_obj_tag(x_70) == 0) { -uint8_t x_69; -x_69 = !lean_is_exclusive(x_26); -if (x_69 == 0) +uint8_t x_71; +x_71 = !lean_is_exclusive(x_26); +if (x_71 == 0) { -lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_164; lean_object* x_165; lean_object* x_177; lean_object* x_178; -x_70 = lean_ctor_get(x_26, 5); -lean_dec(x_70); -x_71 = lean_ctor_get(x_26, 4); -lean_dec(x_71); -x_72 = lean_ctor_get(x_26, 3); +lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_166; lean_object* x_167; lean_object* x_179; lean_object* x_180; +x_72 = lean_ctor_get(x_26, 5); lean_dec(x_72); -x_73 = lean_ctor_get(x_26, 2); +x_73 = lean_ctor_get(x_26, 4); lean_dec(x_73); -x_74 = lean_ctor_get(x_26, 1); +x_74 = lean_ctor_get(x_26, 3); lean_dec(x_74); -x_75 = lean_ctor_get(x_26, 0); +x_75 = lean_ctor_get(x_26, 2); lean_dec(x_75); -lean_inc(x_62); -x_177 = l_Lean_MetavarContext_incDepth(x_62); -lean_ctor_set(x_26, 1, x_177); +x_76 = lean_ctor_get(x_26, 1); +lean_dec(x_76); +x_77 = lean_ctor_get(x_26, 0); +lean_dec(x_77); +lean_inc(x_64); +x_179 = l_Lean_MetavarContext_incDepth(x_64); +lean_ctor_set(x_26, 1, x_179); lean_inc(x_2); lean_inc(x_25); -x_178 = l___private_Lean_Meta_SynthInstance_5__preprocessOutParam(x_25, x_2, x_26); -if (lean_obj_tag(x_178) == 0) +x_180 = l___private_Lean_Meta_SynthInstance_5__preprocessOutParam(x_25, x_2, x_26); +if (lean_obj_tag(x_180) == 0) { -lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_216; uint8_t x_217; -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); -x_216 = lean_ctor_get(x_180, 4); -lean_inc(x_216); -x_217 = lean_ctor_get_uint8(x_216, sizeof(void*)*1); -lean_dec(x_216); -if (x_217 == 0) +lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_218; uint8_t x_219; +x_181 = lean_ctor_get(x_180, 0); +lean_inc(x_181); +x_182 = lean_ctor_get(x_180, 1); +lean_inc(x_182); +lean_dec(x_180); +x_218 = lean_ctor_get(x_182, 4); +lean_inc(x_218); +x_219 = lean_ctor_get_uint8(x_218, sizeof(void*)*1); +lean_dec(x_218); +if (x_219 == 0) { -x_181 = x_180; -goto block_215; +x_183 = x_182; +goto block_217; } else { -lean_object* x_218; lean_object* x_219; lean_object* x_220; uint8_t x_221; -x_218 = l_Lean_Meta_SynthInstance_getInstances___lambda__1___closed__1; -x_219 = l___private_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_218, x_2, x_180); -x_220 = lean_ctor_get(x_219, 0); -lean_inc(x_220); -x_221 = lean_unbox(x_220); -lean_dec(x_220); -if (x_221 == 0) -{ -lean_object* x_222; -x_222 = lean_ctor_get(x_219, 1); +lean_object* x_220; lean_object* x_221; lean_object* x_222; uint8_t x_223; +x_220 = l_Lean_Meta_SynthInstance_getInstances___lambda__1___closed__1; +x_221 = l___private_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_220, x_2, x_182); +x_222 = lean_ctor_get(x_221, 0); lean_inc(x_222); -lean_dec(x_219); -x_181 = x_222; -goto block_215; +x_223 = lean_unbox(x_222); +lean_dec(x_222); +if (x_223 == 0) +{ +lean_object* x_224; +x_224 = lean_ctor_get(x_221, 1); +lean_inc(x_224); +lean_dec(x_221); +x_183 = x_224; +goto block_217; } else { -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_223 = lean_ctor_get(x_219, 1); -lean_inc(x_223); -lean_dec(x_219); +lean_object* x_225; lean_object* x_226; lean_object* x_227; lean_object* x_228; lean_object* x_229; lean_object* x_230; lean_object* x_231; lean_object* x_232; +x_225 = lean_ctor_get(x_221, 1); +lean_inc(x_225); +lean_dec(x_221); lean_inc(x_25); -x_224 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_224, 0, x_25); -x_225 = l_Lean_Meta_synthInstance_x3f___closed__9; -x_226 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_226, 0, x_224); -lean_ctor_set(x_226, 1, x_225); -lean_inc(x_179); -x_227 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_227, 0, x_179); +x_226 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_226, 0, x_25); +x_227 = l_Lean_Meta_synthInstance_x3f___closed__9; x_228 = lean_alloc_ctor(9, 2, 0); lean_ctor_set(x_228, 0, x_226); lean_ctor_set(x_228, 1, x_227); -x_229 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_218, x_228, x_2, x_223); -x_230 = lean_ctor_get(x_229, 1); -lean_inc(x_230); -lean_dec(x_229); -x_181 = x_230; -goto block_215; +lean_inc(x_181); +x_229 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_229, 0, x_181); +x_230 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_230, 0, x_228); +lean_ctor_set(x_230, 1, x_229); +x_231 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_220, x_230, x_2, x_225); +x_232 = lean_ctor_get(x_231, 1); +lean_inc(x_232); +lean_dec(x_231); +x_183 = x_232; +goto block_217; } } -block_215: -{ -lean_object* x_182; -lean_inc(x_2); -x_182 = l_Lean_Meta_SynthInstance_main(x_179, x_15, x_2, x_181); -if (lean_obj_tag(x_182) == 0) -{ -lean_object* x_183; -lean_dec(x_22); -x_183 = lean_ctor_get(x_182, 0); -lean_inc(x_183); -if (lean_obj_tag(x_183) == 0) +block_217: { lean_object* x_184; -x_184 = lean_ctor_get(x_182, 1); -lean_inc(x_184); -lean_dec(x_182); -x_76 = x_183; -x_77 = x_184; -goto block_163; -} -else +lean_inc(x_2); +x_184 = l_Lean_Meta_SynthInstance_main(x_181, x_15, x_2, x_183); +if (lean_obj_tag(x_184) == 0) { -lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_200; uint8_t x_201; -x_185 = lean_ctor_get(x_182, 1); +lean_object* x_185; +lean_dec(x_22); +x_185 = lean_ctor_get(x_184, 0); lean_inc(x_185); -lean_dec(x_182); -x_186 = lean_ctor_get(x_183, 0); -lean_inc(x_186); -if (lean_is_exclusive(x_183)) { - lean_ctor_release(x_183, 0); - x_187 = x_183; -} else { - lean_dec_ref(x_183); - x_187 = lean_box(0); -} -x_200 = lean_ctor_get(x_185, 4); -lean_inc(x_200); -x_201 = lean_ctor_get_uint8(x_200, sizeof(void*)*1); -lean_dec(x_200); -if (x_201 == 0) +if (lean_obj_tag(x_185) == 0) { -x_188 = x_185; -goto block_199; +lean_object* x_186; +x_186 = lean_ctor_get(x_184, 1); +lean_inc(x_186); +lean_dec(x_184); +x_78 = x_185; +x_79 = x_186; +goto block_165; } else { -lean_object* x_202; lean_object* x_203; lean_object* x_204; uint8_t x_205; -x_202 = l_Lean_Meta_SynthInstance_getInstances___lambda__1___closed__1; -x_203 = l___private_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_202, x_2, x_185); -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_object* x_202; uint8_t x_203; +x_187 = lean_ctor_get(x_184, 1); +lean_inc(x_187); +lean_dec(x_184); +x_188 = lean_ctor_get(x_185, 0); +lean_inc(x_188); +if (lean_is_exclusive(x_185)) { + lean_ctor_release(x_185, 0); + x_189 = x_185; +} else { + lean_dec_ref(x_185); + x_189 = lean_box(0); +} +x_202 = lean_ctor_get(x_187, 4); +lean_inc(x_202); +x_203 = lean_ctor_get_uint8(x_202, sizeof(void*)*1); +lean_dec(x_202); +if (x_203 == 0) { -lean_object* x_206; -x_206 = lean_ctor_get(x_203, 1); +x_190 = x_187; +goto block_201; +} +else +{ +lean_object* x_204; lean_object* x_205; lean_object* x_206; uint8_t x_207; +x_204 = l_Lean_Meta_SynthInstance_getInstances___lambda__1___closed__1; +x_205 = l___private_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_204, x_2, x_187); +x_206 = lean_ctor_get(x_205, 0); lean_inc(x_206); -lean_dec(x_203); -x_188 = x_206; -goto block_199; +x_207 = lean_unbox(x_206); +lean_dec(x_206); +if (x_207 == 0) +{ +lean_object* x_208; +x_208 = lean_ctor_get(x_205, 1); +lean_inc(x_208); +lean_dec(x_205); +x_190 = x_208; +goto block_201; } else { -lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; -x_207 = lean_ctor_get(x_203, 1); -lean_inc(x_207); -lean_dec(x_203); -lean_inc(x_186); -x_208 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_208, 0, x_186); -x_209 = l_Lean_Meta_synthInstance_x3f___closed__6; -x_210 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_210, 0, x_209); -lean_ctor_set(x_210, 1, x_208); -x_211 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_202, x_210, x_2, x_207); -x_212 = lean_ctor_get(x_211, 1); -lean_inc(x_212); -lean_dec(x_211); -x_188 = x_212; -goto block_199; +lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; +x_209 = lean_ctor_get(x_205, 1); +lean_inc(x_209); +lean_dec(x_205); +lean_inc(x_188); +x_210 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_210, 0, x_188); +x_211 = l_Lean_Meta_synthInstance_x3f___closed__6; +x_212 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_212, 0, x_211); +lean_ctor_set(x_212, 1, x_210); +x_213 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_204, x_212, x_2, x_209); +x_214 = lean_ctor_get(x_213, 1); +lean_inc(x_214); +lean_dec(x_213); +x_190 = x_214; +goto block_201; } } -block_199: +block_201: { -lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; uint8_t x_194; -x_189 = l_Lean_Meta_instantiateMVars(x_186, x_2, x_188); -x_190 = lean_ctor_get(x_189, 0); -lean_inc(x_190); -x_191 = lean_ctor_get(x_189, 1); -lean_inc(x_191); -lean_dec(x_189); -x_192 = l_Lean_Meta_hasAssignableMVar(x_190, x_2, x_191); -x_193 = lean_ctor_get(x_192, 0); +lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; uint8_t x_196; +x_191 = l_Lean_Meta_instantiateMVars(x_188, x_2, x_190); +x_192 = lean_ctor_get(x_191, 0); +lean_inc(x_192); +x_193 = lean_ctor_get(x_191, 1); lean_inc(x_193); -x_194 = lean_unbox(x_193); -lean_dec(x_193); -if (x_194 == 0) -{ -lean_object* x_195; lean_object* x_196; -x_195 = lean_ctor_get(x_192, 1); +lean_dec(x_191); +x_194 = l_Lean_Meta_hasAssignableMVar(x_192, x_2, x_193); +x_195 = lean_ctor_get(x_194, 0); lean_inc(x_195); -lean_dec(x_192); -if (lean_is_scalar(x_187)) { - x_196 = lean_alloc_ctor(1, 1, 0); -} else { - x_196 = x_187; -} -lean_ctor_set(x_196, 0, x_190); -x_76 = x_196; -x_77 = x_195; -goto block_163; -} -else +x_196 = lean_unbox(x_195); +lean_dec(x_195); +if (x_196 == 0) { lean_object* x_197; lean_object* x_198; -lean_dec(x_190); -lean_dec(x_187); -x_197 = lean_ctor_get(x_192, 1); +x_197 = lean_ctor_get(x_194, 1); lean_inc(x_197); +lean_dec(x_194); +if (lean_is_scalar(x_189)) { + x_198 = lean_alloc_ctor(1, 1, 0); +} else { + x_198 = x_189; +} +lean_ctor_set(x_198, 0, x_192); +x_78 = x_198; +x_79 = x_197; +goto block_165; +} +else +{ +lean_object* x_199; lean_object* x_200; lean_dec(x_192); -x_198 = lean_box(0); -x_76 = x_198; -x_77 = x_197; -goto block_163; +lean_dec(x_189); +x_199 = lean_ctor_get(x_194, 1); +lean_inc(x_199); +lean_dec(x_194); +x_200 = lean_box(0); +x_78 = x_200; +x_79 = x_199; +goto block_165; } } } } else { -lean_object* x_213; lean_object* x_214; +lean_object* x_215; lean_object* x_216; lean_dec(x_27); lean_dec(x_25); lean_dec(x_2); @@ -22632,20 +22632,20 @@ lean_dec(x_8); lean_dec(x_7); lean_dec(x_6); lean_dec(x_5); -x_213 = lean_ctor_get(x_182, 0); -lean_inc(x_213); -x_214 = lean_ctor_get(x_182, 1); -lean_inc(x_214); -lean_dec(x_182); -x_164 = x_213; -x_165 = x_214; -goto block_176; +x_215 = lean_ctor_get(x_184, 0); +lean_inc(x_215); +x_216 = lean_ctor_get(x_184, 1); +lean_inc(x_216); +lean_dec(x_184); +x_166 = x_215; +x_167 = x_216; +goto block_178; } } } else { -lean_object* x_231; lean_object* x_232; +lean_object* x_233; lean_object* x_234; lean_dec(x_27); lean_dec(x_25); lean_dec(x_2); @@ -22655,198 +22655,198 @@ lean_dec(x_8); lean_dec(x_7); lean_dec(x_6); lean_dec(x_5); -x_231 = lean_ctor_get(x_178, 0); -lean_inc(x_231); -x_232 = lean_ctor_get(x_178, 1); -lean_inc(x_232); -lean_dec(x_178); -x_164 = x_231; -x_165 = x_232; -goto block_176; +x_233 = lean_ctor_get(x_180, 0); +lean_inc(x_233); +x_234 = lean_ctor_get(x_180, 1); +lean_inc(x_234); +lean_dec(x_180); +x_166 = x_233; +x_167 = x_234; +goto block_178; } -block_163: +block_165: { -uint8_t x_78; -x_78 = !lean_is_exclusive(x_77); -if (x_78 == 0) +uint8_t x_80; +x_80 = !lean_is_exclusive(x_79); +if (x_80 == 0) { -lean_object* x_79; lean_object* x_80; -x_79 = lean_ctor_get(x_77, 4); -x_80 = lean_ctor_get(x_77, 1); -lean_dec(x_80); -lean_inc(x_79); -lean_ctor_set(x_77, 1, x_62); -if (lean_obj_tag(x_76) == 0) +lean_object* x_81; lean_object* x_82; +x_81 = lean_ctor_get(x_79, 4); +x_82 = lean_ctor_get(x_79, 1); +lean_dec(x_82); +lean_inc(x_81); +lean_ctor_set(x_79, 1, x_64); +if (lean_obj_tag(x_78) == 0) { -lean_dec(x_79); +lean_dec(x_81); lean_dec(x_2); lean_dec(x_9); lean_dec(x_8); lean_dec(x_7); lean_dec(x_6); lean_dec(x_5); -x_28 = x_76; -x_29 = x_77; -goto block_60; +x_28 = x_78; +x_29 = x_79; +goto block_62; } else { -lean_object* x_81; lean_object* x_82; lean_object* x_83; uint8_t x_107; -x_81 = lean_ctor_get(x_76, 0); -lean_inc(x_81); -if (lean_is_exclusive(x_76)) { - lean_ctor_release(x_76, 0); - x_82 = x_76; +lean_object* x_83; lean_object* x_84; lean_object* x_85; uint8_t x_109; +x_83 = lean_ctor_get(x_78, 0); +lean_inc(x_83); +if (lean_is_exclusive(x_78)) { + lean_ctor_release(x_78, 0); + x_84 = x_78; } else { - lean_dec_ref(x_76); - x_82 = lean_box(0); + lean_dec_ref(x_78); + x_84 = lean_box(0); } -x_107 = lean_ctor_get_uint8(x_79, sizeof(void*)*1); -lean_dec(x_79); -if (x_107 == 0) +x_109 = lean_ctor_get_uint8(x_81, sizeof(void*)*1); +lean_dec(x_81); +if (x_109 == 0) { -x_83 = x_77; -goto block_106; +x_85 = x_79; +goto block_108; } else { -lean_object* x_108; lean_object* x_109; lean_object* x_110; uint8_t x_111; -x_108 = l_Lean_Meta_SynthInstance_getInstances___lambda__1___closed__1; -x_109 = l___private_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_108, x_2, x_77); -x_110 = lean_ctor_get(x_109, 0); -lean_inc(x_110); -x_111 = lean_unbox(x_110); -lean_dec(x_110); -if (x_111 == 0) -{ -lean_object* x_112; -x_112 = lean_ctor_get(x_109, 1); +lean_object* x_110; lean_object* x_111; lean_object* x_112; uint8_t x_113; +x_110 = l_Lean_Meta_SynthInstance_getInstances___lambda__1___closed__1; +x_111 = l___private_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_110, x_2, x_79); +x_112 = lean_ctor_get(x_111, 0); lean_inc(x_112); -lean_dec(x_109); -x_83 = x_112; -goto block_106; +x_113 = lean_unbox(x_112); +lean_dec(x_112); +if (x_113 == 0) +{ +lean_object* x_114; +x_114 = lean_ctor_get(x_111, 1); +lean_inc(x_114); +lean_dec(x_111); +x_85 = x_114; +goto block_108; } else { -lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; -x_113 = lean_ctor_get(x_109, 1); -lean_inc(x_113); -lean_dec(x_109); -lean_inc(x_81); -x_114 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_114, 0, x_81); -x_115 = l_Lean_Meta_synthInstance_x3f___closed__3; -x_116 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_116, 0, x_115); -lean_ctor_set(x_116, 1, x_114); -x_117 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_108, x_116, x_2, x_113); -x_118 = lean_ctor_get(x_117, 1); -lean_inc(x_118); -lean_dec(x_117); -x_83 = x_118; -goto block_106; +lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; +x_115 = lean_ctor_get(x_111, 1); +lean_inc(x_115); +lean_dec(x_111); +lean_inc(x_83); +x_116 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_116, 0, x_83); +x_117 = l_Lean_Meta_synthInstance_x3f___closed__3; +x_118 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_118, 0, x_117); +lean_ctor_set(x_118, 1, x_116); +x_119 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_110, x_118, x_2, x_115); +x_120 = lean_ctor_get(x_119, 1); +lean_inc(x_120); +lean_dec(x_119); +x_85 = x_120; +goto block_108; } } -block_106: +block_108: { -lean_object* x_84; +lean_object* x_86; lean_inc(x_2); -lean_inc(x_81); -x_84 = l_Lean_Meta_inferType(x_81, x_2, x_83); -if (lean_obj_tag(x_84) == 0) +lean_inc(x_83); +x_86 = l_Lean_Meta_inferType(x_83, x_2, x_85); +if (lean_obj_tag(x_86) == 0) { -lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; -x_85 = lean_ctor_get(x_84, 0); -lean_inc(x_85); -x_86 = lean_ctor_get(x_84, 1); -lean_inc(x_86); -lean_dec(x_84); -x_87 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_87, 0, x_5); -lean_ctor_set(x_87, 1, x_6); -lean_ctor_set(x_87, 2, x_7); -lean_ctor_set(x_87, 3, x_8); -lean_ctor_set(x_87, 4, x_9); +lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; +x_87 = lean_ctor_get(x_86, 0); +lean_inc(x_87); +x_88 = lean_ctor_get(x_86, 1); +lean_inc(x_88); +lean_dec(x_86); +x_89 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_89, 0, x_5); +lean_ctor_set(x_89, 1, x_6); +lean_ctor_set(x_89, 2, x_7); +lean_ctor_set(x_89, 3, x_8); +lean_ctor_set(x_89, 4, x_9); lean_inc(x_25); -x_88 = l_Lean_Meta_isExprDefEq(x_25, x_85, x_87, x_86); -if (lean_obj_tag(x_88) == 0) +x_90 = l_Lean_Meta_isExprDefEq(x_25, x_87, x_89, x_88); +if (lean_obj_tag(x_90) == 0) { -lean_object* x_89; uint8_t x_90; -x_89 = lean_ctor_get(x_88, 0); -lean_inc(x_89); -x_90 = lean_unbox(x_89); -lean_dec(x_89); -if (x_90 == 0) -{ -lean_object* x_91; lean_object* x_92; -lean_dec(x_82); -lean_dec(x_81); -lean_dec(x_2); -x_91 = lean_ctor_get(x_88, 1); +lean_object* x_91; uint8_t x_92; +x_91 = lean_ctor_get(x_90, 0); lean_inc(x_91); -lean_dec(x_88); -x_92 = lean_box(0); -x_28 = x_92; -x_29 = x_91; -goto block_60; -} -else +x_92 = lean_unbox(x_91); +lean_dec(x_91); +if (x_92 == 0) { -lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; -x_93 = lean_ctor_get(x_88, 1); -lean_inc(x_93); -lean_dec(x_88); -x_94 = l_Lean_Meta_instantiateMVars(x_81, x_2, x_93); +lean_object* x_93; lean_object* x_94; +lean_dec(x_84); +lean_dec(x_83); lean_dec(x_2); -x_95 = lean_ctor_get(x_94, 0); -lean_inc(x_95); -x_96 = lean_ctor_get(x_94, 1); -lean_inc(x_96); -lean_dec(x_94); -if (lean_is_scalar(x_82)) { - x_97 = lean_alloc_ctor(1, 1, 0); -} else { - x_97 = x_82; +x_93 = lean_ctor_get(x_90, 1); +lean_inc(x_93); +lean_dec(x_90); +x_94 = lean_box(0); +x_28 = x_94; +x_29 = x_93; +goto block_62; } -lean_ctor_set(x_97, 0, x_95); -x_28 = x_97; -x_29 = x_96; -goto block_60; +else +{ +lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; +x_95 = lean_ctor_get(x_90, 1); +lean_inc(x_95); +lean_dec(x_90); +x_96 = l_Lean_Meta_instantiateMVars(x_83, x_2, x_95); +lean_dec(x_2); +x_97 = lean_ctor_get(x_96, 0); +lean_inc(x_97); +x_98 = lean_ctor_get(x_96, 1); +lean_inc(x_98); +lean_dec(x_96); +if (lean_is_scalar(x_84)) { + x_99 = lean_alloc_ctor(1, 1, 0); +} else { + x_99 = x_84; +} +lean_ctor_set(x_99, 0, x_97); +x_28 = x_99; +x_29 = x_98; +goto block_62; } } else { -uint8_t x_98; -lean_dec(x_82); -lean_dec(x_81); +uint8_t x_100; +lean_dec(x_84); +lean_dec(x_83); lean_dec(x_27); lean_dec(x_25); lean_dec(x_2); -x_98 = !lean_is_exclusive(x_88); -if (x_98 == 0) +x_100 = !lean_is_exclusive(x_90); +if (x_100 == 0) { -return x_88; +return x_90; } else { -lean_object* x_99; lean_object* x_100; lean_object* x_101; -x_99 = lean_ctor_get(x_88, 0); -x_100 = lean_ctor_get(x_88, 1); -lean_inc(x_100); -lean_inc(x_99); -lean_dec(x_88); -x_101 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_101, 0, x_99); -lean_ctor_set(x_101, 1, x_100); -return x_101; +lean_object* x_101; lean_object* x_102; lean_object* x_103; +x_101 = lean_ctor_get(x_90, 0); +x_102 = lean_ctor_get(x_90, 1); +lean_inc(x_102); +lean_inc(x_101); +lean_dec(x_90); +x_103 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_103, 0, x_101); +lean_ctor_set(x_103, 1, x_102); +return x_103; } } } else { -uint8_t x_102; -lean_dec(x_82); -lean_dec(x_81); +uint8_t x_104; +lean_dec(x_84); +lean_dec(x_83); lean_dec(x_27); lean_dec(x_25); lean_dec(x_2); @@ -22855,23 +22855,23 @@ lean_dec(x_8); lean_dec(x_7); lean_dec(x_6); lean_dec(x_5); -x_102 = !lean_is_exclusive(x_84); -if (x_102 == 0) +x_104 = !lean_is_exclusive(x_86); +if (x_104 == 0) { -return x_84; +return x_86; } else { -lean_object* x_103; lean_object* x_104; lean_object* x_105; -x_103 = lean_ctor_get(x_84, 0); -x_104 = lean_ctor_get(x_84, 1); -lean_inc(x_104); -lean_inc(x_103); -lean_dec(x_84); -x_105 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_105, 0, x_103); -lean_ctor_set(x_105, 1, x_104); -return x_105; +lean_object* x_105; lean_object* x_106; lean_object* x_107; +x_105 = lean_ctor_get(x_86, 0); +x_106 = lean_ctor_get(x_86, 1); +lean_inc(x_106); +lean_inc(x_105); +lean_dec(x_86); +x_107 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_107, 0, x_105); +lean_ctor_set(x_107, 1, x_106); +return x_107; } } } @@ -22879,199 +22879,199 @@ return x_105; } else { -lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; -x_119 = lean_ctor_get(x_77, 0); -x_120 = lean_ctor_get(x_77, 2); -x_121 = lean_ctor_get(x_77, 3); -x_122 = lean_ctor_get(x_77, 4); -x_123 = lean_ctor_get(x_77, 5); +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_79, 0); +x_122 = lean_ctor_get(x_79, 2); +x_123 = lean_ctor_get(x_79, 3); +x_124 = lean_ctor_get(x_79, 4); +x_125 = lean_ctor_get(x_79, 5); +lean_inc(x_125); +lean_inc(x_124); lean_inc(x_123); lean_inc(x_122); lean_inc(x_121); -lean_inc(x_120); -lean_inc(x_119); -lean_dec(x_77); -lean_inc(x_122); -x_124 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_124, 0, x_119); -lean_ctor_set(x_124, 1, x_62); -lean_ctor_set(x_124, 2, x_120); -lean_ctor_set(x_124, 3, x_121); -lean_ctor_set(x_124, 4, x_122); -lean_ctor_set(x_124, 5, x_123); -if (lean_obj_tag(x_76) == 0) +lean_dec(x_79); +lean_inc(x_124); +x_126 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_126, 0, x_121); +lean_ctor_set(x_126, 1, x_64); +lean_ctor_set(x_126, 2, x_122); +lean_ctor_set(x_126, 3, x_123); +lean_ctor_set(x_126, 4, x_124); +lean_ctor_set(x_126, 5, x_125); +if (lean_obj_tag(x_78) == 0) { -lean_dec(x_122); +lean_dec(x_124); lean_dec(x_2); lean_dec(x_9); lean_dec(x_8); lean_dec(x_7); lean_dec(x_6); lean_dec(x_5); -x_28 = x_76; -x_29 = x_124; -goto block_60; +x_28 = x_78; +x_29 = x_126; +goto block_62; } else { -lean_object* x_125; lean_object* x_126; lean_object* x_127; uint8_t x_151; -x_125 = lean_ctor_get(x_76, 0); -lean_inc(x_125); -if (lean_is_exclusive(x_76)) { - lean_ctor_release(x_76, 0); - x_126 = x_76; +lean_object* x_127; lean_object* x_128; lean_object* x_129; uint8_t x_153; +x_127 = lean_ctor_get(x_78, 0); +lean_inc(x_127); +if (lean_is_exclusive(x_78)) { + lean_ctor_release(x_78, 0); + x_128 = x_78; } else { - lean_dec_ref(x_76); - x_126 = lean_box(0); + lean_dec_ref(x_78); + x_128 = lean_box(0); } -x_151 = lean_ctor_get_uint8(x_122, sizeof(void*)*1); -lean_dec(x_122); -if (x_151 == 0) +x_153 = lean_ctor_get_uint8(x_124, sizeof(void*)*1); +lean_dec(x_124); +if (x_153 == 0) { -x_127 = x_124; -goto block_150; +x_129 = x_126; +goto block_152; } else { -lean_object* x_152; lean_object* x_153; lean_object* x_154; uint8_t x_155; -x_152 = l_Lean_Meta_SynthInstance_getInstances___lambda__1___closed__1; -x_153 = l___private_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_152, x_2, x_124); -x_154 = lean_ctor_get(x_153, 0); -lean_inc(x_154); -x_155 = lean_unbox(x_154); -lean_dec(x_154); -if (x_155 == 0) -{ -lean_object* x_156; -x_156 = lean_ctor_get(x_153, 1); +lean_object* x_154; lean_object* x_155; lean_object* x_156; uint8_t x_157; +x_154 = l_Lean_Meta_SynthInstance_getInstances___lambda__1___closed__1; +x_155 = l___private_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_154, x_2, x_126); +x_156 = lean_ctor_get(x_155, 0); lean_inc(x_156); -lean_dec(x_153); -x_127 = x_156; -goto block_150; +x_157 = lean_unbox(x_156); +lean_dec(x_156); +if (x_157 == 0) +{ +lean_object* x_158; +x_158 = lean_ctor_get(x_155, 1); +lean_inc(x_158); +lean_dec(x_155); +x_129 = x_158; +goto block_152; } else { -lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; -x_157 = lean_ctor_get(x_153, 1); -lean_inc(x_157); -lean_dec(x_153); -lean_inc(x_125); -x_158 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_158, 0, x_125); -x_159 = l_Lean_Meta_synthInstance_x3f___closed__3; -x_160 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_160, 0, x_159); -lean_ctor_set(x_160, 1, x_158); -x_161 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_152, x_160, x_2, x_157); -x_162 = lean_ctor_get(x_161, 1); -lean_inc(x_162); -lean_dec(x_161); -x_127 = x_162; -goto block_150; +lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; +x_159 = lean_ctor_get(x_155, 1); +lean_inc(x_159); +lean_dec(x_155); +lean_inc(x_127); +x_160 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_160, 0, x_127); +x_161 = l_Lean_Meta_synthInstance_x3f___closed__3; +x_162 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_162, 0, x_161); +lean_ctor_set(x_162, 1, x_160); +x_163 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_154, x_162, x_2, x_159); +x_164 = lean_ctor_get(x_163, 1); +lean_inc(x_164); +lean_dec(x_163); +x_129 = x_164; +goto block_152; } } -block_150: +block_152: { -lean_object* x_128; +lean_object* x_130; lean_inc(x_2); -lean_inc(x_125); -x_128 = l_Lean_Meta_inferType(x_125, x_2, x_127); -if (lean_obj_tag(x_128) == 0) +lean_inc(x_127); +x_130 = l_Lean_Meta_inferType(x_127, x_2, x_129); +if (lean_obj_tag(x_130) == 0) { -lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; -x_129 = lean_ctor_get(x_128, 0); -lean_inc(x_129); -x_130 = lean_ctor_get(x_128, 1); -lean_inc(x_130); -lean_dec(x_128); -x_131 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_131, 0, x_5); -lean_ctor_set(x_131, 1, x_6); -lean_ctor_set(x_131, 2, x_7); -lean_ctor_set(x_131, 3, x_8); -lean_ctor_set(x_131, 4, x_9); +lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; +x_131 = lean_ctor_get(x_130, 0); +lean_inc(x_131); +x_132 = lean_ctor_get(x_130, 1); +lean_inc(x_132); +lean_dec(x_130); +x_133 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_133, 0, x_5); +lean_ctor_set(x_133, 1, x_6); +lean_ctor_set(x_133, 2, x_7); +lean_ctor_set(x_133, 3, x_8); +lean_ctor_set(x_133, 4, x_9); lean_inc(x_25); -x_132 = l_Lean_Meta_isExprDefEq(x_25, x_129, x_131, x_130); -if (lean_obj_tag(x_132) == 0) +x_134 = l_Lean_Meta_isExprDefEq(x_25, x_131, x_133, x_132); +if (lean_obj_tag(x_134) == 0) { -lean_object* x_133; uint8_t x_134; -x_133 = lean_ctor_get(x_132, 0); -lean_inc(x_133); -x_134 = lean_unbox(x_133); -lean_dec(x_133); -if (x_134 == 0) -{ -lean_object* x_135; lean_object* x_136; -lean_dec(x_126); -lean_dec(x_125); -lean_dec(x_2); -x_135 = lean_ctor_get(x_132, 1); +lean_object* x_135; uint8_t x_136; +x_135 = lean_ctor_get(x_134, 0); lean_inc(x_135); -lean_dec(x_132); -x_136 = lean_box(0); -x_28 = x_136; -x_29 = x_135; -goto block_60; -} -else +x_136 = lean_unbox(x_135); +lean_dec(x_135); +if (x_136 == 0) { -lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; -x_137 = lean_ctor_get(x_132, 1); -lean_inc(x_137); -lean_dec(x_132); -x_138 = l_Lean_Meta_instantiateMVars(x_125, x_2, x_137); +lean_object* x_137; lean_object* x_138; +lean_dec(x_128); +lean_dec(x_127); lean_dec(x_2); -x_139 = lean_ctor_get(x_138, 0); -lean_inc(x_139); -x_140 = lean_ctor_get(x_138, 1); -lean_inc(x_140); -lean_dec(x_138); -if (lean_is_scalar(x_126)) { - x_141 = lean_alloc_ctor(1, 1, 0); -} else { - x_141 = x_126; +x_137 = lean_ctor_get(x_134, 1); +lean_inc(x_137); +lean_dec(x_134); +x_138 = lean_box(0); +x_28 = x_138; +x_29 = x_137; +goto block_62; } -lean_ctor_set(x_141, 0, x_139); -x_28 = x_141; -x_29 = x_140; -goto block_60; +else +{ +lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; +x_139 = lean_ctor_get(x_134, 1); +lean_inc(x_139); +lean_dec(x_134); +x_140 = l_Lean_Meta_instantiateMVars(x_127, x_2, x_139); +lean_dec(x_2); +x_141 = lean_ctor_get(x_140, 0); +lean_inc(x_141); +x_142 = lean_ctor_get(x_140, 1); +lean_inc(x_142); +lean_dec(x_140); +if (lean_is_scalar(x_128)) { + x_143 = lean_alloc_ctor(1, 1, 0); +} else { + x_143 = x_128; +} +lean_ctor_set(x_143, 0, x_141); +x_28 = x_143; +x_29 = x_142; +goto block_62; } } else { -lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; -lean_dec(x_126); -lean_dec(x_125); +lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; +lean_dec(x_128); +lean_dec(x_127); lean_dec(x_27); lean_dec(x_25); lean_dec(x_2); -x_142 = lean_ctor_get(x_132, 0); -lean_inc(x_142); -x_143 = lean_ctor_get(x_132, 1); -lean_inc(x_143); -if (lean_is_exclusive(x_132)) { - lean_ctor_release(x_132, 0); - lean_ctor_release(x_132, 1); - x_144 = x_132; +x_144 = lean_ctor_get(x_134, 0); +lean_inc(x_144); +x_145 = lean_ctor_get(x_134, 1); +lean_inc(x_145); +if (lean_is_exclusive(x_134)) { + lean_ctor_release(x_134, 0); + lean_ctor_release(x_134, 1); + x_146 = x_134; } else { - lean_dec_ref(x_132); - x_144 = lean_box(0); + lean_dec_ref(x_134); + x_146 = lean_box(0); } -if (lean_is_scalar(x_144)) { - x_145 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_146)) { + x_147 = lean_alloc_ctor(1, 2, 0); } else { - x_145 = x_144; + x_147 = x_146; } -lean_ctor_set(x_145, 0, x_142); -lean_ctor_set(x_145, 1, x_143); -return x_145; +lean_ctor_set(x_147, 0, x_144); +lean_ctor_set(x_147, 1, x_145); +return x_147; } } else { -lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; -lean_dec(x_126); -lean_dec(x_125); +lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; +lean_dec(x_128); +lean_dec(x_127); lean_dec(x_27); lean_dec(x_25); lean_dec(x_2); @@ -23080,295 +23080,295 @@ lean_dec(x_8); lean_dec(x_7); lean_dec(x_6); lean_dec(x_5); -x_146 = lean_ctor_get(x_128, 0); -lean_inc(x_146); -x_147 = lean_ctor_get(x_128, 1); -lean_inc(x_147); -if (lean_is_exclusive(x_128)) { - lean_ctor_release(x_128, 0); - lean_ctor_release(x_128, 1); - x_148 = x_128; +x_148 = lean_ctor_get(x_130, 0); +lean_inc(x_148); +x_149 = lean_ctor_get(x_130, 1); +lean_inc(x_149); +if (lean_is_exclusive(x_130)) { + lean_ctor_release(x_130, 0); + lean_ctor_release(x_130, 1); + x_150 = x_130; } else { - lean_dec_ref(x_128); - x_148 = lean_box(0); + lean_dec_ref(x_130); + x_150 = lean_box(0); } -if (lean_is_scalar(x_148)) { - x_149 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_150)) { + x_151 = lean_alloc_ctor(1, 2, 0); } else { - x_149 = x_148; + x_151 = x_150; } -lean_ctor_set(x_149, 0, x_146); -lean_ctor_set(x_149, 1, x_147); -return x_149; +lean_ctor_set(x_151, 0, x_148); +lean_ctor_set(x_151, 1, x_149); +return x_151; } } } } } -block_176: +block_178: { -uint8_t x_166; -x_166 = !lean_is_exclusive(x_165); -if (x_166 == 0) +uint8_t x_168; +x_168 = !lean_is_exclusive(x_167); +if (x_168 == 0) { -lean_object* x_167; lean_object* x_168; -x_167 = lean_ctor_get(x_165, 1); -lean_dec(x_167); -lean_ctor_set(x_165, 1, x_62); +lean_object* x_169; lean_object* x_170; +x_169 = lean_ctor_get(x_167, 1); +lean_dec(x_169); +lean_ctor_set(x_167, 1, x_64); if (lean_is_scalar(x_22)) { - x_168 = lean_alloc_ctor(1, 2, 0); + x_170 = lean_alloc_ctor(1, 2, 0); } else { - x_168 = x_22; - lean_ctor_set_tag(x_168, 1); + x_170 = x_22; + lean_ctor_set_tag(x_170, 1); } -lean_ctor_set(x_168, 0, x_164); -lean_ctor_set(x_168, 1, x_165); -return x_168; +lean_ctor_set(x_170, 0, x_166); +lean_ctor_set(x_170, 1, x_167); +return x_170; } else { -lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; lean_object* x_173; lean_object* x_174; lean_object* x_175; -x_169 = lean_ctor_get(x_165, 0); -x_170 = lean_ctor_get(x_165, 2); -x_171 = lean_ctor_get(x_165, 3); -x_172 = lean_ctor_get(x_165, 4); -x_173 = lean_ctor_get(x_165, 5); +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; +x_171 = lean_ctor_get(x_167, 0); +x_172 = lean_ctor_get(x_167, 2); +x_173 = lean_ctor_get(x_167, 3); +x_174 = lean_ctor_get(x_167, 4); +x_175 = lean_ctor_get(x_167, 5); +lean_inc(x_175); +lean_inc(x_174); lean_inc(x_173); lean_inc(x_172); lean_inc(x_171); -lean_inc(x_170); -lean_inc(x_169); -lean_dec(x_165); -x_174 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_174, 0, x_169); -lean_ctor_set(x_174, 1, x_62); -lean_ctor_set(x_174, 2, x_170); -lean_ctor_set(x_174, 3, x_171); -lean_ctor_set(x_174, 4, x_172); -lean_ctor_set(x_174, 5, x_173); +lean_dec(x_167); +x_176 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_176, 0, x_171); +lean_ctor_set(x_176, 1, x_64); +lean_ctor_set(x_176, 2, x_172); +lean_ctor_set(x_176, 3, x_173); +lean_ctor_set(x_176, 4, x_174); +lean_ctor_set(x_176, 5, x_175); if (lean_is_scalar(x_22)) { - x_175 = lean_alloc_ctor(1, 2, 0); + x_177 = lean_alloc_ctor(1, 2, 0); } else { - x_175 = x_22; - lean_ctor_set_tag(x_175, 1); + x_177 = x_22; + lean_ctor_set_tag(x_177, 1); } -lean_ctor_set(x_175, 0, x_164); -lean_ctor_set(x_175, 1, x_174); -return x_175; +lean_ctor_set(x_177, 0, x_166); +lean_ctor_set(x_177, 1, x_176); +return x_177; } } } else { -lean_object* x_233; lean_object* x_234; lean_object* x_281; lean_object* x_282; lean_object* x_292; lean_object* x_293; lean_object* x_294; +lean_object* x_235; lean_object* x_236; lean_object* x_283; lean_object* x_284; lean_object* x_294; lean_object* x_295; lean_object* x_296; lean_dec(x_26); -lean_inc(x_62); -x_292 = l_Lean_MetavarContext_incDepth(x_62); -x_293 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_293, 0, x_61); -lean_ctor_set(x_293, 1, x_292); -lean_ctor_set(x_293, 2, x_63); -lean_ctor_set(x_293, 3, x_64); -lean_ctor_set(x_293, 4, x_65); -lean_ctor_set(x_293, 5, x_66); +lean_inc(x_64); +x_294 = l_Lean_MetavarContext_incDepth(x_64); +x_295 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_295, 0, x_63); +lean_ctor_set(x_295, 1, x_294); +lean_ctor_set(x_295, 2, x_65); +lean_ctor_set(x_295, 3, x_66); +lean_ctor_set(x_295, 4, x_67); +lean_ctor_set(x_295, 5, x_68); lean_inc(x_2); lean_inc(x_25); -x_294 = l___private_Lean_Meta_SynthInstance_5__preprocessOutParam(x_25, x_2, x_293); -if (lean_obj_tag(x_294) == 0) +x_296 = l___private_Lean_Meta_SynthInstance_5__preprocessOutParam(x_25, x_2, x_295); +if (lean_obj_tag(x_296) == 0) { -lean_object* x_295; lean_object* x_296; lean_object* x_297; lean_object* x_332; uint8_t x_333; -x_295 = lean_ctor_get(x_294, 0); -lean_inc(x_295); -x_296 = lean_ctor_get(x_294, 1); -lean_inc(x_296); -lean_dec(x_294); -x_332 = lean_ctor_get(x_296, 4); -lean_inc(x_332); -x_333 = lean_ctor_get_uint8(x_332, sizeof(void*)*1); -lean_dec(x_332); -if (x_333 == 0) +lean_object* x_297; lean_object* x_298; lean_object* x_299; lean_object* x_334; uint8_t x_335; +x_297 = lean_ctor_get(x_296, 0); +lean_inc(x_297); +x_298 = lean_ctor_get(x_296, 1); +lean_inc(x_298); +lean_dec(x_296); +x_334 = lean_ctor_get(x_298, 4); +lean_inc(x_334); +x_335 = lean_ctor_get_uint8(x_334, sizeof(void*)*1); +lean_dec(x_334); +if (x_335 == 0) { -x_297 = x_296; -goto block_331; +x_299 = x_298; +goto block_333; } else { -lean_object* x_334; lean_object* x_335; lean_object* x_336; uint8_t x_337; -x_334 = l_Lean_Meta_SynthInstance_getInstances___lambda__1___closed__1; -x_335 = l___private_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_334, x_2, x_296); -x_336 = lean_ctor_get(x_335, 0); -lean_inc(x_336); -x_337 = lean_unbox(x_336); -lean_dec(x_336); -if (x_337 == 0) -{ -lean_object* x_338; -x_338 = lean_ctor_get(x_335, 1); +lean_object* x_336; lean_object* x_337; lean_object* x_338; uint8_t x_339; +x_336 = l_Lean_Meta_SynthInstance_getInstances___lambda__1___closed__1; +x_337 = l___private_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_336, x_2, x_298); +x_338 = lean_ctor_get(x_337, 0); lean_inc(x_338); -lean_dec(x_335); -x_297 = x_338; -goto block_331; +x_339 = lean_unbox(x_338); +lean_dec(x_338); +if (x_339 == 0) +{ +lean_object* x_340; +x_340 = lean_ctor_get(x_337, 1); +lean_inc(x_340); +lean_dec(x_337); +x_299 = x_340; +goto block_333; } else { -lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; lean_object* x_345; lean_object* x_346; -x_339 = lean_ctor_get(x_335, 1); -lean_inc(x_339); -lean_dec(x_335); +lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; +x_341 = lean_ctor_get(x_337, 1); +lean_inc(x_341); +lean_dec(x_337); lean_inc(x_25); -x_340 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_340, 0, x_25); -x_341 = l_Lean_Meta_synthInstance_x3f___closed__9; -x_342 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_342, 0, x_340); -lean_ctor_set(x_342, 1, x_341); -lean_inc(x_295); -x_343 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_343, 0, x_295); +x_342 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_342, 0, x_25); +x_343 = l_Lean_Meta_synthInstance_x3f___closed__9; x_344 = lean_alloc_ctor(9, 2, 0); lean_ctor_set(x_344, 0, x_342); lean_ctor_set(x_344, 1, x_343); -x_345 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_334, x_344, x_2, x_339); -x_346 = lean_ctor_get(x_345, 1); -lean_inc(x_346); -lean_dec(x_345); -x_297 = x_346; -goto block_331; +lean_inc(x_297); +x_345 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_345, 0, x_297); +x_346 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_346, 0, x_344); +lean_ctor_set(x_346, 1, x_345); +x_347 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_336, x_346, x_2, x_341); +x_348 = lean_ctor_get(x_347, 1); +lean_inc(x_348); +lean_dec(x_347); +x_299 = x_348; +goto block_333; } } -block_331: -{ -lean_object* x_298; -lean_inc(x_2); -x_298 = l_Lean_Meta_SynthInstance_main(x_295, x_15, x_2, x_297); -if (lean_obj_tag(x_298) == 0) -{ -lean_object* x_299; -lean_dec(x_22); -x_299 = lean_ctor_get(x_298, 0); -lean_inc(x_299); -if (lean_obj_tag(x_299) == 0) +block_333: { lean_object* x_300; -x_300 = lean_ctor_get(x_298, 1); -lean_inc(x_300); -lean_dec(x_298); -x_233 = x_299; -x_234 = x_300; -goto block_280; -} -else +lean_inc(x_2); +x_300 = l_Lean_Meta_SynthInstance_main(x_297, x_15, x_2, x_299); +if (lean_obj_tag(x_300) == 0) { -lean_object* x_301; lean_object* x_302; lean_object* x_303; lean_object* x_304; lean_object* x_316; uint8_t x_317; -x_301 = lean_ctor_get(x_298, 1); +lean_object* x_301; +lean_dec(x_22); +x_301 = lean_ctor_get(x_300, 0); lean_inc(x_301); -lean_dec(x_298); -x_302 = lean_ctor_get(x_299, 0); -lean_inc(x_302); -if (lean_is_exclusive(x_299)) { - lean_ctor_release(x_299, 0); - x_303 = x_299; -} else { - lean_dec_ref(x_299); - x_303 = lean_box(0); -} -x_316 = lean_ctor_get(x_301, 4); -lean_inc(x_316); -x_317 = lean_ctor_get_uint8(x_316, sizeof(void*)*1); -lean_dec(x_316); -if (x_317 == 0) +if (lean_obj_tag(x_301) == 0) { -x_304 = x_301; -goto block_315; +lean_object* x_302; +x_302 = lean_ctor_get(x_300, 1); +lean_inc(x_302); +lean_dec(x_300); +x_235 = x_301; +x_236 = x_302; +goto block_282; } else { -lean_object* x_318; lean_object* x_319; lean_object* x_320; uint8_t x_321; -x_318 = l_Lean_Meta_SynthInstance_getInstances___lambda__1___closed__1; -x_319 = l___private_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_318, x_2, x_301); -x_320 = lean_ctor_get(x_319, 0); -lean_inc(x_320); -x_321 = lean_unbox(x_320); -lean_dec(x_320); -if (x_321 == 0) +lean_object* x_303; lean_object* x_304; lean_object* x_305; lean_object* x_306; lean_object* x_318; uint8_t x_319; +x_303 = lean_ctor_get(x_300, 1); +lean_inc(x_303); +lean_dec(x_300); +x_304 = lean_ctor_get(x_301, 0); +lean_inc(x_304); +if (lean_is_exclusive(x_301)) { + lean_ctor_release(x_301, 0); + x_305 = x_301; +} else { + lean_dec_ref(x_301); + x_305 = lean_box(0); +} +x_318 = lean_ctor_get(x_303, 4); +lean_inc(x_318); +x_319 = lean_ctor_get_uint8(x_318, sizeof(void*)*1); +lean_dec(x_318); +if (x_319 == 0) { -lean_object* x_322; -x_322 = lean_ctor_get(x_319, 1); +x_306 = x_303; +goto block_317; +} +else +{ +lean_object* x_320; lean_object* x_321; lean_object* x_322; uint8_t x_323; +x_320 = l_Lean_Meta_SynthInstance_getInstances___lambda__1___closed__1; +x_321 = l___private_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_320, x_2, x_303); +x_322 = lean_ctor_get(x_321, 0); lean_inc(x_322); -lean_dec(x_319); -x_304 = x_322; -goto block_315; +x_323 = lean_unbox(x_322); +lean_dec(x_322); +if (x_323 == 0) +{ +lean_object* x_324; +x_324 = lean_ctor_get(x_321, 1); +lean_inc(x_324); +lean_dec(x_321); +x_306 = x_324; +goto block_317; } else { -lean_object* x_323; lean_object* x_324; lean_object* x_325; lean_object* x_326; lean_object* x_327; lean_object* x_328; -x_323 = lean_ctor_get(x_319, 1); -lean_inc(x_323); -lean_dec(x_319); -lean_inc(x_302); -x_324 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_324, 0, x_302); -x_325 = l_Lean_Meta_synthInstance_x3f___closed__6; -x_326 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_326, 0, x_325); -lean_ctor_set(x_326, 1, x_324); -x_327 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_318, x_326, x_2, x_323); -x_328 = lean_ctor_get(x_327, 1); -lean_inc(x_328); -lean_dec(x_327); -x_304 = x_328; -goto block_315; +lean_object* x_325; lean_object* x_326; lean_object* x_327; lean_object* x_328; lean_object* x_329; lean_object* x_330; +x_325 = lean_ctor_get(x_321, 1); +lean_inc(x_325); +lean_dec(x_321); +lean_inc(x_304); +x_326 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_326, 0, x_304); +x_327 = l_Lean_Meta_synthInstance_x3f___closed__6; +x_328 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_328, 0, x_327); +lean_ctor_set(x_328, 1, x_326); +x_329 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_320, x_328, x_2, x_325); +x_330 = lean_ctor_get(x_329, 1); +lean_inc(x_330); +lean_dec(x_329); +x_306 = x_330; +goto block_317; } } -block_315: +block_317: { -lean_object* x_305; lean_object* x_306; lean_object* x_307; lean_object* x_308; lean_object* x_309; uint8_t x_310; -x_305 = l_Lean_Meta_instantiateMVars(x_302, x_2, x_304); -x_306 = lean_ctor_get(x_305, 0); -lean_inc(x_306); -x_307 = lean_ctor_get(x_305, 1); -lean_inc(x_307); -lean_dec(x_305); -x_308 = l_Lean_Meta_hasAssignableMVar(x_306, x_2, x_307); -x_309 = lean_ctor_get(x_308, 0); +lean_object* x_307; lean_object* x_308; lean_object* x_309; lean_object* x_310; lean_object* x_311; uint8_t x_312; +x_307 = l_Lean_Meta_instantiateMVars(x_304, x_2, x_306); +x_308 = lean_ctor_get(x_307, 0); +lean_inc(x_308); +x_309 = lean_ctor_get(x_307, 1); lean_inc(x_309); -x_310 = lean_unbox(x_309); -lean_dec(x_309); -if (x_310 == 0) -{ -lean_object* x_311; lean_object* x_312; -x_311 = lean_ctor_get(x_308, 1); +lean_dec(x_307); +x_310 = l_Lean_Meta_hasAssignableMVar(x_308, x_2, x_309); +x_311 = lean_ctor_get(x_310, 0); lean_inc(x_311); -lean_dec(x_308); -if (lean_is_scalar(x_303)) { - x_312 = lean_alloc_ctor(1, 1, 0); -} else { - x_312 = x_303; -} -lean_ctor_set(x_312, 0, x_306); -x_233 = x_312; -x_234 = x_311; -goto block_280; -} -else +x_312 = lean_unbox(x_311); +lean_dec(x_311); +if (x_312 == 0) { lean_object* x_313; lean_object* x_314; -lean_dec(x_306); -lean_dec(x_303); -x_313 = lean_ctor_get(x_308, 1); +x_313 = lean_ctor_get(x_310, 1); lean_inc(x_313); +lean_dec(x_310); +if (lean_is_scalar(x_305)) { + x_314 = lean_alloc_ctor(1, 1, 0); +} else { + x_314 = x_305; +} +lean_ctor_set(x_314, 0, x_308); +x_235 = x_314; +x_236 = x_313; +goto block_282; +} +else +{ +lean_object* x_315; lean_object* x_316; lean_dec(x_308); -x_314 = lean_box(0); -x_233 = x_314; -x_234 = x_313; -goto block_280; +lean_dec(x_305); +x_315 = lean_ctor_get(x_310, 1); +lean_inc(x_315); +lean_dec(x_310); +x_316 = lean_box(0); +x_235 = x_316; +x_236 = x_315; +goto block_282; } } } } else { -lean_object* x_329; lean_object* x_330; +lean_object* x_331; lean_object* x_332; lean_dec(x_27); lean_dec(x_25); lean_dec(x_2); @@ -23377,337 +23377,20 @@ lean_dec(x_8); lean_dec(x_7); lean_dec(x_6); lean_dec(x_5); -x_329 = lean_ctor_get(x_298, 0); -lean_inc(x_329); -x_330 = lean_ctor_get(x_298, 1); -lean_inc(x_330); -lean_dec(x_298); -x_281 = x_329; -x_282 = x_330; -goto block_291; -} -} -} -else -{ -lean_object* x_347; lean_object* x_348; -lean_dec(x_27); -lean_dec(x_25); -lean_dec(x_2); -lean_dec(x_15); -lean_dec(x_9); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -x_347 = lean_ctor_get(x_294, 0); -lean_inc(x_347); -x_348 = lean_ctor_get(x_294, 1); -lean_inc(x_348); -lean_dec(x_294); -x_281 = x_347; -x_282 = x_348; -goto block_291; -} -block_280: -{ -lean_object* x_235; lean_object* x_236; lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; -x_235 = lean_ctor_get(x_234, 0); -lean_inc(x_235); -x_236 = lean_ctor_get(x_234, 2); -lean_inc(x_236); -x_237 = lean_ctor_get(x_234, 3); -lean_inc(x_237); -x_238 = lean_ctor_get(x_234, 4); -lean_inc(x_238); -x_239 = lean_ctor_get(x_234, 5); -lean_inc(x_239); -if (lean_is_exclusive(x_234)) { - lean_ctor_release(x_234, 0); - lean_ctor_release(x_234, 1); - lean_ctor_release(x_234, 2); - lean_ctor_release(x_234, 3); - lean_ctor_release(x_234, 4); - lean_ctor_release(x_234, 5); - x_240 = x_234; -} else { - lean_dec_ref(x_234); - x_240 = lean_box(0); -} -lean_inc(x_238); -if (lean_is_scalar(x_240)) { - x_241 = lean_alloc_ctor(0, 6, 0); -} else { - x_241 = x_240; -} -lean_ctor_set(x_241, 0, x_235); -lean_ctor_set(x_241, 1, x_62); -lean_ctor_set(x_241, 2, x_236); -lean_ctor_set(x_241, 3, x_237); -lean_ctor_set(x_241, 4, x_238); -lean_ctor_set(x_241, 5, x_239); -if (lean_obj_tag(x_233) == 0) -{ -lean_dec(x_238); -lean_dec(x_2); -lean_dec(x_9); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -x_28 = x_233; -x_29 = x_241; -goto block_60; -} -else -{ -lean_object* x_242; lean_object* x_243; lean_object* x_244; uint8_t x_268; -x_242 = lean_ctor_get(x_233, 0); -lean_inc(x_242); -if (lean_is_exclusive(x_233)) { - lean_ctor_release(x_233, 0); - x_243 = x_233; -} else { - lean_dec_ref(x_233); - x_243 = lean_box(0); -} -x_268 = lean_ctor_get_uint8(x_238, sizeof(void*)*1); -lean_dec(x_238); -if (x_268 == 0) -{ -x_244 = x_241; -goto block_267; -} -else -{ -lean_object* x_269; lean_object* x_270; lean_object* x_271; uint8_t x_272; -x_269 = l_Lean_Meta_SynthInstance_getInstances___lambda__1___closed__1; -x_270 = l___private_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_269, x_2, x_241); -x_271 = lean_ctor_get(x_270, 0); -lean_inc(x_271); -x_272 = lean_unbox(x_271); -lean_dec(x_271); -if (x_272 == 0) -{ -lean_object* x_273; -x_273 = lean_ctor_get(x_270, 1); -lean_inc(x_273); -lean_dec(x_270); -x_244 = x_273; -goto block_267; -} -else -{ -lean_object* x_274; lean_object* x_275; lean_object* x_276; lean_object* x_277; lean_object* x_278; lean_object* x_279; -x_274 = lean_ctor_get(x_270, 1); -lean_inc(x_274); -lean_dec(x_270); -lean_inc(x_242); -x_275 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_275, 0, x_242); -x_276 = l_Lean_Meta_synthInstance_x3f___closed__3; -x_277 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_277, 0, x_276); -lean_ctor_set(x_277, 1, x_275); -x_278 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_269, x_277, x_2, x_274); -x_279 = lean_ctor_get(x_278, 1); -lean_inc(x_279); -lean_dec(x_278); -x_244 = x_279; -goto block_267; -} -} -block_267: -{ -lean_object* x_245; -lean_inc(x_2); -lean_inc(x_242); -x_245 = l_Lean_Meta_inferType(x_242, x_2, x_244); -if (lean_obj_tag(x_245) == 0) -{ -lean_object* x_246; lean_object* x_247; lean_object* x_248; lean_object* x_249; -x_246 = lean_ctor_get(x_245, 0); -lean_inc(x_246); -x_247 = lean_ctor_get(x_245, 1); -lean_inc(x_247); -lean_dec(x_245); -x_248 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_248, 0, x_5); -lean_ctor_set(x_248, 1, x_6); -lean_ctor_set(x_248, 2, x_7); -lean_ctor_set(x_248, 3, x_8); -lean_ctor_set(x_248, 4, x_9); -lean_inc(x_25); -x_249 = l_Lean_Meta_isExprDefEq(x_25, x_246, x_248, x_247); -if (lean_obj_tag(x_249) == 0) -{ -lean_object* x_250; uint8_t x_251; -x_250 = lean_ctor_get(x_249, 0); -lean_inc(x_250); -x_251 = lean_unbox(x_250); -lean_dec(x_250); -if (x_251 == 0) -{ -lean_object* x_252; lean_object* x_253; -lean_dec(x_243); -lean_dec(x_242); -lean_dec(x_2); -x_252 = lean_ctor_get(x_249, 1); -lean_inc(x_252); -lean_dec(x_249); -x_253 = lean_box(0); -x_28 = x_253; -x_29 = x_252; -goto block_60; -} -else -{ -lean_object* x_254; lean_object* x_255; lean_object* x_256; lean_object* x_257; lean_object* x_258; -x_254 = lean_ctor_get(x_249, 1); -lean_inc(x_254); -lean_dec(x_249); -x_255 = l_Lean_Meta_instantiateMVars(x_242, x_2, x_254); -lean_dec(x_2); -x_256 = lean_ctor_get(x_255, 0); -lean_inc(x_256); -x_257 = lean_ctor_get(x_255, 1); -lean_inc(x_257); -lean_dec(x_255); -if (lean_is_scalar(x_243)) { - x_258 = lean_alloc_ctor(1, 1, 0); -} else { - x_258 = x_243; -} -lean_ctor_set(x_258, 0, x_256); -x_28 = x_258; -x_29 = x_257; -goto block_60; -} -} -else -{ -lean_object* x_259; lean_object* x_260; lean_object* x_261; lean_object* x_262; -lean_dec(x_243); -lean_dec(x_242); -lean_dec(x_27); -lean_dec(x_25); -lean_dec(x_2); -x_259 = lean_ctor_get(x_249, 0); -lean_inc(x_259); -x_260 = lean_ctor_get(x_249, 1); -lean_inc(x_260); -if (lean_is_exclusive(x_249)) { - lean_ctor_release(x_249, 0); - lean_ctor_release(x_249, 1); - x_261 = x_249; -} else { - lean_dec_ref(x_249); - x_261 = lean_box(0); -} -if (lean_is_scalar(x_261)) { - x_262 = lean_alloc_ctor(1, 2, 0); -} else { - x_262 = x_261; -} -lean_ctor_set(x_262, 0, x_259); -lean_ctor_set(x_262, 1, x_260); -return x_262; -} -} -else -{ -lean_object* x_263; lean_object* x_264; lean_object* x_265; lean_object* x_266; -lean_dec(x_243); -lean_dec(x_242); -lean_dec(x_27); -lean_dec(x_25); -lean_dec(x_2); -lean_dec(x_9); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -x_263 = lean_ctor_get(x_245, 0); -lean_inc(x_263); -x_264 = lean_ctor_get(x_245, 1); -lean_inc(x_264); -if (lean_is_exclusive(x_245)) { - lean_ctor_release(x_245, 0); - lean_ctor_release(x_245, 1); - x_265 = x_245; -} else { - lean_dec_ref(x_245); - x_265 = lean_box(0); -} -if (lean_is_scalar(x_265)) { - x_266 = lean_alloc_ctor(1, 2, 0); -} else { - x_266 = x_265; -} -lean_ctor_set(x_266, 0, x_263); -lean_ctor_set(x_266, 1, x_264); -return x_266; -} -} -} -} -block_291: -{ -lean_object* x_283; lean_object* x_284; lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; lean_object* x_289; lean_object* x_290; -x_283 = lean_ctor_get(x_282, 0); -lean_inc(x_283); -x_284 = lean_ctor_get(x_282, 2); -lean_inc(x_284); -x_285 = lean_ctor_get(x_282, 3); -lean_inc(x_285); -x_286 = lean_ctor_get(x_282, 4); -lean_inc(x_286); -x_287 = lean_ctor_get(x_282, 5); -lean_inc(x_287); -if (lean_is_exclusive(x_282)) { - lean_ctor_release(x_282, 0); - lean_ctor_release(x_282, 1); - lean_ctor_release(x_282, 2); - lean_ctor_release(x_282, 3); - lean_ctor_release(x_282, 4); - lean_ctor_release(x_282, 5); - x_288 = x_282; -} else { - lean_dec_ref(x_282); - x_288 = lean_box(0); -} -if (lean_is_scalar(x_288)) { - x_289 = lean_alloc_ctor(0, 6, 0); -} else { - x_289 = x_288; -} -lean_ctor_set(x_289, 0, x_283); -lean_ctor_set(x_289, 1, x_62); -lean_ctor_set(x_289, 2, x_284); -lean_ctor_set(x_289, 3, x_285); -lean_ctor_set(x_289, 4, x_286); -lean_ctor_set(x_289, 5, x_287); -if (lean_is_scalar(x_22)) { - x_290 = lean_alloc_ctor(1, 2, 0); -} else { - x_290 = x_22; - lean_ctor_set_tag(x_290, 1); -} -lean_ctor_set(x_290, 0, x_281); -lean_ctor_set(x_290, 1, x_289); -return x_290; +x_331 = lean_ctor_get(x_300, 0); +lean_inc(x_331); +x_332 = lean_ctor_get(x_300, 1); +lean_inc(x_332); +lean_dec(x_300); +x_283 = x_331; +x_284 = x_332; +goto block_293; } } } else { lean_object* x_349; lean_object* x_350; -lean_dec(x_66); -lean_dec(x_65); -lean_dec(x_64); -lean_dec(x_63); -lean_dec(x_62); -lean_dec(x_61); lean_dec(x_27); lean_dec(x_25); lean_dec(x_2); @@ -23717,19 +23400,336 @@ lean_dec(x_8); lean_dec(x_7); lean_dec(x_6); lean_dec(x_5); -x_349 = lean_ctor_get(x_68, 0); +x_349 = lean_ctor_get(x_296, 0); lean_inc(x_349); -lean_dec(x_68); -if (lean_is_scalar(x_22)) { - x_350 = lean_alloc_ctor(0, 2, 0); +x_350 = lean_ctor_get(x_296, 1); +lean_inc(x_350); +lean_dec(x_296); +x_283 = x_349; +x_284 = x_350; +goto block_293; +} +block_282: +{ +lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; lean_object* x_242; lean_object* x_243; +x_237 = lean_ctor_get(x_236, 0); +lean_inc(x_237); +x_238 = lean_ctor_get(x_236, 2); +lean_inc(x_238); +x_239 = lean_ctor_get(x_236, 3); +lean_inc(x_239); +x_240 = lean_ctor_get(x_236, 4); +lean_inc(x_240); +x_241 = lean_ctor_get(x_236, 5); +lean_inc(x_241); +if (lean_is_exclusive(x_236)) { + lean_ctor_release(x_236, 0); + lean_ctor_release(x_236, 1); + lean_ctor_release(x_236, 2); + lean_ctor_release(x_236, 3); + lean_ctor_release(x_236, 4); + lean_ctor_release(x_236, 5); + x_242 = x_236; } else { - x_350 = x_22; + lean_dec_ref(x_236); + x_242 = lean_box(0); } -lean_ctor_set(x_350, 0, x_349); -lean_ctor_set(x_350, 1, x_26); -return x_350; +lean_inc(x_240); +if (lean_is_scalar(x_242)) { + x_243 = lean_alloc_ctor(0, 6, 0); +} else { + x_243 = x_242; } -block_60: +lean_ctor_set(x_243, 0, x_237); +lean_ctor_set(x_243, 1, x_64); +lean_ctor_set(x_243, 2, x_238); +lean_ctor_set(x_243, 3, x_239); +lean_ctor_set(x_243, 4, x_240); +lean_ctor_set(x_243, 5, x_241); +if (lean_obj_tag(x_235) == 0) +{ +lean_dec(x_240); +lean_dec(x_2); +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +x_28 = x_235; +x_29 = x_243; +goto block_62; +} +else +{ +lean_object* x_244; lean_object* x_245; lean_object* x_246; uint8_t x_270; +x_244 = lean_ctor_get(x_235, 0); +lean_inc(x_244); +if (lean_is_exclusive(x_235)) { + lean_ctor_release(x_235, 0); + x_245 = x_235; +} else { + lean_dec_ref(x_235); + x_245 = lean_box(0); +} +x_270 = lean_ctor_get_uint8(x_240, sizeof(void*)*1); +lean_dec(x_240); +if (x_270 == 0) +{ +x_246 = x_243; +goto block_269; +} +else +{ +lean_object* x_271; lean_object* x_272; lean_object* x_273; uint8_t x_274; +x_271 = l_Lean_Meta_SynthInstance_getInstances___lambda__1___closed__1; +x_272 = l___private_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_271, x_2, x_243); +x_273 = lean_ctor_get(x_272, 0); +lean_inc(x_273); +x_274 = lean_unbox(x_273); +lean_dec(x_273); +if (x_274 == 0) +{ +lean_object* x_275; +x_275 = lean_ctor_get(x_272, 1); +lean_inc(x_275); +lean_dec(x_272); +x_246 = x_275; +goto block_269; +} +else +{ +lean_object* x_276; lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; lean_object* x_281; +x_276 = lean_ctor_get(x_272, 1); +lean_inc(x_276); +lean_dec(x_272); +lean_inc(x_244); +x_277 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_277, 0, x_244); +x_278 = l_Lean_Meta_synthInstance_x3f___closed__3; +x_279 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_279, 0, x_278); +lean_ctor_set(x_279, 1, x_277); +x_280 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_271, x_279, x_2, x_276); +x_281 = lean_ctor_get(x_280, 1); +lean_inc(x_281); +lean_dec(x_280); +x_246 = x_281; +goto block_269; +} +} +block_269: +{ +lean_object* x_247; +lean_inc(x_2); +lean_inc(x_244); +x_247 = l_Lean_Meta_inferType(x_244, x_2, x_246); +if (lean_obj_tag(x_247) == 0) +{ +lean_object* x_248; lean_object* x_249; lean_object* x_250; lean_object* x_251; +x_248 = lean_ctor_get(x_247, 0); +lean_inc(x_248); +x_249 = lean_ctor_get(x_247, 1); +lean_inc(x_249); +lean_dec(x_247); +x_250 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_250, 0, x_5); +lean_ctor_set(x_250, 1, x_6); +lean_ctor_set(x_250, 2, x_7); +lean_ctor_set(x_250, 3, x_8); +lean_ctor_set(x_250, 4, x_9); +lean_inc(x_25); +x_251 = l_Lean_Meta_isExprDefEq(x_25, x_248, x_250, x_249); +if (lean_obj_tag(x_251) == 0) +{ +lean_object* x_252; uint8_t x_253; +x_252 = lean_ctor_get(x_251, 0); +lean_inc(x_252); +x_253 = lean_unbox(x_252); +lean_dec(x_252); +if (x_253 == 0) +{ +lean_object* x_254; lean_object* x_255; +lean_dec(x_245); +lean_dec(x_244); +lean_dec(x_2); +x_254 = lean_ctor_get(x_251, 1); +lean_inc(x_254); +lean_dec(x_251); +x_255 = lean_box(0); +x_28 = x_255; +x_29 = x_254; +goto block_62; +} +else +{ +lean_object* x_256; lean_object* x_257; lean_object* x_258; lean_object* x_259; lean_object* x_260; +x_256 = lean_ctor_get(x_251, 1); +lean_inc(x_256); +lean_dec(x_251); +x_257 = l_Lean_Meta_instantiateMVars(x_244, x_2, x_256); +lean_dec(x_2); +x_258 = lean_ctor_get(x_257, 0); +lean_inc(x_258); +x_259 = lean_ctor_get(x_257, 1); +lean_inc(x_259); +lean_dec(x_257); +if (lean_is_scalar(x_245)) { + x_260 = lean_alloc_ctor(1, 1, 0); +} else { + x_260 = x_245; +} +lean_ctor_set(x_260, 0, x_258); +x_28 = x_260; +x_29 = x_259; +goto block_62; +} +} +else +{ +lean_object* x_261; lean_object* x_262; lean_object* x_263; lean_object* x_264; +lean_dec(x_245); +lean_dec(x_244); +lean_dec(x_27); +lean_dec(x_25); +lean_dec(x_2); +x_261 = lean_ctor_get(x_251, 0); +lean_inc(x_261); +x_262 = lean_ctor_get(x_251, 1); +lean_inc(x_262); +if (lean_is_exclusive(x_251)) { + lean_ctor_release(x_251, 0); + lean_ctor_release(x_251, 1); + x_263 = x_251; +} else { + lean_dec_ref(x_251); + x_263 = lean_box(0); +} +if (lean_is_scalar(x_263)) { + x_264 = lean_alloc_ctor(1, 2, 0); +} else { + x_264 = x_263; +} +lean_ctor_set(x_264, 0, x_261); +lean_ctor_set(x_264, 1, x_262); +return x_264; +} +} +else +{ +lean_object* x_265; lean_object* x_266; lean_object* x_267; lean_object* x_268; +lean_dec(x_245); +lean_dec(x_244); +lean_dec(x_27); +lean_dec(x_25); +lean_dec(x_2); +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +x_265 = lean_ctor_get(x_247, 0); +lean_inc(x_265); +x_266 = lean_ctor_get(x_247, 1); +lean_inc(x_266); +if (lean_is_exclusive(x_247)) { + lean_ctor_release(x_247, 0); + lean_ctor_release(x_247, 1); + x_267 = x_247; +} else { + lean_dec_ref(x_247); + x_267 = lean_box(0); +} +if (lean_is_scalar(x_267)) { + x_268 = lean_alloc_ctor(1, 2, 0); +} else { + x_268 = x_267; +} +lean_ctor_set(x_268, 0, x_265); +lean_ctor_set(x_268, 1, x_266); +return x_268; +} +} +} +} +block_293: +{ +lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; lean_object* x_289; lean_object* x_290; lean_object* x_291; lean_object* x_292; +x_285 = lean_ctor_get(x_284, 0); +lean_inc(x_285); +x_286 = lean_ctor_get(x_284, 2); +lean_inc(x_286); +x_287 = lean_ctor_get(x_284, 3); +lean_inc(x_287); +x_288 = lean_ctor_get(x_284, 4); +lean_inc(x_288); +x_289 = lean_ctor_get(x_284, 5); +lean_inc(x_289); +if (lean_is_exclusive(x_284)) { + lean_ctor_release(x_284, 0); + lean_ctor_release(x_284, 1); + lean_ctor_release(x_284, 2); + lean_ctor_release(x_284, 3); + lean_ctor_release(x_284, 4); + lean_ctor_release(x_284, 5); + x_290 = x_284; +} else { + lean_dec_ref(x_284); + x_290 = lean_box(0); +} +if (lean_is_scalar(x_290)) { + x_291 = lean_alloc_ctor(0, 6, 0); +} else { + x_291 = x_290; +} +lean_ctor_set(x_291, 0, x_285); +lean_ctor_set(x_291, 1, x_64); +lean_ctor_set(x_291, 2, x_286); +lean_ctor_set(x_291, 3, x_287); +lean_ctor_set(x_291, 4, x_288); +lean_ctor_set(x_291, 5, x_289); +if (lean_is_scalar(x_22)) { + x_292 = lean_alloc_ctor(1, 2, 0); +} else { + x_292 = x_22; + lean_ctor_set_tag(x_292, 1); +} +lean_ctor_set(x_292, 0, x_283); +lean_ctor_set(x_292, 1, x_291); +return x_292; +} +} +} +else +{ +lean_object* x_351; lean_object* x_352; +lean_dec(x_68); +lean_dec(x_67); +lean_dec(x_66); +lean_dec(x_65); +lean_dec(x_64); +lean_dec(x_63); +lean_dec(x_27); +lean_dec(x_25); +lean_dec(x_2); +lean_dec(x_15); +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +x_351 = lean_ctor_get(x_70, 0); +lean_inc(x_351); +lean_dec(x_70); +if (lean_is_scalar(x_22)) { + x_352 = lean_alloc_ctor(0, 2, 0); +} else { + x_352 = x_22; +} +lean_ctor_set(x_352, 0, x_351); +lean_ctor_set(x_352, 1, x_26); +return x_352; +} +block_62: { uint8_t x_30; x_30 = l_Lean_Expr_hasMVar(x_25); @@ -23760,114 +23760,121 @@ return x_36; } else { -lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; +lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; x_37 = lean_ctor_get(x_32, 0); x_38 = lean_ctor_get(x_32, 1); x_39 = lean_ctor_get(x_32, 2); x_40 = lean_ctor_get(x_32, 3); +x_41 = lean_ctor_get(x_32, 4); +lean_inc(x_41); lean_inc(x_40); lean_inc(x_39); lean_inc(x_38); lean_inc(x_37); lean_dec(x_32); lean_inc(x_28); -x_41 = l_Std_PersistentHashMap_insert___at_Lean_Meta_synthInstance_x3f___spec__1(x_39, x_25, x_28); -x_42 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_42, 0, x_37); -lean_ctor_set(x_42, 1, x_38); -lean_ctor_set(x_42, 2, x_41); -lean_ctor_set(x_42, 3, x_40); -lean_ctor_set(x_29, 2, x_42); +x_42 = l_Std_PersistentHashMap_insert___at_Lean_Meta_synthInstance_x3f___spec__1(x_39, x_25, x_28); +x_43 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_43, 0, x_37); +lean_ctor_set(x_43, 1, x_38); +lean_ctor_set(x_43, 2, x_42); +lean_ctor_set(x_43, 3, x_40); +lean_ctor_set(x_43, 4, x_41); +lean_ctor_set(x_29, 2, x_43); if (lean_is_scalar(x_27)) { - x_43 = lean_alloc_ctor(0, 2, 0); + x_44 = lean_alloc_ctor(0, 2, 0); } else { - x_43 = x_27; + x_44 = x_27; } -lean_ctor_set(x_43, 0, x_28); -lean_ctor_set(x_43, 1, x_29); -return x_43; +lean_ctor_set(x_44, 0, x_28); +lean_ctor_set(x_44, 1, x_29); +return x_44; } } 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; -x_44 = lean_ctor_get(x_29, 2); -x_45 = lean_ctor_get(x_29, 0); -x_46 = lean_ctor_get(x_29, 1); -x_47 = lean_ctor_get(x_29, 3); -x_48 = lean_ctor_get(x_29, 4); -x_49 = lean_ctor_get(x_29, 5); +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; lean_object* x_60; +x_45 = lean_ctor_get(x_29, 2); +x_46 = lean_ctor_get(x_29, 0); +x_47 = lean_ctor_get(x_29, 1); +x_48 = lean_ctor_get(x_29, 3); +x_49 = lean_ctor_get(x_29, 4); +x_50 = lean_ctor_get(x_29, 5); +lean_inc(x_50); lean_inc(x_49); lean_inc(x_48); -lean_inc(x_47); -lean_inc(x_44); -lean_inc(x_46); lean_inc(x_45); +lean_inc(x_47); +lean_inc(x_46); lean_dec(x_29); -x_50 = lean_ctor_get(x_44, 0); -lean_inc(x_50); -x_51 = lean_ctor_get(x_44, 1); +x_51 = lean_ctor_get(x_45, 0); lean_inc(x_51); -x_52 = lean_ctor_get(x_44, 2); +x_52 = lean_ctor_get(x_45, 1); lean_inc(x_52); -x_53 = lean_ctor_get(x_44, 3); +x_53 = lean_ctor_get(x_45, 2); lean_inc(x_53); -if (lean_is_exclusive(x_44)) { - lean_ctor_release(x_44, 0); - lean_ctor_release(x_44, 1); - lean_ctor_release(x_44, 2); - lean_ctor_release(x_44, 3); - x_54 = x_44; +x_54 = lean_ctor_get(x_45, 3); +lean_inc(x_54); +x_55 = lean_ctor_get(x_45, 4); +lean_inc(x_55); +if (lean_is_exclusive(x_45)) { + lean_ctor_release(x_45, 0); + lean_ctor_release(x_45, 1); + lean_ctor_release(x_45, 2); + lean_ctor_release(x_45, 3); + lean_ctor_release(x_45, 4); + x_56 = x_45; } else { - lean_dec_ref(x_44); - x_54 = lean_box(0); + lean_dec_ref(x_45); + x_56 = lean_box(0); } lean_inc(x_28); -x_55 = l_Std_PersistentHashMap_insert___at_Lean_Meta_synthInstance_x3f___spec__1(x_52, x_25, x_28); -if (lean_is_scalar(x_54)) { - x_56 = lean_alloc_ctor(0, 4, 0); +x_57 = l_Std_PersistentHashMap_insert___at_Lean_Meta_synthInstance_x3f___spec__1(x_53, x_25, x_28); +if (lean_is_scalar(x_56)) { + x_58 = lean_alloc_ctor(0, 5, 0); } else { - x_56 = x_54; + x_58 = x_56; } -lean_ctor_set(x_56, 0, x_50); -lean_ctor_set(x_56, 1, x_51); -lean_ctor_set(x_56, 2, x_55); -lean_ctor_set(x_56, 3, x_53); -x_57 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_57, 0, x_45); -lean_ctor_set(x_57, 1, x_46); -lean_ctor_set(x_57, 2, x_56); -lean_ctor_set(x_57, 3, x_47); -lean_ctor_set(x_57, 4, x_48); -lean_ctor_set(x_57, 5, x_49); +lean_ctor_set(x_58, 0, x_51); +lean_ctor_set(x_58, 1, x_52); +lean_ctor_set(x_58, 2, x_57); +lean_ctor_set(x_58, 3, x_54); +lean_ctor_set(x_58, 4, x_55); +x_59 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_59, 0, x_46); +lean_ctor_set(x_59, 1, x_47); +lean_ctor_set(x_59, 2, x_58); +lean_ctor_set(x_59, 3, x_48); +lean_ctor_set(x_59, 4, x_49); +lean_ctor_set(x_59, 5, x_50); if (lean_is_scalar(x_27)) { - x_58 = lean_alloc_ctor(0, 2, 0); + x_60 = lean_alloc_ctor(0, 2, 0); } else { - x_58 = x_27; + x_60 = x_27; } -lean_ctor_set(x_58, 0, x_28); -lean_ctor_set(x_58, 1, x_57); -return x_58; +lean_ctor_set(x_60, 0, x_28); +lean_ctor_set(x_60, 1, x_59); +return x_60; } } else { -lean_object* x_59; +lean_object* x_61; lean_dec(x_25); if (lean_is_scalar(x_27)) { - x_59 = lean_alloc_ctor(0, 2, 0); + x_61 = lean_alloc_ctor(0, 2, 0); } else { - x_59 = x_27; + x_61 = x_27; } -lean_ctor_set(x_59, 0, x_28); -lean_ctor_set(x_59, 1, x_29); -return x_59; +lean_ctor_set(x_61, 0, x_28); +lean_ctor_set(x_61, 1, x_29); +return x_61; } } } else { -uint8_t x_351; +uint8_t x_353; lean_dec(x_22); lean_dec(x_2); lean_dec(x_15); @@ -23876,825 +23883,829 @@ lean_dec(x_8); lean_dec(x_7); lean_dec(x_6); lean_dec(x_5); -x_351 = !lean_is_exclusive(x_24); -if (x_351 == 0) +x_353 = !lean_is_exclusive(x_24); +if (x_353 == 0) { return x_24; } else { -lean_object* x_352; lean_object* x_353; lean_object* x_354; -x_352 = lean_ctor_get(x_24, 0); -x_353 = lean_ctor_get(x_24, 1); -lean_inc(x_353); -lean_inc(x_352); +lean_object* x_354; lean_object* x_355; lean_object* x_356; +x_354 = lean_ctor_get(x_24, 0); +x_355 = lean_ctor_get(x_24, 1); +lean_inc(x_355); +lean_inc(x_354); lean_dec(x_24); -x_354 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_354, 0, x_352); -lean_ctor_set(x_354, 1, x_353); -return x_354; +x_356 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_356, 0, x_354); +lean_ctor_set(x_356, 1, x_355); +return x_356; } } } else { -lean_object* x_355; lean_object* x_356; lean_object* x_357; lean_object* x_358; lean_object* x_359; lean_object* x_360; uint8_t x_361; uint8_t x_362; uint8_t x_363; uint8_t x_364; lean_object* x_365; uint8_t x_366; uint8_t 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; lean_object* x_374; lean_object* x_375; -x_355 = lean_ctor_get(x_2, 0); -x_356 = lean_ctor_get(x_2, 1); -x_357 = lean_ctor_get(x_2, 2); -x_358 = lean_ctor_get(x_2, 3); -x_359 = lean_ctor_get(x_2, 4); -lean_inc(x_359); -lean_inc(x_358); -lean_inc(x_357); -lean_inc(x_356); -lean_inc(x_355); -lean_dec(x_2); -x_360 = lean_ctor_get(x_355, 0); +lean_object* x_357; lean_object* x_358; lean_object* x_359; lean_object* x_360; lean_object* x_361; lean_object* x_362; uint8_t x_363; uint8_t x_364; uint8_t x_365; uint8_t x_366; lean_object* x_367; uint8_t x_368; uint8_t x_369; lean_object* x_370; lean_object* x_371; lean_object* x_372; lean_object* x_373; lean_object* x_374; lean_object* x_375; lean_object* x_376; lean_object* x_377; +x_357 = lean_ctor_get(x_2, 0); +x_358 = lean_ctor_get(x_2, 1); +x_359 = lean_ctor_get(x_2, 2); +x_360 = lean_ctor_get(x_2, 3); +x_361 = lean_ctor_get(x_2, 4); +lean_inc(x_361); lean_inc(x_360); -x_361 = lean_ctor_get_uint8(x_355, sizeof(void*)*1 + 2); -x_362 = lean_ctor_get_uint8(x_355, sizeof(void*)*1 + 3); -x_363 = lean_ctor_get_uint8(x_355, sizeof(void*)*1 + 4); -x_364 = lean_ctor_get_uint8(x_355, sizeof(void*)*1 + 5); -x_365 = l___private_Lean_Meta_SynthInstance_6__getMaxSteps(x_360); -x_366 = 1; -x_367 = 2; -x_368 = lean_alloc_ctor(0, 1, 7); -lean_ctor_set(x_368, 0, x_360); -lean_ctor_set_uint8(x_368, sizeof(void*)*1, x_366); -lean_ctor_set_uint8(x_368, sizeof(void*)*1 + 1, x_366); -lean_ctor_set_uint8(x_368, sizeof(void*)*1 + 2, x_361); -lean_ctor_set_uint8(x_368, sizeof(void*)*1 + 3, x_362); -lean_ctor_set_uint8(x_368, sizeof(void*)*1 + 4, x_363); -lean_ctor_set_uint8(x_368, sizeof(void*)*1 + 5, x_364); -lean_ctor_set_uint8(x_368, sizeof(void*)*1 + 6, x_367); lean_inc(x_359); lean_inc(x_358); lean_inc(x_357); -lean_inc(x_356); -x_369 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_369, 0, x_368); -lean_ctor_set(x_369, 1, x_356); -lean_ctor_set(x_369, 2, x_357); -lean_ctor_set(x_369, 3, x_358); -lean_ctor_set(x_369, 4, x_359); -x_370 = l_Lean_Meta_instantiateMVars(x_1, x_369, x_3); -x_371 = lean_ctor_get(x_370, 0); +lean_dec(x_2); +x_362 = lean_ctor_get(x_357, 0); +lean_inc(x_362); +x_363 = lean_ctor_get_uint8(x_357, sizeof(void*)*1 + 2); +x_364 = lean_ctor_get_uint8(x_357, sizeof(void*)*1 + 3); +x_365 = lean_ctor_get_uint8(x_357, sizeof(void*)*1 + 4); +x_366 = lean_ctor_get_uint8(x_357, sizeof(void*)*1 + 5); +x_367 = l___private_Lean_Meta_SynthInstance_6__getMaxSteps(x_362); +x_368 = 1; +x_369 = 2; +x_370 = lean_alloc_ctor(0, 1, 7); +lean_ctor_set(x_370, 0, x_362); +lean_ctor_set_uint8(x_370, sizeof(void*)*1, x_368); +lean_ctor_set_uint8(x_370, sizeof(void*)*1 + 1, x_368); +lean_ctor_set_uint8(x_370, sizeof(void*)*1 + 2, x_363); +lean_ctor_set_uint8(x_370, sizeof(void*)*1 + 3, x_364); +lean_ctor_set_uint8(x_370, sizeof(void*)*1 + 4, x_365); +lean_ctor_set_uint8(x_370, sizeof(void*)*1 + 5, x_366); +lean_ctor_set_uint8(x_370, sizeof(void*)*1 + 6, x_369); +lean_inc(x_361); +lean_inc(x_360); +lean_inc(x_359); +lean_inc(x_358); +x_371 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_371, 0, x_370); +lean_ctor_set(x_371, 1, x_358); +lean_ctor_set(x_371, 2, x_359); +lean_ctor_set(x_371, 3, x_360); +lean_ctor_set(x_371, 4, x_361); +x_372 = l_Lean_Meta_instantiateMVars(x_1, x_371, x_3); +x_373 = lean_ctor_get(x_372, 0); +lean_inc(x_373); +x_374 = lean_ctor_get(x_372, 1); +lean_inc(x_374); +if (lean_is_exclusive(x_372)) { + lean_ctor_release(x_372, 0); + lean_ctor_release(x_372, 1); + x_375 = x_372; +} else { + lean_dec_ref(x_372); + x_375 = lean_box(0); +} +x_376 = l___private_Lean_Meta_SynthInstance_2__preprocess___closed__1; lean_inc(x_371); -x_372 = lean_ctor_get(x_370, 1); -lean_inc(x_372); -if (lean_is_exclusive(x_370)) { - lean_ctor_release(x_370, 0); - lean_ctor_release(x_370, 1); - x_373 = x_370; -} else { - lean_dec_ref(x_370); - x_373 = lean_box(0); -} -x_374 = l___private_Lean_Meta_SynthInstance_2__preprocess___closed__1; -lean_inc(x_369); -x_375 = l_Lean_Meta_forallTelescopeReducing___rarg(x_371, x_374, x_369, x_372); -if (lean_obj_tag(x_375) == 0) +x_377 = l_Lean_Meta_forallTelescopeReducing___rarg(x_373, x_376, x_371, x_374); +if (lean_obj_tag(x_377) == 0) { -lean_object* x_376; lean_object* x_377; lean_object* x_378; lean_object* x_379; lean_object* x_380; 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; -x_376 = lean_ctor_get(x_375, 0); -lean_inc(x_376); -x_377 = lean_ctor_get(x_375, 1); -lean_inc(x_377); -if (lean_is_exclusive(x_375)) { - lean_ctor_release(x_375, 0); - lean_ctor_release(x_375, 1); - x_378 = x_375; -} else { - lean_dec_ref(x_375); - x_378 = lean_box(0); -} -x_400 = lean_ctor_get(x_377, 0); -lean_inc(x_400); -x_401 = lean_ctor_get(x_377, 1); -lean_inc(x_401); -x_402 = lean_ctor_get(x_377, 2); -lean_inc(x_402); -x_403 = lean_ctor_get(x_377, 3); -lean_inc(x_403); -x_404 = lean_ctor_get(x_377, 4); -lean_inc(x_404); -x_405 = lean_ctor_get(x_377, 5); -lean_inc(x_405); -x_406 = lean_ctor_get(x_402, 2); -lean_inc(x_406); -x_407 = l_Std_PersistentHashMap_find_x3f___at_Lean_Meta_synthInstance_x3f___spec__5(x_406, x_376); -if (lean_obj_tag(x_407) == 0) -{ -lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_457; lean_object* x_458; lean_object* x_468; lean_object* x_469; lean_object* x_470; +lean_object* x_378; lean_object* x_379; lean_object* x_380; lean_object* x_381; lean_object* x_382; lean_object* x_403; lean_object* x_404; lean_object* x_405; lean_object* x_406; lean_object* x_407; lean_object* x_408; lean_object* x_409; lean_object* x_410; +x_378 = lean_ctor_get(x_377, 0); +lean_inc(x_378); +x_379 = lean_ctor_get(x_377, 1); +lean_inc(x_379); if (lean_is_exclusive(x_377)) { lean_ctor_release(x_377, 0); lean_ctor_release(x_377, 1); - lean_ctor_release(x_377, 2); - lean_ctor_release(x_377, 3); - lean_ctor_release(x_377, 4); - lean_ctor_release(x_377, 5); - x_408 = x_377; + x_380 = x_377; } else { lean_dec_ref(x_377); - x_408 = lean_box(0); + x_380 = lean_box(0); } -lean_inc(x_401); -x_468 = l_Lean_MetavarContext_incDepth(x_401); -if (lean_is_scalar(x_408)) { - x_469 = lean_alloc_ctor(0, 6, 0); +x_403 = lean_ctor_get(x_379, 0); +lean_inc(x_403); +x_404 = lean_ctor_get(x_379, 1); +lean_inc(x_404); +x_405 = lean_ctor_get(x_379, 2); +lean_inc(x_405); +x_406 = lean_ctor_get(x_379, 3); +lean_inc(x_406); +x_407 = lean_ctor_get(x_379, 4); +lean_inc(x_407); +x_408 = lean_ctor_get(x_379, 5); +lean_inc(x_408); +x_409 = lean_ctor_get(x_405, 2); +lean_inc(x_409); +x_410 = l_Std_PersistentHashMap_find_x3f___at_Lean_Meta_synthInstance_x3f___spec__5(x_409, x_378); +if (lean_obj_tag(x_410) == 0) +{ +lean_object* x_411; lean_object* x_412; lean_object* x_413; lean_object* x_460; lean_object* x_461; lean_object* x_471; lean_object* x_472; lean_object* x_473; +if (lean_is_exclusive(x_379)) { + lean_ctor_release(x_379, 0); + lean_ctor_release(x_379, 1); + lean_ctor_release(x_379, 2); + lean_ctor_release(x_379, 3); + lean_ctor_release(x_379, 4); + lean_ctor_release(x_379, 5); + x_411 = x_379; } else { - x_469 = x_408; + lean_dec_ref(x_379); + x_411 = lean_box(0); } -lean_ctor_set(x_469, 0, x_400); -lean_ctor_set(x_469, 1, x_468); -lean_ctor_set(x_469, 2, x_402); -lean_ctor_set(x_469, 3, x_403); -lean_ctor_set(x_469, 4, x_404); -lean_ctor_set(x_469, 5, x_405); -lean_inc(x_369); -lean_inc(x_376); -x_470 = l___private_Lean_Meta_SynthInstance_5__preprocessOutParam(x_376, x_369, x_469); -if (lean_obj_tag(x_470) == 0) -{ -lean_object* x_471; lean_object* x_472; lean_object* x_473; lean_object* x_508; uint8_t x_509; -x_471 = lean_ctor_get(x_470, 0); -lean_inc(x_471); -x_472 = lean_ctor_get(x_470, 1); -lean_inc(x_472); -lean_dec(x_470); -x_508 = lean_ctor_get(x_472, 4); -lean_inc(x_508); -x_509 = lean_ctor_get_uint8(x_508, sizeof(void*)*1); -lean_dec(x_508); -if (x_509 == 0) -{ -x_473 = x_472; -goto block_507; +lean_inc(x_404); +x_471 = l_Lean_MetavarContext_incDepth(x_404); +if (lean_is_scalar(x_411)) { + x_472 = lean_alloc_ctor(0, 6, 0); +} else { + x_472 = x_411; } -else +lean_ctor_set(x_472, 0, x_403); +lean_ctor_set(x_472, 1, x_471); +lean_ctor_set(x_472, 2, x_405); +lean_ctor_set(x_472, 3, x_406); +lean_ctor_set(x_472, 4, x_407); +lean_ctor_set(x_472, 5, x_408); +lean_inc(x_371); +lean_inc(x_378); +x_473 = l___private_Lean_Meta_SynthInstance_5__preprocessOutParam(x_378, x_371, x_472); +if (lean_obj_tag(x_473) == 0) { -lean_object* x_510; lean_object* x_511; lean_object* x_512; uint8_t x_513; -x_510 = l_Lean_Meta_SynthInstance_getInstances___lambda__1___closed__1; -x_511 = l___private_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_510, x_369, x_472); -x_512 = lean_ctor_get(x_511, 0); -lean_inc(x_512); -x_513 = lean_unbox(x_512); -lean_dec(x_512); -if (x_513 == 0) -{ -lean_object* x_514; -x_514 = lean_ctor_get(x_511, 1); -lean_inc(x_514); -lean_dec(x_511); -x_473 = x_514; -goto block_507; -} -else -{ -lean_object* x_515; lean_object* x_516; lean_object* x_517; lean_object* x_518; lean_object* x_519; lean_object* x_520; lean_object* x_521; lean_object* x_522; -x_515 = lean_ctor_get(x_511, 1); -lean_inc(x_515); -lean_dec(x_511); -lean_inc(x_376); -x_516 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_516, 0, x_376); -x_517 = l_Lean_Meta_synthInstance_x3f___closed__9; -x_518 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_518, 0, x_516); -lean_ctor_set(x_518, 1, x_517); -lean_inc(x_471); -x_519 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_519, 0, x_471); -x_520 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_520, 0, x_518); -lean_ctor_set(x_520, 1, x_519); -x_521 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_510, x_520, x_369, x_515); -x_522 = lean_ctor_get(x_521, 1); -lean_inc(x_522); -lean_dec(x_521); -x_473 = x_522; -goto block_507; -} -} -block_507: -{ -lean_object* x_474; -lean_inc(x_369); -x_474 = l_Lean_Meta_SynthInstance_main(x_471, x_365, x_369, x_473); -if (lean_obj_tag(x_474) == 0) -{ -lean_object* x_475; -lean_dec(x_373); -x_475 = lean_ctor_get(x_474, 0); +lean_object* x_474; lean_object* x_475; lean_object* x_476; lean_object* x_511; uint8_t x_512; +x_474 = lean_ctor_get(x_473, 0); +lean_inc(x_474); +x_475 = lean_ctor_get(x_473, 1); lean_inc(x_475); -if (lean_obj_tag(x_475) == 0) +lean_dec(x_473); +x_511 = lean_ctor_get(x_475, 4); +lean_inc(x_511); +x_512 = lean_ctor_get_uint8(x_511, sizeof(void*)*1); +lean_dec(x_511); +if (x_512 == 0) { -lean_object* x_476; -x_476 = lean_ctor_get(x_474, 1); -lean_inc(x_476); -lean_dec(x_474); -x_409 = x_475; -x_410 = x_476; -goto block_456; +x_476 = x_475; +goto block_510; } else { -lean_object* x_477; lean_object* x_478; lean_object* x_479; lean_object* x_480; lean_object* x_492; uint8_t x_493; -x_477 = lean_ctor_get(x_474, 1); -lean_inc(x_477); -lean_dec(x_474); -x_478 = lean_ctor_get(x_475, 0); +lean_object* x_513; lean_object* x_514; lean_object* x_515; uint8_t x_516; +x_513 = l_Lean_Meta_SynthInstance_getInstances___lambda__1___closed__1; +x_514 = l___private_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_513, x_371, x_475); +x_515 = lean_ctor_get(x_514, 0); +lean_inc(x_515); +x_516 = lean_unbox(x_515); +lean_dec(x_515); +if (x_516 == 0) +{ +lean_object* x_517; +x_517 = lean_ctor_get(x_514, 1); +lean_inc(x_517); +lean_dec(x_514); +x_476 = x_517; +goto block_510; +} +else +{ +lean_object* x_518; lean_object* x_519; lean_object* x_520; lean_object* x_521; lean_object* x_522; lean_object* x_523; lean_object* x_524; lean_object* x_525; +x_518 = lean_ctor_get(x_514, 1); +lean_inc(x_518); +lean_dec(x_514); +lean_inc(x_378); +x_519 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_519, 0, x_378); +x_520 = l_Lean_Meta_synthInstance_x3f___closed__9; +x_521 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_521, 0, x_519); +lean_ctor_set(x_521, 1, x_520); +lean_inc(x_474); +x_522 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_522, 0, x_474); +x_523 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_523, 0, x_521); +lean_ctor_set(x_523, 1, x_522); +x_524 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_513, x_523, x_371, x_518); +x_525 = lean_ctor_get(x_524, 1); +lean_inc(x_525); +lean_dec(x_524); +x_476 = x_525; +goto block_510; +} +} +block_510: +{ +lean_object* x_477; +lean_inc(x_371); +x_477 = l_Lean_Meta_SynthInstance_main(x_474, x_367, x_371, x_476); +if (lean_obj_tag(x_477) == 0) +{ +lean_object* x_478; +lean_dec(x_375); +x_478 = lean_ctor_get(x_477, 0); lean_inc(x_478); -if (lean_is_exclusive(x_475)) { - lean_ctor_release(x_475, 0); - x_479 = x_475; +if (lean_obj_tag(x_478) == 0) +{ +lean_object* x_479; +x_479 = lean_ctor_get(x_477, 1); +lean_inc(x_479); +lean_dec(x_477); +x_412 = x_478; +x_413 = x_479; +goto block_459; +} +else +{ +lean_object* x_480; lean_object* x_481; lean_object* x_482; lean_object* x_483; lean_object* x_495; uint8_t x_496; +x_480 = lean_ctor_get(x_477, 1); +lean_inc(x_480); +lean_dec(x_477); +x_481 = lean_ctor_get(x_478, 0); +lean_inc(x_481); +if (lean_is_exclusive(x_478)) { + lean_ctor_release(x_478, 0); + x_482 = x_478; } else { - lean_dec_ref(x_475); - x_479 = lean_box(0); + lean_dec_ref(x_478); + x_482 = lean_box(0); } -x_492 = lean_ctor_get(x_477, 4); -lean_inc(x_492); -x_493 = lean_ctor_get_uint8(x_492, sizeof(void*)*1); -lean_dec(x_492); -if (x_493 == 0) -{ -x_480 = x_477; -goto block_491; -} -else -{ -lean_object* x_494; lean_object* x_495; lean_object* x_496; uint8_t x_497; -x_494 = l_Lean_Meta_SynthInstance_getInstances___lambda__1___closed__1; -x_495 = l___private_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_494, x_369, x_477); -x_496 = lean_ctor_get(x_495, 0); -lean_inc(x_496); -x_497 = lean_unbox(x_496); -lean_dec(x_496); -if (x_497 == 0) -{ -lean_object* x_498; -x_498 = lean_ctor_get(x_495, 1); -lean_inc(x_498); +x_495 = lean_ctor_get(x_480, 4); +lean_inc(x_495); +x_496 = lean_ctor_get_uint8(x_495, sizeof(void*)*1); lean_dec(x_495); -x_480 = x_498; -goto block_491; +if (x_496 == 0) +{ +x_483 = x_480; +goto block_494; } else { -lean_object* x_499; lean_object* x_500; lean_object* x_501; lean_object* x_502; lean_object* x_503; lean_object* x_504; -x_499 = lean_ctor_get(x_495, 1); +lean_object* x_497; lean_object* x_498; lean_object* x_499; uint8_t x_500; +x_497 = l_Lean_Meta_SynthInstance_getInstances___lambda__1___closed__1; +x_498 = l___private_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_497, x_371, x_480); +x_499 = lean_ctor_get(x_498, 0); lean_inc(x_499); -lean_dec(x_495); -lean_inc(x_478); -x_500 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_500, 0, x_478); -x_501 = l_Lean_Meta_synthInstance_x3f___closed__6; -x_502 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_502, 0, x_501); -lean_ctor_set(x_502, 1, x_500); -x_503 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_494, x_502, x_369, x_499); -x_504 = lean_ctor_get(x_503, 1); -lean_inc(x_504); -lean_dec(x_503); -x_480 = x_504; -goto block_491; -} -} -block_491: +x_500 = lean_unbox(x_499); +lean_dec(x_499); +if (x_500 == 0) { -lean_object* x_481; lean_object* x_482; lean_object* x_483; lean_object* x_484; lean_object* x_485; uint8_t x_486; -x_481 = l_Lean_Meta_instantiateMVars(x_478, x_369, x_480); -x_482 = lean_ctor_get(x_481, 0); -lean_inc(x_482); -x_483 = lean_ctor_get(x_481, 1); -lean_inc(x_483); -lean_dec(x_481); -x_484 = l_Lean_Meta_hasAssignableMVar(x_482, x_369, x_483); +lean_object* x_501; +x_501 = lean_ctor_get(x_498, 1); +lean_inc(x_501); +lean_dec(x_498); +x_483 = x_501; +goto block_494; +} +else +{ +lean_object* x_502; lean_object* x_503; lean_object* x_504; lean_object* x_505; lean_object* x_506; lean_object* x_507; +x_502 = lean_ctor_get(x_498, 1); +lean_inc(x_502); +lean_dec(x_498); +lean_inc(x_481); +x_503 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_503, 0, x_481); +x_504 = l_Lean_Meta_synthInstance_x3f___closed__6; +x_505 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_505, 0, x_504); +lean_ctor_set(x_505, 1, x_503); +x_506 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_497, x_505, x_371, x_502); +x_507 = lean_ctor_get(x_506, 1); +lean_inc(x_507); +lean_dec(x_506); +x_483 = x_507; +goto block_494; +} +} +block_494: +{ +lean_object* x_484; lean_object* x_485; lean_object* x_486; lean_object* x_487; lean_object* x_488; uint8_t x_489; +x_484 = l_Lean_Meta_instantiateMVars(x_481, x_371, x_483); x_485 = lean_ctor_get(x_484, 0); lean_inc(x_485); -x_486 = lean_unbox(x_485); +x_486 = lean_ctor_get(x_484, 1); +lean_inc(x_486); +lean_dec(x_484); +x_487 = l_Lean_Meta_hasAssignableMVar(x_485, x_371, x_486); +x_488 = lean_ctor_get(x_487, 0); +lean_inc(x_488); +x_489 = lean_unbox(x_488); +lean_dec(x_488); +if (x_489 == 0) +{ +lean_object* x_490; lean_object* x_491; +x_490 = lean_ctor_get(x_487, 1); +lean_inc(x_490); +lean_dec(x_487); +if (lean_is_scalar(x_482)) { + x_491 = lean_alloc_ctor(1, 1, 0); +} else { + x_491 = x_482; +} +lean_ctor_set(x_491, 0, x_485); +x_412 = x_491; +x_413 = x_490; +goto block_459; +} +else +{ +lean_object* x_492; lean_object* x_493; lean_dec(x_485); -if (x_486 == 0) -{ -lean_object* x_487; lean_object* x_488; -x_487 = lean_ctor_get(x_484, 1); -lean_inc(x_487); -lean_dec(x_484); -if (lean_is_scalar(x_479)) { - x_488 = lean_alloc_ctor(1, 1, 0); -} else { - x_488 = x_479; -} -lean_ctor_set(x_488, 0, x_482); -x_409 = x_488; -x_410 = x_487; -goto block_456; -} -else -{ -lean_object* x_489; lean_object* x_490; lean_dec(x_482); -lean_dec(x_479); -x_489 = lean_ctor_get(x_484, 1); -lean_inc(x_489); -lean_dec(x_484); -x_490 = lean_box(0); -x_409 = x_490; -x_410 = x_489; -goto block_456; +x_492 = lean_ctor_get(x_487, 1); +lean_inc(x_492); +lean_dec(x_487); +x_493 = lean_box(0); +x_412 = x_493; +x_413 = x_492; +goto block_459; } } } } else { -lean_object* x_505; lean_object* x_506; +lean_object* x_508; lean_object* x_509; +lean_dec(x_380); lean_dec(x_378); -lean_dec(x_376); -lean_dec(x_369); +lean_dec(x_371); +lean_dec(x_361); +lean_dec(x_360); lean_dec(x_359); lean_dec(x_358); lean_dec(x_357); -lean_dec(x_356); -lean_dec(x_355); -x_505 = lean_ctor_get(x_474, 0); -lean_inc(x_505); -x_506 = lean_ctor_get(x_474, 1); -lean_inc(x_506); -lean_dec(x_474); -x_457 = x_505; -x_458 = x_506; -goto block_467; +x_508 = lean_ctor_get(x_477, 0); +lean_inc(x_508); +x_509 = lean_ctor_get(x_477, 1); +lean_inc(x_509); +lean_dec(x_477); +x_460 = x_508; +x_461 = x_509; +goto block_470; } } } else { -lean_object* x_523; lean_object* x_524; +lean_object* x_526; lean_object* x_527; +lean_dec(x_380); lean_dec(x_378); -lean_dec(x_376); -lean_dec(x_369); -lean_dec(x_365); +lean_dec(x_371); +lean_dec(x_367); +lean_dec(x_361); +lean_dec(x_360); lean_dec(x_359); lean_dec(x_358); lean_dec(x_357); -lean_dec(x_356); -lean_dec(x_355); -x_523 = lean_ctor_get(x_470, 0); -lean_inc(x_523); -x_524 = lean_ctor_get(x_470, 1); -lean_inc(x_524); -lean_dec(x_470); -x_457 = x_523; -x_458 = x_524; -goto block_467; +x_526 = lean_ctor_get(x_473, 0); +lean_inc(x_526); +x_527 = lean_ctor_get(x_473, 1); +lean_inc(x_527); +lean_dec(x_473); +x_460 = x_526; +x_461 = x_527; +goto block_470; } -block_456: +block_459: { -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; -x_411 = lean_ctor_get(x_410, 0); -lean_inc(x_411); -x_412 = lean_ctor_get(x_410, 2); -lean_inc(x_412); -x_413 = lean_ctor_get(x_410, 3); -lean_inc(x_413); -x_414 = lean_ctor_get(x_410, 4); +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; +x_414 = lean_ctor_get(x_413, 0); lean_inc(x_414); -x_415 = lean_ctor_get(x_410, 5); +x_415 = lean_ctor_get(x_413, 2); lean_inc(x_415); -if (lean_is_exclusive(x_410)) { - lean_ctor_release(x_410, 0); - lean_ctor_release(x_410, 1); - lean_ctor_release(x_410, 2); - lean_ctor_release(x_410, 3); - lean_ctor_release(x_410, 4); - lean_ctor_release(x_410, 5); - x_416 = x_410; -} else { - lean_dec_ref(x_410); - x_416 = lean_box(0); -} -lean_inc(x_414); -if (lean_is_scalar(x_416)) { - x_417 = lean_alloc_ctor(0, 6, 0); -} else { - x_417 = x_416; -} -lean_ctor_set(x_417, 0, x_411); -lean_ctor_set(x_417, 1, x_401); -lean_ctor_set(x_417, 2, x_412); -lean_ctor_set(x_417, 3, x_413); -lean_ctor_set(x_417, 4, x_414); -lean_ctor_set(x_417, 5, x_415); -if (lean_obj_tag(x_409) == 0) -{ -lean_dec(x_414); -lean_dec(x_369); -lean_dec(x_359); -lean_dec(x_358); -lean_dec(x_357); -lean_dec(x_356); -lean_dec(x_355); -x_379 = x_409; -x_380 = x_417; -goto block_399; -} -else -{ -lean_object* x_418; lean_object* x_419; lean_object* x_420; uint8_t x_444; -x_418 = lean_ctor_get(x_409, 0); +x_416 = lean_ctor_get(x_413, 3); +lean_inc(x_416); +x_417 = lean_ctor_get(x_413, 4); +lean_inc(x_417); +x_418 = lean_ctor_get(x_413, 5); lean_inc(x_418); -if (lean_is_exclusive(x_409)) { - lean_ctor_release(x_409, 0); - x_419 = x_409; +if (lean_is_exclusive(x_413)) { + lean_ctor_release(x_413, 0); + lean_ctor_release(x_413, 1); + lean_ctor_release(x_413, 2); + lean_ctor_release(x_413, 3); + lean_ctor_release(x_413, 4); + lean_ctor_release(x_413, 5); + x_419 = x_413; } else { - lean_dec_ref(x_409); + lean_dec_ref(x_413); x_419 = lean_box(0); } -x_444 = lean_ctor_get_uint8(x_414, sizeof(void*)*1); -lean_dec(x_414); -if (x_444 == 0) -{ -x_420 = x_417; -goto block_443; -} -else -{ -lean_object* x_445; lean_object* x_446; lean_object* x_447; uint8_t x_448; -x_445 = l_Lean_Meta_SynthInstance_getInstances___lambda__1___closed__1; -x_446 = l___private_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_445, x_369, x_417); -x_447 = lean_ctor_get(x_446, 0); -lean_inc(x_447); -x_448 = lean_unbox(x_447); -lean_dec(x_447); -if (x_448 == 0) -{ -lean_object* x_449; -x_449 = lean_ctor_get(x_446, 1); -lean_inc(x_449); -lean_dec(x_446); -x_420 = x_449; -goto block_443; -} -else -{ -lean_object* x_450; lean_object* x_451; lean_object* x_452; lean_object* x_453; lean_object* x_454; lean_object* x_455; -x_450 = lean_ctor_get(x_446, 1); -lean_inc(x_450); -lean_dec(x_446); -lean_inc(x_418); -x_451 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_451, 0, x_418); -x_452 = l_Lean_Meta_synthInstance_x3f___closed__3; -x_453 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_453, 0, x_452); -lean_ctor_set(x_453, 1, x_451); -x_454 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_445, x_453, x_369, x_450); -x_455 = lean_ctor_get(x_454, 1); -lean_inc(x_455); -lean_dec(x_454); -x_420 = x_455; -goto block_443; -} -} -block_443: -{ -lean_object* x_421; -lean_inc(x_369); -lean_inc(x_418); -x_421 = l_Lean_Meta_inferType(x_418, x_369, x_420); -if (lean_obj_tag(x_421) == 0) -{ -lean_object* x_422; lean_object* x_423; lean_object* x_424; lean_object* x_425; -x_422 = lean_ctor_get(x_421, 0); -lean_inc(x_422); -x_423 = lean_ctor_get(x_421, 1); -lean_inc(x_423); -lean_dec(x_421); -x_424 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_424, 0, x_355); -lean_ctor_set(x_424, 1, x_356); -lean_ctor_set(x_424, 2, x_357); -lean_ctor_set(x_424, 3, x_358); -lean_ctor_set(x_424, 4, x_359); -lean_inc(x_376); -x_425 = l_Lean_Meta_isExprDefEq(x_376, x_422, x_424, x_423); -if (lean_obj_tag(x_425) == 0) -{ -lean_object* x_426; uint8_t x_427; -x_426 = lean_ctor_get(x_425, 0); -lean_inc(x_426); -x_427 = lean_unbox(x_426); -lean_dec(x_426); -if (x_427 == 0) -{ -lean_object* x_428; lean_object* x_429; -lean_dec(x_419); -lean_dec(x_418); -lean_dec(x_369); -x_428 = lean_ctor_get(x_425, 1); -lean_inc(x_428); -lean_dec(x_425); -x_429 = lean_box(0); -x_379 = x_429; -x_380 = x_428; -goto block_399; -} -else -{ -lean_object* x_430; lean_object* x_431; lean_object* x_432; lean_object* x_433; lean_object* x_434; -x_430 = lean_ctor_get(x_425, 1); -lean_inc(x_430); -lean_dec(x_425); -x_431 = l_Lean_Meta_instantiateMVars(x_418, x_369, x_430); -lean_dec(x_369); -x_432 = lean_ctor_get(x_431, 0); -lean_inc(x_432); -x_433 = lean_ctor_get(x_431, 1); -lean_inc(x_433); -lean_dec(x_431); +lean_inc(x_417); if (lean_is_scalar(x_419)) { - x_434 = lean_alloc_ctor(1, 1, 0); + x_420 = lean_alloc_ctor(0, 6, 0); } else { - x_434 = x_419; + x_420 = x_419; } -lean_ctor_set(x_434, 0, x_432); -x_379 = x_434; -x_380 = x_433; -goto block_399; -} -} -else +lean_ctor_set(x_420, 0, x_414); +lean_ctor_set(x_420, 1, x_404); +lean_ctor_set(x_420, 2, x_415); +lean_ctor_set(x_420, 3, x_416); +lean_ctor_set(x_420, 4, x_417); +lean_ctor_set(x_420, 5, x_418); +if (lean_obj_tag(x_412) == 0) { -lean_object* x_435; lean_object* x_436; lean_object* x_437; lean_object* x_438; -lean_dec(x_419); -lean_dec(x_418); -lean_dec(x_378); -lean_dec(x_376); -lean_dec(x_369); -x_435 = lean_ctor_get(x_425, 0); -lean_inc(x_435); -x_436 = lean_ctor_get(x_425, 1); -lean_inc(x_436); -if (lean_is_exclusive(x_425)) { - lean_ctor_release(x_425, 0); - lean_ctor_release(x_425, 1); - x_437 = x_425; -} else { - lean_dec_ref(x_425); - x_437 = lean_box(0); -} -if (lean_is_scalar(x_437)) { - x_438 = lean_alloc_ctor(1, 2, 0); -} else { - x_438 = x_437; -} -lean_ctor_set(x_438, 0, x_435); -lean_ctor_set(x_438, 1, x_436); -return x_438; -} -} -else -{ -lean_object* x_439; lean_object* x_440; lean_object* x_441; lean_object* x_442; -lean_dec(x_419); -lean_dec(x_418); -lean_dec(x_378); -lean_dec(x_376); -lean_dec(x_369); +lean_dec(x_417); +lean_dec(x_371); +lean_dec(x_361); +lean_dec(x_360); lean_dec(x_359); lean_dec(x_358); lean_dec(x_357); -lean_dec(x_356); -lean_dec(x_355); -x_439 = lean_ctor_get(x_421, 0); -lean_inc(x_439); -x_440 = lean_ctor_get(x_421, 1); -lean_inc(x_440); -if (lean_is_exclusive(x_421)) { - lean_ctor_release(x_421, 0); - lean_ctor_release(x_421, 1); - x_441 = x_421; -} else { - lean_dec_ref(x_421); - x_441 = lean_box(0); +x_381 = x_412; +x_382 = x_420; +goto block_402; } -if (lean_is_scalar(x_441)) { - x_442 = lean_alloc_ctor(1, 2, 0); -} else { - x_442 = x_441; -} -lean_ctor_set(x_442, 0, x_439); -lean_ctor_set(x_442, 1, x_440); -return x_442; -} -} -} -} -block_467: +else { -lean_object* x_459; lean_object* x_460; lean_object* x_461; lean_object* x_462; lean_object* x_463; lean_object* x_464; lean_object* x_465; lean_object* x_466; -x_459 = lean_ctor_get(x_458, 0); -lean_inc(x_459); -x_460 = lean_ctor_get(x_458, 2); -lean_inc(x_460); -x_461 = lean_ctor_get(x_458, 3); -lean_inc(x_461); -x_462 = lean_ctor_get(x_458, 4); -lean_inc(x_462); -x_463 = lean_ctor_get(x_458, 5); -lean_inc(x_463); -if (lean_is_exclusive(x_458)) { - lean_ctor_release(x_458, 0); - lean_ctor_release(x_458, 1); - lean_ctor_release(x_458, 2); - lean_ctor_release(x_458, 3); - lean_ctor_release(x_458, 4); - lean_ctor_release(x_458, 5); - x_464 = x_458; +lean_object* x_421; lean_object* x_422; lean_object* x_423; uint8_t x_447; +x_421 = lean_ctor_get(x_412, 0); +lean_inc(x_421); +if (lean_is_exclusive(x_412)) { + lean_ctor_release(x_412, 0); + x_422 = x_412; } else { - lean_dec_ref(x_458); - x_464 = lean_box(0); + lean_dec_ref(x_412); + x_422 = lean_box(0); } -if (lean_is_scalar(x_464)) { - x_465 = lean_alloc_ctor(0, 6, 0); +x_447 = lean_ctor_get_uint8(x_417, sizeof(void*)*1); +lean_dec(x_417); +if (x_447 == 0) +{ +x_423 = x_420; +goto block_446; +} +else +{ +lean_object* x_448; lean_object* x_449; lean_object* x_450; uint8_t x_451; +x_448 = l_Lean_Meta_SynthInstance_getInstances___lambda__1___closed__1; +x_449 = l___private_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_448, x_371, x_420); +x_450 = lean_ctor_get(x_449, 0); +lean_inc(x_450); +x_451 = lean_unbox(x_450); +lean_dec(x_450); +if (x_451 == 0) +{ +lean_object* x_452; +x_452 = lean_ctor_get(x_449, 1); +lean_inc(x_452); +lean_dec(x_449); +x_423 = x_452; +goto block_446; +} +else +{ +lean_object* x_453; lean_object* x_454; lean_object* x_455; lean_object* x_456; lean_object* x_457; lean_object* x_458; +x_453 = lean_ctor_get(x_449, 1); +lean_inc(x_453); +lean_dec(x_449); +lean_inc(x_421); +x_454 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_454, 0, x_421); +x_455 = l_Lean_Meta_synthInstance_x3f___closed__3; +x_456 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_456, 0, x_455); +lean_ctor_set(x_456, 1, x_454); +x_457 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_448, x_456, x_371, x_453); +x_458 = lean_ctor_get(x_457, 1); +lean_inc(x_458); +lean_dec(x_457); +x_423 = x_458; +goto block_446; +} +} +block_446: +{ +lean_object* x_424; +lean_inc(x_371); +lean_inc(x_421); +x_424 = l_Lean_Meta_inferType(x_421, x_371, x_423); +if (lean_obj_tag(x_424) == 0) +{ +lean_object* x_425; lean_object* x_426; lean_object* x_427; lean_object* x_428; +x_425 = lean_ctor_get(x_424, 0); +lean_inc(x_425); +x_426 = lean_ctor_get(x_424, 1); +lean_inc(x_426); +lean_dec(x_424); +x_427 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_427, 0, x_357); +lean_ctor_set(x_427, 1, x_358); +lean_ctor_set(x_427, 2, x_359); +lean_ctor_set(x_427, 3, x_360); +lean_ctor_set(x_427, 4, x_361); +lean_inc(x_378); +x_428 = l_Lean_Meta_isExprDefEq(x_378, x_425, x_427, x_426); +if (lean_obj_tag(x_428) == 0) +{ +lean_object* x_429; uint8_t x_430; +x_429 = lean_ctor_get(x_428, 0); +lean_inc(x_429); +x_430 = lean_unbox(x_429); +lean_dec(x_429); +if (x_430 == 0) +{ +lean_object* x_431; lean_object* x_432; +lean_dec(x_422); +lean_dec(x_421); +lean_dec(x_371); +x_431 = lean_ctor_get(x_428, 1); +lean_inc(x_431); +lean_dec(x_428); +x_432 = lean_box(0); +x_381 = x_432; +x_382 = x_431; +goto block_402; +} +else +{ +lean_object* x_433; lean_object* x_434; lean_object* x_435; lean_object* x_436; lean_object* x_437; +x_433 = lean_ctor_get(x_428, 1); +lean_inc(x_433); +lean_dec(x_428); +x_434 = l_Lean_Meta_instantiateMVars(x_421, x_371, x_433); +lean_dec(x_371); +x_435 = lean_ctor_get(x_434, 0); +lean_inc(x_435); +x_436 = lean_ctor_get(x_434, 1); +lean_inc(x_436); +lean_dec(x_434); +if (lean_is_scalar(x_422)) { + x_437 = lean_alloc_ctor(1, 1, 0); } else { - x_465 = x_464; + x_437 = x_422; } -lean_ctor_set(x_465, 0, x_459); -lean_ctor_set(x_465, 1, x_401); -lean_ctor_set(x_465, 2, x_460); -lean_ctor_set(x_465, 3, x_461); -lean_ctor_set(x_465, 4, x_462); -lean_ctor_set(x_465, 5, x_463); -if (lean_is_scalar(x_373)) { - x_466 = lean_alloc_ctor(1, 2, 0); -} else { - x_466 = x_373; - lean_ctor_set_tag(x_466, 1); -} -lean_ctor_set(x_466, 0, x_457); -lean_ctor_set(x_466, 1, x_465); -return x_466; +lean_ctor_set(x_437, 0, x_435); +x_381 = x_437; +x_382 = x_436; +goto block_402; } } else { -lean_object* x_525; lean_object* x_526; +lean_object* x_438; lean_object* x_439; lean_object* x_440; lean_object* x_441; +lean_dec(x_422); +lean_dec(x_421); +lean_dec(x_380); +lean_dec(x_378); +lean_dec(x_371); +x_438 = lean_ctor_get(x_428, 0); +lean_inc(x_438); +x_439 = lean_ctor_get(x_428, 1); +lean_inc(x_439); +if (lean_is_exclusive(x_428)) { + lean_ctor_release(x_428, 0); + lean_ctor_release(x_428, 1); + x_440 = x_428; +} else { + lean_dec_ref(x_428); + x_440 = lean_box(0); +} +if (lean_is_scalar(x_440)) { + x_441 = lean_alloc_ctor(1, 2, 0); +} else { + x_441 = x_440; +} +lean_ctor_set(x_441, 0, x_438); +lean_ctor_set(x_441, 1, x_439); +return x_441; +} +} +else +{ +lean_object* x_442; lean_object* x_443; lean_object* x_444; lean_object* x_445; +lean_dec(x_422); +lean_dec(x_421); +lean_dec(x_380); +lean_dec(x_378); +lean_dec(x_371); +lean_dec(x_361); +lean_dec(x_360); +lean_dec(x_359); +lean_dec(x_358); +lean_dec(x_357); +x_442 = lean_ctor_get(x_424, 0); +lean_inc(x_442); +x_443 = lean_ctor_get(x_424, 1); +lean_inc(x_443); +if (lean_is_exclusive(x_424)) { + lean_ctor_release(x_424, 0); + lean_ctor_release(x_424, 1); + x_444 = x_424; +} else { + lean_dec_ref(x_424); + x_444 = lean_box(0); +} +if (lean_is_scalar(x_444)) { + x_445 = lean_alloc_ctor(1, 2, 0); +} else { + x_445 = x_444; +} +lean_ctor_set(x_445, 0, x_442); +lean_ctor_set(x_445, 1, x_443); +return x_445; +} +} +} +} +block_470: +{ +lean_object* x_462; lean_object* x_463; lean_object* x_464; lean_object* x_465; lean_object* x_466; lean_object* x_467; lean_object* x_468; lean_object* x_469; +x_462 = lean_ctor_get(x_461, 0); +lean_inc(x_462); +x_463 = lean_ctor_get(x_461, 2); +lean_inc(x_463); +x_464 = lean_ctor_get(x_461, 3); +lean_inc(x_464); +x_465 = lean_ctor_get(x_461, 4); +lean_inc(x_465); +x_466 = lean_ctor_get(x_461, 5); +lean_inc(x_466); +if (lean_is_exclusive(x_461)) { + lean_ctor_release(x_461, 0); + lean_ctor_release(x_461, 1); + lean_ctor_release(x_461, 2); + lean_ctor_release(x_461, 3); + lean_ctor_release(x_461, 4); + lean_ctor_release(x_461, 5); + x_467 = x_461; +} else { + lean_dec_ref(x_461); + x_467 = lean_box(0); +} +if (lean_is_scalar(x_467)) { + x_468 = lean_alloc_ctor(0, 6, 0); +} else { + x_468 = x_467; +} +lean_ctor_set(x_468, 0, x_462); +lean_ctor_set(x_468, 1, x_404); +lean_ctor_set(x_468, 2, x_463); +lean_ctor_set(x_468, 3, x_464); +lean_ctor_set(x_468, 4, x_465); +lean_ctor_set(x_468, 5, x_466); +if (lean_is_scalar(x_375)) { + x_469 = lean_alloc_ctor(1, 2, 0); +} else { + x_469 = x_375; + lean_ctor_set_tag(x_469, 1); +} +lean_ctor_set(x_469, 0, x_460); +lean_ctor_set(x_469, 1, x_468); +return x_469; +} +} +else +{ +lean_object* x_528; lean_object* x_529; +lean_dec(x_408); +lean_dec(x_407); +lean_dec(x_406); lean_dec(x_405); lean_dec(x_404); lean_dec(x_403); -lean_dec(x_402); -lean_dec(x_401); -lean_dec(x_400); +lean_dec(x_380); lean_dec(x_378); -lean_dec(x_376); -lean_dec(x_369); -lean_dec(x_365); +lean_dec(x_371); +lean_dec(x_367); +lean_dec(x_361); +lean_dec(x_360); lean_dec(x_359); lean_dec(x_358); lean_dec(x_357); -lean_dec(x_356); -lean_dec(x_355); -x_525 = lean_ctor_get(x_407, 0); -lean_inc(x_525); -lean_dec(x_407); -if (lean_is_scalar(x_373)) { - x_526 = lean_alloc_ctor(0, 2, 0); +x_528 = lean_ctor_get(x_410, 0); +lean_inc(x_528); +lean_dec(x_410); +if (lean_is_scalar(x_375)) { + x_529 = lean_alloc_ctor(0, 2, 0); } else { - x_526 = x_373; + x_529 = x_375; } -lean_ctor_set(x_526, 0, x_525); -lean_ctor_set(x_526, 1, x_377); -return x_526; +lean_ctor_set(x_529, 0, x_528); +lean_ctor_set(x_529, 1, x_379); +return x_529; } -block_399: +block_402: { -uint8_t x_381; -x_381 = l_Lean_Expr_hasMVar(x_376); -if (x_381 == 0) +uint8_t x_383; +x_383 = l_Lean_Expr_hasMVar(x_378); +if (x_383 == 0) { -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; lean_object* x_391; lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; -x_382 = lean_ctor_get(x_380, 2); -lean_inc(x_382); -x_383 = lean_ctor_get(x_380, 0); -lean_inc(x_383); -x_384 = lean_ctor_get(x_380, 1); +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; lean_object* x_391; lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; lean_object* x_400; +x_384 = lean_ctor_get(x_382, 2); lean_inc(x_384); -x_385 = lean_ctor_get(x_380, 3); +x_385 = lean_ctor_get(x_382, 0); lean_inc(x_385); -x_386 = lean_ctor_get(x_380, 4); +x_386 = lean_ctor_get(x_382, 1); lean_inc(x_386); -x_387 = lean_ctor_get(x_380, 5); +x_387 = lean_ctor_get(x_382, 3); lean_inc(x_387); -if (lean_is_exclusive(x_380)) { - lean_ctor_release(x_380, 0); - lean_ctor_release(x_380, 1); - lean_ctor_release(x_380, 2); - lean_ctor_release(x_380, 3); - lean_ctor_release(x_380, 4); - lean_ctor_release(x_380, 5); - x_388 = x_380; -} else { - lean_dec_ref(x_380); - x_388 = lean_box(0); -} -x_389 = lean_ctor_get(x_382, 0); +x_388 = lean_ctor_get(x_382, 4); +lean_inc(x_388); +x_389 = lean_ctor_get(x_382, 5); lean_inc(x_389); -x_390 = lean_ctor_get(x_382, 1); -lean_inc(x_390); -x_391 = lean_ctor_get(x_382, 2); -lean_inc(x_391); -x_392 = lean_ctor_get(x_382, 3); -lean_inc(x_392); if (lean_is_exclusive(x_382)) { lean_ctor_release(x_382, 0); lean_ctor_release(x_382, 1); lean_ctor_release(x_382, 2); lean_ctor_release(x_382, 3); - x_393 = x_382; + lean_ctor_release(x_382, 4); + lean_ctor_release(x_382, 5); + x_390 = x_382; } else { lean_dec_ref(x_382); - x_393 = lean_box(0); + x_390 = lean_box(0); } -lean_inc(x_379); -x_394 = l_Std_PersistentHashMap_insert___at_Lean_Meta_synthInstance_x3f___spec__1(x_391, x_376, x_379); -if (lean_is_scalar(x_393)) { - x_395 = lean_alloc_ctor(0, 4, 0); +x_391 = lean_ctor_get(x_384, 0); +lean_inc(x_391); +x_392 = lean_ctor_get(x_384, 1); +lean_inc(x_392); +x_393 = lean_ctor_get(x_384, 2); +lean_inc(x_393); +x_394 = lean_ctor_get(x_384, 3); +lean_inc(x_394); +x_395 = lean_ctor_get(x_384, 4); +lean_inc(x_395); +if (lean_is_exclusive(x_384)) { + lean_ctor_release(x_384, 0); + lean_ctor_release(x_384, 1); + lean_ctor_release(x_384, 2); + lean_ctor_release(x_384, 3); + lean_ctor_release(x_384, 4); + x_396 = x_384; } else { - x_395 = x_393; + lean_dec_ref(x_384); + x_396 = lean_box(0); } -lean_ctor_set(x_395, 0, x_389); -lean_ctor_set(x_395, 1, x_390); -lean_ctor_set(x_395, 2, x_394); -lean_ctor_set(x_395, 3, x_392); -if (lean_is_scalar(x_388)) { - x_396 = lean_alloc_ctor(0, 6, 0); +lean_inc(x_381); +x_397 = l_Std_PersistentHashMap_insert___at_Lean_Meta_synthInstance_x3f___spec__1(x_393, x_378, x_381); +if (lean_is_scalar(x_396)) { + x_398 = lean_alloc_ctor(0, 5, 0); } else { - x_396 = x_388; + x_398 = x_396; } -lean_ctor_set(x_396, 0, x_383); -lean_ctor_set(x_396, 1, x_384); -lean_ctor_set(x_396, 2, x_395); -lean_ctor_set(x_396, 3, x_385); -lean_ctor_set(x_396, 4, x_386); -lean_ctor_set(x_396, 5, x_387); -if (lean_is_scalar(x_378)) { - x_397 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_398, 0, x_391); +lean_ctor_set(x_398, 1, x_392); +lean_ctor_set(x_398, 2, x_397); +lean_ctor_set(x_398, 3, x_394); +lean_ctor_set(x_398, 4, x_395); +if (lean_is_scalar(x_390)) { + x_399 = lean_alloc_ctor(0, 6, 0); } else { - x_397 = x_378; + x_399 = x_390; } -lean_ctor_set(x_397, 0, x_379); -lean_ctor_set(x_397, 1, x_396); -return x_397; +lean_ctor_set(x_399, 0, x_385); +lean_ctor_set(x_399, 1, x_386); +lean_ctor_set(x_399, 2, x_398); +lean_ctor_set(x_399, 3, x_387); +lean_ctor_set(x_399, 4, x_388); +lean_ctor_set(x_399, 5, x_389); +if (lean_is_scalar(x_380)) { + x_400 = lean_alloc_ctor(0, 2, 0); +} else { + x_400 = x_380; +} +lean_ctor_set(x_400, 0, x_381); +lean_ctor_set(x_400, 1, x_399); +return x_400; } else { -lean_object* x_398; -lean_dec(x_376); -if (lean_is_scalar(x_378)) { - x_398 = lean_alloc_ctor(0, 2, 0); +lean_object* x_401; +lean_dec(x_378); +if (lean_is_scalar(x_380)) { + x_401 = lean_alloc_ctor(0, 2, 0); } else { - x_398 = x_378; + x_401 = x_380; } -lean_ctor_set(x_398, 0, x_379); -lean_ctor_set(x_398, 1, x_380); -return x_398; +lean_ctor_set(x_401, 0, x_381); +lean_ctor_set(x_401, 1, x_382); +return x_401; } } } else { -lean_object* x_527; lean_object* x_528; lean_object* x_529; lean_object* x_530; -lean_dec(x_373); -lean_dec(x_369); -lean_dec(x_365); +lean_object* x_530; lean_object* x_531; lean_object* x_532; lean_object* x_533; +lean_dec(x_375); +lean_dec(x_371); +lean_dec(x_367); +lean_dec(x_361); +lean_dec(x_360); lean_dec(x_359); lean_dec(x_358); lean_dec(x_357); -lean_dec(x_356); -lean_dec(x_355); -x_527 = lean_ctor_get(x_375, 0); -lean_inc(x_527); -x_528 = lean_ctor_get(x_375, 1); -lean_inc(x_528); -if (lean_is_exclusive(x_375)) { - lean_ctor_release(x_375, 0); - lean_ctor_release(x_375, 1); - x_529 = x_375; +x_530 = lean_ctor_get(x_377, 0); +lean_inc(x_530); +x_531 = lean_ctor_get(x_377, 1); +lean_inc(x_531); +if (lean_is_exclusive(x_377)) { + lean_ctor_release(x_377, 0); + lean_ctor_release(x_377, 1); + x_532 = x_377; } else { - lean_dec_ref(x_375); - x_529 = lean_box(0); + lean_dec_ref(x_377); + x_532 = lean_box(0); } -if (lean_is_scalar(x_529)) { - x_530 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_532)) { + x_533 = lean_alloc_ctor(1, 2, 0); } else { - x_530 = x_529; + x_533 = x_532; } -lean_ctor_set(x_530, 0, x_527); -lean_ctor_set(x_530, 1, x_528); -return x_530; +lean_ctor_set(x_533, 0, x_530); +lean_ctor_set(x_533, 1, x_531); +return x_533; } } } diff --git a/stage0/stdlib/Lean/Meta/Tactic/Cases.c b/stage0/stdlib/Lean/Meta/Tactic/Cases.c index 8c51b3a66d..c613b12a13 100644 --- a/stage0/stdlib/Lean/Meta/Tactic/Cases.c +++ b/stage0/stdlib/Lean/Meta/Tactic/Cases.c @@ -25,6 +25,7 @@ lean_object* l_Lean_Expr_withAppAux___main___at_Lean_Meta_generalizeIndices___sp extern lean_object* l_Lean_Expr_eq_x3f___closed__2; lean_object* l_Lean_Expr_mvarId_x21(lean_object*); lean_object* l___private_Lean_Meta_Tactic_Cases_5__hasIndepIndices(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_registerTraceClass(lean_object*, lean_object*); lean_object* l___private_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main___closed__1; lean_object* lean_mk_empty_array_with_capacity(lean_object*); lean_object* l___private_Lean_Meta_Tactic_Cases_2__withNewIndexEqsAux___main(lean_object*); @@ -81,7 +82,6 @@ lean_object* l_Nat_anyAux___main___at___private_Lean_Meta_Tactic_Cases_5__hasInd lean_object* l_Array_umapMAux___main___at___private_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main___spec__2(lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_MetavarContext_8__dep___main___at___private_Lean_Meta_Tactic_Cases_5__hasIndepIndices___spec__36(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Expr_appFn_x21(lean_object*); -extern lean_object* l___private_Lean_Meta_Basic_11__regTraceClasses___closed__2; lean_object* l_Std_PersistentArray_anyMAux___main___at___private_Lean_Meta_Tactic_Cases_5__hasIndepIndices___spec__14___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_array_push(lean_object*, lean_object*); lean_object* lean_array_get_size(lean_object*); @@ -277,6 +277,7 @@ lean_object* l_Array_umapMAux___main___at___private_Lean_Meta_Tactic_Cases_8__un uint8_t l_Array_anyRangeMAux___main___at___private_Lean_Meta_Tactic_Cases_5__hasIndepIndices___spec__10(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Meta_Tactic_Cases_9__unifyEqs___boxed(lean_object*, lean_object*, lean_object*, lean_object*); uint8_t l_Array_anyRangeMAux___main___at___private_Lean_Meta_Tactic_Cases_5__hasIndepIndices___spec__44(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +extern lean_object* l___private_Lean_Meta_Tactic_Util_1__regTraceClasses___closed__2; lean_object* l_Array_umapMAux___main___at___private_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main___spec__9___boxed(lean_object*, lean_object*, lean_object*); uint8_t l_Array_anyRangeMAux___main___at___private_Lean_Meta_Tactic_Cases_5__hasIndepIndices___spec__45(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Expr_withAppAux___main___at___private_Lean_Meta_Tactic_Cases_4__mkCasesContext_x3f___spec__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); @@ -310,6 +311,7 @@ uint8_t l_Std_PersistentArray_anyMAux___main___at___private_Lean_Meta_Tactic_Cas lean_object* l_Array_umapMAux___main___at___private_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main___spec__3___boxed(lean_object*, lean_object*, lean_object*); uint8_t lean_nat_dec_lt(lean_object*, lean_object*); lean_object* l_Lean_Meta_cases___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Meta_Tactic_Cases_10__regTraceClasses(lean_object*); lean_object* l___private_Lean_Meta_Tactic_Cases_1__mkEqAndProof(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { @@ -12675,7 +12677,7 @@ lean_object* _init_l___private_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main___cl _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; -x_1 = l___private_Lean_Meta_Basic_11__regTraceClasses___closed__2; +x_1 = l___private_Lean_Meta_Tactic_Util_1__regTraceClasses___closed__2; x_2 = l___private_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main___lambda__1___closed__1; x_3 = lean_name_mk_string(x_1, x_2); return x_3; @@ -13930,6 +13932,15 @@ lean_dec(x_5); return x_8; } } +lean_object* l___private_Lean_Meta_Tactic_Cases_10__regTraceClasses(lean_object* x_1) { +_start: +{ +lean_object* x_2; lean_object* x_3; +x_2 = l___private_Lean_Meta_Tactic_Cases_8__unifyEqsAux___main___closed__1; +x_3 = l_Lean_registerTraceClass(x_2, x_1); +return x_3; +} +} lean_object* initialize_Init(lean_object*); lean_object* initialize_Lean_Meta_AppBuilder(lean_object*); lean_object* initialize_Lean_Meta_Tactic_Induction(lean_object*); @@ -14019,6 +14030,9 @@ l_Lean_Meta_Cases_cases___lambda__1___closed__6 = _init_l_Lean_Meta_Cases_cases_ lean_mark_persistent(l_Lean_Meta_Cases_cases___lambda__1___closed__6); l_Lean_Meta_Cases_cases___lambda__1___closed__7 = _init_l_Lean_Meta_Cases_cases___lambda__1___closed__7(); lean_mark_persistent(l_Lean_Meta_Cases_cases___lambda__1___closed__7); +res = l___private_Lean_Meta_Tactic_Cases_10__regTraceClasses(lean_io_mk_world()); +if (lean_io_result_is_error(res)) return res; +lean_dec_ref(res); return lean_mk_io_result(lean_box(0)); } #ifdef __cplusplus diff --git a/stage0/stdlib/Lean/Meta/Tactic/FVarSubst.c b/stage0/stdlib/Lean/Meta/Tactic/FVarSubst.c index 2917931818..0997614290 100644 --- a/stage0/stdlib/Lean/Meta/Tactic/FVarSubst.c +++ b/stage0/stdlib/Lean/Meta/Tactic/FVarSubst.c @@ -1,6 +1,6 @@ // Lean compiler output // Module: Lean.Meta.Tactic.FVarSubst -// Imports: Init Lean.Expr Lean.Util.ReplaceExpr +// Imports: Init Lean.Expr Lean.LocalContext Lean.Util.ReplaceExpr #include #if defined(__clang__) #pragma clang diagnostic ignored "-Wunused-parameter" @@ -15,6 +15,7 @@ extern "C" { #endif lean_object* lean_expr_update_forall(lean_object*, uint8_t, lean_object*, lean_object*); lean_object* l_Lean_Meta_FVarSubst_apply___boxed(lean_object*, lean_object*); +lean_object* l_Std_RBNode_fold___main___at_Lean_Meta_FVarSubst_domain___spec__1___boxed(lean_object*, lean_object*); lean_object* l_unreachable_x21___rarg(lean_object*); uint8_t l_USize_decEq(size_t, size_t); lean_object* lean_array_uget(lean_object*, size_t); @@ -22,12 +23,16 @@ lean_object* lean_expr_update_mdata(lean_object*, lean_object*); uint8_t l_Lean_Name_quickLt(lean_object*, lean_object*); lean_object* l_Lean_Meta_FVarSubst_erase(lean_object*, lean_object*); lean_object* lean_array_uset(lean_object*, size_t, lean_object*); +lean_object* l_Lean_Meta_FVarSubst_domain(lean_object*); lean_object* l_Std_RBNode_find___main___at_Lean_Meta_FVarSubst_get___spec__1___boxed(lean_object*, lean_object*); +lean_object* l_Lean_Expr_applyFVarSubst___boxed(lean_object*, lean_object*); +lean_object* l_Lean_Meta_FVarSubst_domain___boxed(lean_object*); uint8_t l_Lean_NameMap_contains___rarg(lean_object*, lean_object*); lean_object* l_Std_RBNode_erase___at_Lean_Meta_FVarSubst_erase___spec__1(lean_object*, lean_object*); lean_object* l_Std_RBNode_del___main___at_Lean_Meta_FVarSubst_erase___spec__2(lean_object*, lean_object*); lean_object* l_Std_RBNode_fold___main___at_Lean_Meta_FVarSubst_compose___spec__1(lean_object*, lean_object*); lean_object* l_Std_RBNode_setBlack___rarg(lean_object*); +lean_object* l_Std_RBNode_fold___main___at_Lean_Meta_FVarSubst_domain___spec__1(lean_object*, lean_object*); lean_object* l_Lean_Meta_FVarSubst_apply(lean_object*, lean_object*); lean_object* l_Std_RBNode_balRight___rarg(lean_object*, lean_object*, lean_object*, lean_object*); uint8_t l_Std_RBNode_isBlack___rarg(lean_object*); @@ -41,6 +46,7 @@ lean_object* l_Std_RBNode_appendTrees___main___rarg(lean_object*, lean_object*); lean_object* lean_expr_update_let(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_mkFVar(lean_object*); uint8_t l_Lean_Expr_Data_binderInfo(uint64_t); +lean_object* l_Lean_LocalDecl_applyFVarSubst___boxed(lean_object*, lean_object*); lean_object* l_Lean_Meta_FVarSubst_contains___boxed(lean_object*, lean_object*); lean_object* lean_expr_update_proj(lean_object*, lean_object*); lean_object* l_Std_RBNode_erase___at_Lean_Meta_FVarSubst_erase___spec__1___boxed(lean_object*, lean_object*); @@ -56,8 +62,10 @@ lean_object* l_Lean_Meta_FVarSubst_erase___boxed(lean_object*, lean_object*); lean_object* l_Std_RBNode_del___main___at_Lean_Meta_FVarSubst_erase___spec__2___boxed(lean_object*, lean_object*); lean_object* lean_expr_update_app(lean_object*, lean_object*, lean_object*); uint8_t l_Lean_Expr_hasFVar(lean_object*); +lean_object* l_Lean_LocalDecl_applyFVarSubst(lean_object*, lean_object*); lean_object* l_Lean_Expr_ReplaceImpl_replaceUnsafeM___main___at_Lean_Meta_FVarSubst_apply___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Expr_ReplaceImpl_initCache; +lean_object* l_Lean_Expr_applyFVarSubst(lean_object*, lean_object*); lean_object* _init_l_Lean_Meta_FVarSubst_empty() { _start: { @@ -992,8 +1000,166 @@ return x_3; } } } +lean_object* l_Std_RBNode_fold___main___at_Lean_Meta_FVarSubst_domain___spec__1(lean_object* x_1, lean_object* x_2) { +_start: +{ +if (lean_obj_tag(x_2) == 0) +{ +return x_1; +} +else +{ +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_2, 0); +x_4 = lean_ctor_get(x_2, 1); +x_5 = lean_ctor_get(x_2, 3); +x_6 = l_Std_RBNode_fold___main___at_Lean_Meta_FVarSubst_domain___spec__1(x_1, x_3); +lean_inc(x_4); +x_7 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_7, 0, x_4); +lean_ctor_set(x_7, 1, x_6); +x_1 = x_7; +x_2 = x_5; +goto _start; +} +} +} +lean_object* l_Lean_Meta_FVarSubst_domain(lean_object* x_1) { +_start: +{ +lean_object* x_2; lean_object* x_3; +x_2 = lean_box(0); +x_3 = l_Std_RBNode_fold___main___at_Lean_Meta_FVarSubst_domain___spec__1(x_2, x_1); +return x_3; +} +} +lean_object* l_Std_RBNode_fold___main___at_Lean_Meta_FVarSubst_domain___spec__1___boxed(lean_object* x_1, lean_object* x_2) { +_start: +{ +lean_object* x_3; +x_3 = l_Std_RBNode_fold___main___at_Lean_Meta_FVarSubst_domain___spec__1(x_1, x_2); +lean_dec(x_2); +return x_3; +} +} +lean_object* l_Lean_Meta_FVarSubst_domain___boxed(lean_object* x_1) { +_start: +{ +lean_object* x_2; +x_2 = l_Lean_Meta_FVarSubst_domain(x_1); +lean_dec(x_1); +return x_2; +} +} +lean_object* l_Lean_LocalDecl_applyFVarSubst(lean_object* x_1, lean_object* x_2) { +_start: +{ +if (lean_obj_tag(x_2) == 0) +{ +uint8_t x_3; +x_3 = !lean_is_exclusive(x_2); +if (x_3 == 0) +{ +lean_object* x_4; lean_object* x_5; +x_4 = lean_ctor_get(x_2, 3); +x_5 = l_Lean_Meta_FVarSubst_apply(x_1, x_4); +lean_ctor_set(x_2, 3, x_5); +return x_2; +} +else +{ +lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; uint8_t x_10; lean_object* x_11; lean_object* x_12; +x_6 = lean_ctor_get(x_2, 0); +x_7 = lean_ctor_get(x_2, 1); +x_8 = lean_ctor_get(x_2, 2); +x_9 = lean_ctor_get(x_2, 3); +x_10 = lean_ctor_get_uint8(x_2, sizeof(void*)*4); +lean_inc(x_9); +lean_inc(x_8); +lean_inc(x_7); +lean_inc(x_6); +lean_dec(x_2); +x_11 = l_Lean_Meta_FVarSubst_apply(x_1, x_9); +x_12 = lean_alloc_ctor(0, 4, 1); +lean_ctor_set(x_12, 0, x_6); +lean_ctor_set(x_12, 1, x_7); +lean_ctor_set(x_12, 2, x_8); +lean_ctor_set(x_12, 3, x_11); +lean_ctor_set_uint8(x_12, sizeof(void*)*4, x_10); +return x_12; +} +} +else +{ +uint8_t x_13; +x_13 = !lean_is_exclusive(x_2); +if (x_13 == 0) +{ +lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; +x_14 = lean_ctor_get(x_2, 3); +x_15 = lean_ctor_get(x_2, 4); +x_16 = l_Lean_Meta_FVarSubst_apply(x_1, x_14); +x_17 = l_Lean_Meta_FVarSubst_apply(x_1, x_15); +lean_ctor_set(x_2, 4, x_17); +lean_ctor_set(x_2, 3, x_16); +return x_2; +} +else +{ +lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; +x_18 = lean_ctor_get(x_2, 0); +x_19 = lean_ctor_get(x_2, 1); +x_20 = lean_ctor_get(x_2, 2); +x_21 = lean_ctor_get(x_2, 3); +x_22 = lean_ctor_get(x_2, 4); +lean_inc(x_22); +lean_inc(x_21); +lean_inc(x_20); +lean_inc(x_19); +lean_inc(x_18); +lean_dec(x_2); +x_23 = l_Lean_Meta_FVarSubst_apply(x_1, x_21); +x_24 = l_Lean_Meta_FVarSubst_apply(x_1, x_22); +x_25 = lean_alloc_ctor(1, 5, 0); +lean_ctor_set(x_25, 0, x_18); +lean_ctor_set(x_25, 1, x_19); +lean_ctor_set(x_25, 2, x_20); +lean_ctor_set(x_25, 3, x_23); +lean_ctor_set(x_25, 4, x_24); +return x_25; +} +} +} +} +lean_object* l_Lean_LocalDecl_applyFVarSubst___boxed(lean_object* x_1, lean_object* x_2) { +_start: +{ +lean_object* x_3; +x_3 = l_Lean_LocalDecl_applyFVarSubst(x_1, x_2); +lean_dec(x_1); +return x_3; +} +} +lean_object* l_Lean_Expr_applyFVarSubst(lean_object* x_1, lean_object* x_2) { +_start: +{ +lean_object* x_3; +x_3 = l_Lean_Meta_FVarSubst_apply(x_1, x_2); +return x_3; +} +} +lean_object* l_Lean_Expr_applyFVarSubst___boxed(lean_object* x_1, lean_object* x_2) { +_start: +{ +lean_object* x_3; +x_3 = l_Lean_Expr_applyFVarSubst(x_1, x_2); +lean_dec(x_1); +return x_3; +} +} lean_object* initialize_Init(lean_object*); lean_object* initialize_Lean_Expr(lean_object*); +lean_object* initialize_Lean_LocalContext(lean_object*); lean_object* initialize_Lean_Util_ReplaceExpr(lean_object*); static bool _G_initialized = false; lean_object* initialize_Lean_Meta_Tactic_FVarSubst(lean_object* w) { @@ -1006,6 +1172,9 @@ lean_dec_ref(res); res = initialize_Lean_Expr(lean_io_mk_world()); if (lean_io_result_is_error(res)) return res; lean_dec_ref(res); +res = initialize_Lean_LocalContext(lean_io_mk_world()); +if (lean_io_result_is_error(res)) return res; +lean_dec_ref(res); res = initialize_Lean_Util_ReplaceExpr(lean_io_mk_world()); if (lean_io_result_is_error(res)) return res; lean_dec_ref(res); diff --git a/stage0/stdlib/Lean/Meta/Tactic/Intro.c b/stage0/stdlib/Lean/Meta/Tactic/Intro.c index 0640988d1b..a409cb1007 100644 --- a/stage0/stdlib/Lean/Meta/Tactic/Intro.c +++ b/stage0/stdlib/Lean/Meta/Tactic/Intro.c @@ -1021,105 +1021,105 @@ x_30 = lean_ctor_get(x_24, 2); x_31 = !lean_is_exclusive(x_30); if (x_31 == 0) { -lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_84; uint8_t x_85; +lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_88; uint8_t x_89; x_32 = lean_ctor_get(x_30, 2); -x_84 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_30, 2, x_84); -x_85 = !lean_is_exclusive(x_6); -if (x_85 == 0) +x_88 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_30, 2, x_88); +x_89 = !lean_is_exclusive(x_6); +if (x_89 == 0) { -lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; -x_86 = lean_ctor_get(x_6, 2); -x_87 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_87, 0, x_26); -lean_ctor_set(x_87, 1, x_13); -x_88 = lean_array_push(x_86, x_87); -lean_ctor_set(x_6, 2, x_88); -x_89 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_introN___spec__3(x_1, x_2, x_3, x_4, x_28, x_6, x_24); -if (lean_obj_tag(x_89) == 0) +lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; +x_90 = lean_ctor_get(x_6, 2); +x_91 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_91, 0, x_26); +lean_ctor_set(x_91, 1, x_13); +x_92 = lean_array_push(x_90, x_91); +lean_ctor_set(x_6, 2, x_92); +x_93 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_introN___spec__3(x_1, x_2, x_3, x_4, x_28, x_6, x_24); +if (lean_obj_tag(x_93) == 0) { -lean_object* x_90; lean_object* x_91; lean_object* x_92; -x_90 = lean_ctor_get(x_89, 0); -lean_inc(x_90); -x_91 = lean_ctor_get(x_89, 1); -lean_inc(x_91); -lean_dec(x_89); -x_92 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_92, 0, x_90); -x_33 = x_92; -x_34 = x_91; -goto block_83; -} -else -{ -lean_object* x_93; lean_object* x_94; lean_object* x_95; -x_93 = lean_ctor_get(x_89, 0); -lean_inc(x_93); -x_94 = lean_ctor_get(x_89, 1); +lean_object* x_94; lean_object* x_95; lean_object* x_96; +x_94 = lean_ctor_get(x_93, 0); lean_inc(x_94); -lean_dec(x_89); -x_95 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_95, 0, x_93); -x_33 = x_95; -x_34 = x_94; -goto block_83; -} +x_95 = lean_ctor_get(x_93, 1); +lean_inc(x_95); +lean_dec(x_93); +x_96 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_96, 0, x_94); +x_33 = x_96; +x_34 = x_95; +goto block_87; } else { -lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; -x_96 = lean_ctor_get(x_6, 0); -x_97 = lean_ctor_get(x_6, 1); -x_98 = lean_ctor_get(x_6, 2); -x_99 = lean_ctor_get(x_6, 3); -x_100 = lean_ctor_get(x_6, 4); -lean_inc(x_100); -lean_inc(x_99); -lean_inc(x_98); +lean_object* x_97; lean_object* x_98; lean_object* x_99; +x_97 = lean_ctor_get(x_93, 0); lean_inc(x_97); -lean_inc(x_96); -lean_dec(x_6); -x_101 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_101, 0, x_26); -lean_ctor_set(x_101, 1, x_13); -x_102 = lean_array_push(x_98, x_101); -x_103 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_103, 0, x_96); -lean_ctor_set(x_103, 1, x_97); -lean_ctor_set(x_103, 2, x_102); -lean_ctor_set(x_103, 3, x_99); -lean_ctor_set(x_103, 4, x_100); -x_104 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_introN___spec__3(x_1, x_2, x_3, x_4, x_28, x_103, x_24); -if (lean_obj_tag(x_104) == 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); -x_107 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_107, 0, x_105); -x_33 = x_107; -x_34 = x_106; -goto block_83; +x_98 = lean_ctor_get(x_93, 1); +lean_inc(x_98); +lean_dec(x_93); +x_99 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_99, 0, x_97); +x_33 = x_99; +x_34 = x_98; +goto block_87; +} } else { -lean_object* x_108; lean_object* x_109; lean_object* x_110; -x_108 = lean_ctor_get(x_104, 0); -lean_inc(x_108); -x_109 = lean_ctor_get(x_104, 1); +lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; +x_100 = lean_ctor_get(x_6, 0); +x_101 = lean_ctor_get(x_6, 1); +x_102 = lean_ctor_get(x_6, 2); +x_103 = lean_ctor_get(x_6, 3); +x_104 = lean_ctor_get(x_6, 4); +lean_inc(x_104); +lean_inc(x_103); +lean_inc(x_102); +lean_inc(x_101); +lean_inc(x_100); +lean_dec(x_6); +x_105 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_105, 0, x_26); +lean_ctor_set(x_105, 1, x_13); +x_106 = lean_array_push(x_102, x_105); +x_107 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_107, 0, x_100); +lean_ctor_set(x_107, 1, x_101); +lean_ctor_set(x_107, 2, x_106); +lean_ctor_set(x_107, 3, x_103); +lean_ctor_set(x_107, 4, x_104); +x_108 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_introN___spec__3(x_1, x_2, x_3, x_4, x_28, x_107, x_24); +if (lean_obj_tag(x_108) == 0) +{ +lean_object* x_109; lean_object* x_110; lean_object* x_111; +x_109 = lean_ctor_get(x_108, 0); lean_inc(x_109); -lean_dec(x_104); -x_110 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_110, 0, x_108); -x_33 = x_110; -x_34 = x_109; -goto block_83; +x_110 = lean_ctor_get(x_108, 1); +lean_inc(x_110); +lean_dec(x_108); +x_111 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_111, 0, x_109); +x_33 = x_111; +x_34 = x_110; +goto block_87; +} +else +{ +lean_object* x_112; lean_object* x_113; lean_object* x_114; +x_112 = lean_ctor_get(x_108, 0); +lean_inc(x_112); +x_113 = lean_ctor_get(x_108, 1); +lean_inc(x_113); +lean_dec(x_108); +x_114 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_114, 0, x_112); +x_33 = x_114; +x_34 = x_113; +goto block_87; } } -block_83: +block_87: { if (lean_obj_tag(x_33) == 0) { @@ -1154,1284 +1154,1262 @@ return x_41; } else { -lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; +lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; x_42 = lean_ctor_get(x_35, 0); x_43 = lean_ctor_get(x_35, 1); x_44 = lean_ctor_get(x_35, 3); +x_45 = lean_ctor_get(x_35, 4); +lean_inc(x_45); lean_inc(x_44); lean_inc(x_43); lean_inc(x_42); lean_dec(x_35); -x_45 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_45, 0, x_42); -lean_ctor_set(x_45, 1, x_43); -lean_ctor_set(x_45, 2, x_32); -lean_ctor_set(x_45, 3, x_44); -lean_ctor_set(x_34, 2, x_45); +x_46 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_46, 0, x_42); +lean_ctor_set(x_46, 1, x_43); +lean_ctor_set(x_46, 2, x_32); +lean_ctor_set(x_46, 3, x_44); +lean_ctor_set(x_46, 4, x_45); +lean_ctor_set(x_34, 2, x_46); if (lean_is_scalar(x_25)) { - x_46 = lean_alloc_ctor(1, 2, 0); + x_47 = lean_alloc_ctor(1, 2, 0); } else { - x_46 = x_25; - lean_ctor_set_tag(x_46, 1); + x_47 = x_25; + lean_ctor_set_tag(x_47, 1); } -lean_ctor_set(x_46, 0, x_36); -lean_ctor_set(x_46, 1, x_34); -return x_46; +lean_ctor_set(x_47, 0, x_36); +lean_ctor_set(x_47, 1, x_34); +return x_47; } } else { -lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; -x_47 = lean_ctor_get(x_34, 0); -x_48 = lean_ctor_get(x_34, 1); -x_49 = lean_ctor_get(x_34, 3); -x_50 = lean_ctor_get(x_34, 4); -x_51 = lean_ctor_get(x_34, 5); +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; +x_48 = lean_ctor_get(x_34, 0); +x_49 = lean_ctor_get(x_34, 1); +x_50 = lean_ctor_get(x_34, 3); +x_51 = lean_ctor_get(x_34, 4); +x_52 = lean_ctor_get(x_34, 5); +lean_inc(x_52); lean_inc(x_51); lean_inc(x_50); lean_inc(x_49); lean_inc(x_48); -lean_inc(x_47); lean_dec(x_34); -x_52 = lean_ctor_get(x_35, 0); -lean_inc(x_52); -x_53 = lean_ctor_get(x_35, 1); +x_53 = lean_ctor_get(x_35, 0); lean_inc(x_53); -x_54 = lean_ctor_get(x_35, 3); +x_54 = lean_ctor_get(x_35, 1); lean_inc(x_54); +x_55 = lean_ctor_get(x_35, 3); +lean_inc(x_55); +x_56 = lean_ctor_get(x_35, 4); +lean_inc(x_56); if (lean_is_exclusive(x_35)) { lean_ctor_release(x_35, 0); lean_ctor_release(x_35, 1); lean_ctor_release(x_35, 2); lean_ctor_release(x_35, 3); - x_55 = x_35; + lean_ctor_release(x_35, 4); + x_57 = x_35; } else { lean_dec_ref(x_35); - x_55 = lean_box(0); + x_57 = lean_box(0); } -if (lean_is_scalar(x_55)) { - x_56 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_57)) { + x_58 = lean_alloc_ctor(0, 5, 0); } else { - x_56 = x_55; + x_58 = x_57; } -lean_ctor_set(x_56, 0, x_52); -lean_ctor_set(x_56, 1, x_53); -lean_ctor_set(x_56, 2, x_32); -lean_ctor_set(x_56, 3, x_54); -x_57 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_57, 0, x_47); -lean_ctor_set(x_57, 1, x_48); -lean_ctor_set(x_57, 2, x_56); -lean_ctor_set(x_57, 3, x_49); -lean_ctor_set(x_57, 4, x_50); -lean_ctor_set(x_57, 5, x_51); +lean_ctor_set(x_58, 0, x_53); +lean_ctor_set(x_58, 1, x_54); +lean_ctor_set(x_58, 2, x_32); +lean_ctor_set(x_58, 3, x_55); +lean_ctor_set(x_58, 4, x_56); +x_59 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_59, 0, x_48); +lean_ctor_set(x_59, 1, x_49); +lean_ctor_set(x_59, 2, x_58); +lean_ctor_set(x_59, 3, x_50); +lean_ctor_set(x_59, 4, x_51); +lean_ctor_set(x_59, 5, x_52); if (lean_is_scalar(x_25)) { - x_58 = lean_alloc_ctor(1, 2, 0); + x_60 = lean_alloc_ctor(1, 2, 0); } else { - x_58 = x_25; - lean_ctor_set_tag(x_58, 1); + x_60 = x_25; + lean_ctor_set_tag(x_60, 1); } -lean_ctor_set(x_58, 0, x_36); -lean_ctor_set(x_58, 1, x_57); -return x_58; +lean_ctor_set(x_60, 0, x_36); +lean_ctor_set(x_60, 1, x_59); +return x_60; } } else { -lean_object* x_59; lean_object* x_60; uint8_t x_61; -x_59 = lean_ctor_get(x_34, 2); -lean_inc(x_59); -x_60 = lean_ctor_get(x_33, 0); -lean_inc(x_60); +lean_object* x_61; lean_object* x_62; uint8_t x_63; +x_61 = lean_ctor_get(x_34, 2); +lean_inc(x_61); +x_62 = lean_ctor_get(x_33, 0); +lean_inc(x_62); lean_dec(x_33); -x_61 = !lean_is_exclusive(x_34); -if (x_61 == 0) -{ -lean_object* x_62; uint8_t x_63; -x_62 = lean_ctor_get(x_34, 2); -lean_dec(x_62); -x_63 = !lean_is_exclusive(x_59); +x_63 = !lean_is_exclusive(x_34); if (x_63 == 0) { -lean_object* x_64; lean_object* x_65; -x_64 = lean_ctor_get(x_59, 2); +lean_object* x_64; uint8_t x_65; +x_64 = lean_ctor_get(x_34, 2); lean_dec(x_64); -lean_ctor_set(x_59, 2, x_32); +x_65 = !lean_is_exclusive(x_61); +if (x_65 == 0) +{ +lean_object* x_66; lean_object* x_67; +x_66 = lean_ctor_get(x_61, 2); +lean_dec(x_66); +lean_ctor_set(x_61, 2, x_32); if (lean_is_scalar(x_25)) { - x_65 = lean_alloc_ctor(0, 2, 0); + x_67 = lean_alloc_ctor(0, 2, 0); } else { - x_65 = x_25; + x_67 = x_25; } -lean_ctor_set(x_65, 0, x_60); -lean_ctor_set(x_65, 1, x_34); -return x_65; +lean_ctor_set(x_67, 0, x_62); +lean_ctor_set(x_67, 1, x_34); +return x_67; } else { -lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; -x_66 = lean_ctor_get(x_59, 0); -x_67 = lean_ctor_get(x_59, 1); -x_68 = lean_ctor_get(x_59, 3); +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_68 = lean_ctor_get(x_61, 0); +x_69 = lean_ctor_get(x_61, 1); +x_70 = lean_ctor_get(x_61, 3); +x_71 = lean_ctor_get(x_61, 4); +lean_inc(x_71); +lean_inc(x_70); +lean_inc(x_69); lean_inc(x_68); -lean_inc(x_67); -lean_inc(x_66); -lean_dec(x_59); -x_69 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_69, 0, x_66); -lean_ctor_set(x_69, 1, x_67); -lean_ctor_set(x_69, 2, x_32); -lean_ctor_set(x_69, 3, x_68); -lean_ctor_set(x_34, 2, x_69); +lean_dec(x_61); +x_72 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_72, 0, x_68); +lean_ctor_set(x_72, 1, x_69); +lean_ctor_set(x_72, 2, x_32); +lean_ctor_set(x_72, 3, x_70); +lean_ctor_set(x_72, 4, x_71); +lean_ctor_set(x_34, 2, x_72); if (lean_is_scalar(x_25)) { - x_70 = lean_alloc_ctor(0, 2, 0); + x_73 = lean_alloc_ctor(0, 2, 0); } else { - x_70 = x_25; + x_73 = x_25; } -lean_ctor_set(x_70, 0, x_60); -lean_ctor_set(x_70, 1, x_34); -return x_70; +lean_ctor_set(x_73, 0, x_62); +lean_ctor_set(x_73, 1, x_34); +return x_73; } } else { -lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; -x_71 = lean_ctor_get(x_34, 0); -x_72 = lean_ctor_get(x_34, 1); -x_73 = lean_ctor_get(x_34, 3); -x_74 = lean_ctor_get(x_34, 4); -x_75 = lean_ctor_get(x_34, 5); +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; +x_74 = lean_ctor_get(x_34, 0); +x_75 = lean_ctor_get(x_34, 1); +x_76 = lean_ctor_get(x_34, 3); +x_77 = lean_ctor_get(x_34, 4); +x_78 = lean_ctor_get(x_34, 5); +lean_inc(x_78); +lean_inc(x_77); +lean_inc(x_76); lean_inc(x_75); lean_inc(x_74); -lean_inc(x_73); -lean_inc(x_72); -lean_inc(x_71); lean_dec(x_34); -x_76 = lean_ctor_get(x_59, 0); -lean_inc(x_76); -x_77 = lean_ctor_get(x_59, 1); -lean_inc(x_77); -x_78 = lean_ctor_get(x_59, 3); -lean_inc(x_78); -if (lean_is_exclusive(x_59)) { - lean_ctor_release(x_59, 0); - lean_ctor_release(x_59, 1); - lean_ctor_release(x_59, 2); - lean_ctor_release(x_59, 3); - x_79 = x_59; +x_79 = lean_ctor_get(x_61, 0); +lean_inc(x_79); +x_80 = lean_ctor_get(x_61, 1); +lean_inc(x_80); +x_81 = lean_ctor_get(x_61, 3); +lean_inc(x_81); +x_82 = lean_ctor_get(x_61, 4); +lean_inc(x_82); +if (lean_is_exclusive(x_61)) { + lean_ctor_release(x_61, 0); + lean_ctor_release(x_61, 1); + lean_ctor_release(x_61, 2); + lean_ctor_release(x_61, 3); + lean_ctor_release(x_61, 4); + x_83 = x_61; } else { - lean_dec_ref(x_59); - x_79 = lean_box(0); + lean_dec_ref(x_61); + x_83 = lean_box(0); } -if (lean_is_scalar(x_79)) { - x_80 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_83)) { + x_84 = lean_alloc_ctor(0, 5, 0); } else { - x_80 = x_79; + x_84 = x_83; } -lean_ctor_set(x_80, 0, x_76); -lean_ctor_set(x_80, 1, x_77); -lean_ctor_set(x_80, 2, x_32); -lean_ctor_set(x_80, 3, x_78); -x_81 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_81, 0, x_71); -lean_ctor_set(x_81, 1, x_72); -lean_ctor_set(x_81, 2, x_80); -lean_ctor_set(x_81, 3, x_73); -lean_ctor_set(x_81, 4, x_74); -lean_ctor_set(x_81, 5, x_75); +lean_ctor_set(x_84, 0, x_79); +lean_ctor_set(x_84, 1, x_80); +lean_ctor_set(x_84, 2, x_32); +lean_ctor_set(x_84, 3, x_81); +lean_ctor_set(x_84, 4, x_82); +x_85 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_85, 0, x_74); +lean_ctor_set(x_85, 1, x_75); +lean_ctor_set(x_85, 2, x_84); +lean_ctor_set(x_85, 3, x_76); +lean_ctor_set(x_85, 4, x_77); +lean_ctor_set(x_85, 5, x_78); if (lean_is_scalar(x_25)) { - x_82 = lean_alloc_ctor(0, 2, 0); + x_86 = lean_alloc_ctor(0, 2, 0); } else { - x_82 = x_25; + x_86 = x_25; } -lean_ctor_set(x_82, 0, x_60); -lean_ctor_set(x_82, 1, x_81); -return x_82; +lean_ctor_set(x_86, 0, x_62); +lean_ctor_set(x_86, 1, x_85); +return x_86; } } } } 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_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; -x_111 = lean_ctor_get(x_30, 0); -x_112 = lean_ctor_get(x_30, 1); -x_113 = lean_ctor_get(x_30, 2); -x_114 = lean_ctor_get(x_30, 3); -lean_inc(x_114); -lean_inc(x_113); -lean_inc(x_112); -lean_inc(x_111); -lean_dec(x_30); -x_148 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_149 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_149, 0, x_111); -lean_ctor_set(x_149, 1, x_112); -lean_ctor_set(x_149, 2, x_148); -lean_ctor_set(x_149, 3, x_114); -lean_ctor_set(x_24, 2, x_149); -x_150 = lean_ctor_get(x_6, 0); -lean_inc(x_150); -x_151 = lean_ctor_get(x_6, 1); -lean_inc(x_151); -x_152 = lean_ctor_get(x_6, 2); -lean_inc(x_152); -x_153 = lean_ctor_get(x_6, 3); -lean_inc(x_153); -x_154 = lean_ctor_get(x_6, 4); -lean_inc(x_154); -if (lean_is_exclusive(x_6)) { - lean_ctor_release(x_6, 0); - lean_ctor_release(x_6, 1); - lean_ctor_release(x_6, 2); - lean_ctor_release(x_6, 3); - lean_ctor_release(x_6, 4); - x_155 = x_6; -} else { - lean_dec_ref(x_6); - x_155 = lean_box(0); -} -x_156 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_156, 0, x_26); -lean_ctor_set(x_156, 1, x_13); -x_157 = lean_array_push(x_152, x_156); -if (lean_is_scalar(x_155)) { - x_158 = lean_alloc_ctor(0, 5, 0); -} else { - x_158 = x_155; -} -lean_ctor_set(x_158, 0, x_150); -lean_ctor_set(x_158, 1, x_151); -lean_ctor_set(x_158, 2, x_157); -lean_ctor_set(x_158, 3, x_153); -lean_ctor_set(x_158, 4, x_154); -x_159 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_introN___spec__3(x_1, x_2, x_3, x_4, x_28, x_158, x_24); -if (lean_obj_tag(x_159) == 0) -{ -lean_object* x_160; lean_object* x_161; lean_object* x_162; -x_160 = lean_ctor_get(x_159, 0); -lean_inc(x_160); -x_161 = lean_ctor_get(x_159, 1); -lean_inc(x_161); -lean_dec(x_159); -x_162 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_162, 0, x_160); -x_115 = x_162; -x_116 = x_161; -goto block_147; -} -else -{ -lean_object* x_163; lean_object* x_164; lean_object* x_165; -x_163 = lean_ctor_get(x_159, 0); -lean_inc(x_163); -x_164 = lean_ctor_get(x_159, 1); -lean_inc(x_164); -lean_dec(x_159); -x_165 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_165, 0, x_163); -x_115 = x_165; -x_116 = x_164; -goto block_147; -} -block_147: -{ -if (lean_obj_tag(x_115) == 0) -{ -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; -x_117 = lean_ctor_get(x_116, 2); -lean_inc(x_117); -x_118 = lean_ctor_get(x_115, 0); -lean_inc(x_118); -lean_dec(x_115); -x_119 = lean_ctor_get(x_116, 0); +lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_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; +x_115 = lean_ctor_get(x_30, 0); +x_116 = lean_ctor_get(x_30, 1); +x_117 = lean_ctor_get(x_30, 2); +x_118 = lean_ctor_get(x_30, 3); +x_119 = lean_ctor_get(x_30, 4); lean_inc(x_119); -x_120 = lean_ctor_get(x_116, 1); -lean_inc(x_120); -x_121 = lean_ctor_get(x_116, 3); -lean_inc(x_121); -x_122 = lean_ctor_get(x_116, 4); -lean_inc(x_122); -x_123 = lean_ctor_get(x_116, 5); -lean_inc(x_123); -if (lean_is_exclusive(x_116)) { - lean_ctor_release(x_116, 0); - lean_ctor_release(x_116, 1); - lean_ctor_release(x_116, 2); - lean_ctor_release(x_116, 3); - lean_ctor_release(x_116, 4); - lean_ctor_release(x_116, 5); - x_124 = x_116; -} else { - lean_dec_ref(x_116); - x_124 = lean_box(0); -} -x_125 = lean_ctor_get(x_117, 0); -lean_inc(x_125); -x_126 = lean_ctor_get(x_117, 1); -lean_inc(x_126); -x_127 = lean_ctor_get(x_117, 3); -lean_inc(x_127); -if (lean_is_exclusive(x_117)) { - lean_ctor_release(x_117, 0); - lean_ctor_release(x_117, 1); - lean_ctor_release(x_117, 2); - lean_ctor_release(x_117, 3); - x_128 = x_117; -} else { - lean_dec_ref(x_117); - x_128 = lean_box(0); -} -if (lean_is_scalar(x_128)) { - x_129 = lean_alloc_ctor(0, 4, 0); -} else { - x_129 = x_128; -} -lean_ctor_set(x_129, 0, x_125); -lean_ctor_set(x_129, 1, x_126); -lean_ctor_set(x_129, 2, x_113); -lean_ctor_set(x_129, 3, x_127); -if (lean_is_scalar(x_124)) { - x_130 = lean_alloc_ctor(0, 6, 0); -} else { - x_130 = x_124; -} -lean_ctor_set(x_130, 0, x_119); -lean_ctor_set(x_130, 1, x_120); -lean_ctor_set(x_130, 2, x_129); -lean_ctor_set(x_130, 3, x_121); -lean_ctor_set(x_130, 4, x_122); -lean_ctor_set(x_130, 5, x_123); -if (lean_is_scalar(x_25)) { - x_131 = lean_alloc_ctor(1, 2, 0); -} else { - x_131 = x_25; - lean_ctor_set_tag(x_131, 1); -} -lean_ctor_set(x_131, 0, x_118); -lean_ctor_set(x_131, 1, x_130); -return x_131; -} -else -{ -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; -x_132 = lean_ctor_get(x_116, 2); -lean_inc(x_132); -x_133 = lean_ctor_get(x_115, 0); -lean_inc(x_133); -lean_dec(x_115); -x_134 = lean_ctor_get(x_116, 0); -lean_inc(x_134); -x_135 = lean_ctor_get(x_116, 1); -lean_inc(x_135); -x_136 = lean_ctor_get(x_116, 3); -lean_inc(x_136); -x_137 = lean_ctor_get(x_116, 4); -lean_inc(x_137); -x_138 = lean_ctor_get(x_116, 5); -lean_inc(x_138); -if (lean_is_exclusive(x_116)) { - lean_ctor_release(x_116, 0); - lean_ctor_release(x_116, 1); - lean_ctor_release(x_116, 2); - lean_ctor_release(x_116, 3); - lean_ctor_release(x_116, 4); - lean_ctor_release(x_116, 5); - x_139 = x_116; -} else { - lean_dec_ref(x_116); - x_139 = lean_box(0); -} -x_140 = lean_ctor_get(x_132, 0); -lean_inc(x_140); -x_141 = lean_ctor_get(x_132, 1); -lean_inc(x_141); -x_142 = lean_ctor_get(x_132, 3); -lean_inc(x_142); -if (lean_is_exclusive(x_132)) { - lean_ctor_release(x_132, 0); - lean_ctor_release(x_132, 1); - lean_ctor_release(x_132, 2); - lean_ctor_release(x_132, 3); - x_143 = x_132; -} else { - lean_dec_ref(x_132); - x_143 = lean_box(0); -} -if (lean_is_scalar(x_143)) { - x_144 = lean_alloc_ctor(0, 4, 0); -} else { - x_144 = x_143; -} -lean_ctor_set(x_144, 0, x_140); -lean_ctor_set(x_144, 1, x_141); -lean_ctor_set(x_144, 2, x_113); -lean_ctor_set(x_144, 3, x_142); -if (lean_is_scalar(x_139)) { - x_145 = lean_alloc_ctor(0, 6, 0); -} else { - x_145 = x_139; -} -lean_ctor_set(x_145, 0, x_134); -lean_ctor_set(x_145, 1, x_135); -lean_ctor_set(x_145, 2, x_144); -lean_ctor_set(x_145, 3, x_136); -lean_ctor_set(x_145, 4, x_137); -lean_ctor_set(x_145, 5, x_138); -if (lean_is_scalar(x_25)) { - x_146 = lean_alloc_ctor(0, 2, 0); -} else { - x_146 = x_25; -} -lean_ctor_set(x_146, 0, x_133); -lean_ctor_set(x_146, 1, x_145); -return x_146; -} -} -} -} -else -{ -lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; lean_object* x_173; lean_object* x_174; lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; -x_166 = lean_ctor_get(x_24, 2); -x_167 = lean_ctor_get(x_24, 0); -x_168 = lean_ctor_get(x_24, 1); -x_169 = lean_ctor_get(x_24, 3); -x_170 = lean_ctor_get(x_24, 4); -x_171 = lean_ctor_get(x_24, 5); -lean_inc(x_171); -lean_inc(x_170); -lean_inc(x_169); -lean_inc(x_166); -lean_inc(x_168); -lean_inc(x_167); -lean_dec(x_24); -x_172 = lean_ctor_get(x_166, 0); -lean_inc(x_172); -x_173 = lean_ctor_get(x_166, 1); -lean_inc(x_173); -x_174 = lean_ctor_get(x_166, 2); -lean_inc(x_174); -x_175 = lean_ctor_get(x_166, 3); -lean_inc(x_175); -if (lean_is_exclusive(x_166)) { - lean_ctor_release(x_166, 0); - lean_ctor_release(x_166, 1); - lean_ctor_release(x_166, 2); - lean_ctor_release(x_166, 3); - x_176 = x_166; -} else { - lean_dec_ref(x_166); - x_176 = lean_box(0); -} -x_210 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_176)) { - x_211 = lean_alloc_ctor(0, 4, 0); -} else { - x_211 = x_176; -} -lean_ctor_set(x_211, 0, x_172); -lean_ctor_set(x_211, 1, x_173); -lean_ctor_set(x_211, 2, x_210); -lean_ctor_set(x_211, 3, x_175); -x_212 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_212, 0, x_167); -lean_ctor_set(x_212, 1, x_168); -lean_ctor_set(x_212, 2, x_211); -lean_ctor_set(x_212, 3, x_169); -lean_ctor_set(x_212, 4, x_170); -lean_ctor_set(x_212, 5, x_171); -x_213 = lean_ctor_get(x_6, 0); -lean_inc(x_213); -x_214 = lean_ctor_get(x_6, 1); -lean_inc(x_214); -x_215 = lean_ctor_get(x_6, 2); -lean_inc(x_215); -x_216 = lean_ctor_get(x_6, 3); -lean_inc(x_216); -x_217 = lean_ctor_get(x_6, 4); -lean_inc(x_217); +lean_inc(x_118); +lean_inc(x_117); +lean_inc(x_116); +lean_inc(x_115); +lean_dec(x_30); +x_155 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_156 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_156, 0, x_115); +lean_ctor_set(x_156, 1, x_116); +lean_ctor_set(x_156, 2, x_155); +lean_ctor_set(x_156, 3, x_118); +lean_ctor_set(x_156, 4, x_119); +lean_ctor_set(x_24, 2, x_156); +x_157 = lean_ctor_get(x_6, 0); +lean_inc(x_157); +x_158 = lean_ctor_get(x_6, 1); +lean_inc(x_158); +x_159 = lean_ctor_get(x_6, 2); +lean_inc(x_159); +x_160 = lean_ctor_get(x_6, 3); +lean_inc(x_160); +x_161 = lean_ctor_get(x_6, 4); +lean_inc(x_161); if (lean_is_exclusive(x_6)) { lean_ctor_release(x_6, 0); lean_ctor_release(x_6, 1); lean_ctor_release(x_6, 2); lean_ctor_release(x_6, 3); lean_ctor_release(x_6, 4); - x_218 = x_6; + x_162 = x_6; } else { lean_dec_ref(x_6); - x_218 = lean_box(0); + x_162 = lean_box(0); } -x_219 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_219, 0, x_26); -lean_ctor_set(x_219, 1, x_13); -x_220 = lean_array_push(x_215, x_219); -if (lean_is_scalar(x_218)) { +x_163 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_163, 0, x_26); +lean_ctor_set(x_163, 1, x_13); +x_164 = lean_array_push(x_159, x_163); +if (lean_is_scalar(x_162)) { + x_165 = lean_alloc_ctor(0, 5, 0); +} else { + x_165 = x_162; +} +lean_ctor_set(x_165, 0, x_157); +lean_ctor_set(x_165, 1, x_158); +lean_ctor_set(x_165, 2, x_164); +lean_ctor_set(x_165, 3, x_160); +lean_ctor_set(x_165, 4, x_161); +x_166 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_introN___spec__3(x_1, x_2, x_3, x_4, x_28, x_165, x_24); +if (lean_obj_tag(x_166) == 0) +{ +lean_object* x_167; lean_object* x_168; lean_object* x_169; +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, 1, 0); +lean_ctor_set(x_169, 0, x_167); +x_120 = x_169; +x_121 = x_168; +goto block_154; +} +else +{ +lean_object* x_170; lean_object* x_171; lean_object* x_172; +x_170 = lean_ctor_get(x_166, 0); +lean_inc(x_170); +x_171 = lean_ctor_get(x_166, 1); +lean_inc(x_171); +lean_dec(x_166); +x_172 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_172, 0, x_170); +x_120 = x_172; +x_121 = x_171; +goto block_154; +} +block_154: +{ +if (lean_obj_tag(x_120) == 0) +{ +lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; +x_122 = lean_ctor_get(x_121, 2); +lean_inc(x_122); +x_123 = lean_ctor_get(x_120, 0); +lean_inc(x_123); +lean_dec(x_120); +x_124 = lean_ctor_get(x_121, 0); +lean_inc(x_124); +x_125 = lean_ctor_get(x_121, 1); +lean_inc(x_125); +x_126 = lean_ctor_get(x_121, 3); +lean_inc(x_126); +x_127 = lean_ctor_get(x_121, 4); +lean_inc(x_127); +x_128 = lean_ctor_get(x_121, 5); +lean_inc(x_128); +if (lean_is_exclusive(x_121)) { + lean_ctor_release(x_121, 0); + lean_ctor_release(x_121, 1); + lean_ctor_release(x_121, 2); + lean_ctor_release(x_121, 3); + lean_ctor_release(x_121, 4); + lean_ctor_release(x_121, 5); + x_129 = x_121; +} else { + lean_dec_ref(x_121); + x_129 = lean_box(0); +} +x_130 = lean_ctor_get(x_122, 0); +lean_inc(x_130); +x_131 = lean_ctor_get(x_122, 1); +lean_inc(x_131); +x_132 = lean_ctor_get(x_122, 3); +lean_inc(x_132); +x_133 = lean_ctor_get(x_122, 4); +lean_inc(x_133); +if (lean_is_exclusive(x_122)) { + lean_ctor_release(x_122, 0); + lean_ctor_release(x_122, 1); + lean_ctor_release(x_122, 2); + lean_ctor_release(x_122, 3); + lean_ctor_release(x_122, 4); + x_134 = x_122; +} else { + lean_dec_ref(x_122); + x_134 = lean_box(0); +} +if (lean_is_scalar(x_134)) { + x_135 = lean_alloc_ctor(0, 5, 0); +} else { + x_135 = x_134; +} +lean_ctor_set(x_135, 0, x_130); +lean_ctor_set(x_135, 1, x_131); +lean_ctor_set(x_135, 2, x_117); +lean_ctor_set(x_135, 3, x_132); +lean_ctor_set(x_135, 4, x_133); +if (lean_is_scalar(x_129)) { + x_136 = lean_alloc_ctor(0, 6, 0); +} else { + x_136 = x_129; +} +lean_ctor_set(x_136, 0, x_124); +lean_ctor_set(x_136, 1, x_125); +lean_ctor_set(x_136, 2, x_135); +lean_ctor_set(x_136, 3, x_126); +lean_ctor_set(x_136, 4, x_127); +lean_ctor_set(x_136, 5, x_128); +if (lean_is_scalar(x_25)) { + x_137 = lean_alloc_ctor(1, 2, 0); +} else { + x_137 = x_25; + lean_ctor_set_tag(x_137, 1); +} +lean_ctor_set(x_137, 0, x_123); +lean_ctor_set(x_137, 1, x_136); +return x_137; +} +else +{ +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; +x_138 = lean_ctor_get(x_121, 2); +lean_inc(x_138); +x_139 = lean_ctor_get(x_120, 0); +lean_inc(x_139); +lean_dec(x_120); +x_140 = lean_ctor_get(x_121, 0); +lean_inc(x_140); +x_141 = lean_ctor_get(x_121, 1); +lean_inc(x_141); +x_142 = lean_ctor_get(x_121, 3); +lean_inc(x_142); +x_143 = lean_ctor_get(x_121, 4); +lean_inc(x_143); +x_144 = lean_ctor_get(x_121, 5); +lean_inc(x_144); +if (lean_is_exclusive(x_121)) { + lean_ctor_release(x_121, 0); + lean_ctor_release(x_121, 1); + lean_ctor_release(x_121, 2); + lean_ctor_release(x_121, 3); + lean_ctor_release(x_121, 4); + lean_ctor_release(x_121, 5); + x_145 = x_121; +} else { + lean_dec_ref(x_121); + x_145 = lean_box(0); +} +x_146 = lean_ctor_get(x_138, 0); +lean_inc(x_146); +x_147 = lean_ctor_get(x_138, 1); +lean_inc(x_147); +x_148 = lean_ctor_get(x_138, 3); +lean_inc(x_148); +x_149 = lean_ctor_get(x_138, 4); +lean_inc(x_149); +if (lean_is_exclusive(x_138)) { + lean_ctor_release(x_138, 0); + lean_ctor_release(x_138, 1); + lean_ctor_release(x_138, 2); + lean_ctor_release(x_138, 3); + lean_ctor_release(x_138, 4); + x_150 = x_138; +} else { + lean_dec_ref(x_138); + x_150 = lean_box(0); +} +if (lean_is_scalar(x_150)) { + x_151 = lean_alloc_ctor(0, 5, 0); +} else { + x_151 = x_150; +} +lean_ctor_set(x_151, 0, x_146); +lean_ctor_set(x_151, 1, x_147); +lean_ctor_set(x_151, 2, x_117); +lean_ctor_set(x_151, 3, x_148); +lean_ctor_set(x_151, 4, x_149); +if (lean_is_scalar(x_145)) { + x_152 = lean_alloc_ctor(0, 6, 0); +} else { + x_152 = x_145; +} +lean_ctor_set(x_152, 0, x_140); +lean_ctor_set(x_152, 1, x_141); +lean_ctor_set(x_152, 2, x_151); +lean_ctor_set(x_152, 3, x_142); +lean_ctor_set(x_152, 4, x_143); +lean_ctor_set(x_152, 5, x_144); +if (lean_is_scalar(x_25)) { + x_153 = lean_alloc_ctor(0, 2, 0); +} else { + x_153 = x_25; +} +lean_ctor_set(x_153, 0, x_139); +lean_ctor_set(x_153, 1, x_152); +return x_153; +} +} +} +} +else +{ +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; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; 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; lean_object* x_231; lean_object* x_232; +x_173 = lean_ctor_get(x_24, 2); +x_174 = lean_ctor_get(x_24, 0); +x_175 = lean_ctor_get(x_24, 1); +x_176 = lean_ctor_get(x_24, 3); +x_177 = lean_ctor_get(x_24, 4); +x_178 = lean_ctor_get(x_24, 5); +lean_inc(x_178); +lean_inc(x_177); +lean_inc(x_176); +lean_inc(x_173); +lean_inc(x_175); +lean_inc(x_174); +lean_dec(x_24); +x_179 = lean_ctor_get(x_173, 0); +lean_inc(x_179); +x_180 = lean_ctor_get(x_173, 1); +lean_inc(x_180); +x_181 = lean_ctor_get(x_173, 2); +lean_inc(x_181); +x_182 = lean_ctor_get(x_173, 3); +lean_inc(x_182); +x_183 = lean_ctor_get(x_173, 4); +lean_inc(x_183); +if (lean_is_exclusive(x_173)) { + lean_ctor_release(x_173, 0); + lean_ctor_release(x_173, 1); + lean_ctor_release(x_173, 2); + lean_ctor_release(x_173, 3); + lean_ctor_release(x_173, 4); + x_184 = x_173; +} else { + lean_dec_ref(x_173); + x_184 = lean_box(0); +} +x_220 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_184)) { x_221 = lean_alloc_ctor(0, 5, 0); } else { - x_221 = x_218; + x_221 = x_184; } -lean_ctor_set(x_221, 0, x_213); -lean_ctor_set(x_221, 1, x_214); +lean_ctor_set(x_221, 0, x_179); +lean_ctor_set(x_221, 1, x_180); lean_ctor_set(x_221, 2, x_220); -lean_ctor_set(x_221, 3, x_216); -lean_ctor_set(x_221, 4, x_217); -x_222 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_introN___spec__3(x_1, x_2, x_3, x_4, x_28, x_221, x_212); -if (lean_obj_tag(x_222) == 0) -{ -lean_object* x_223; lean_object* x_224; lean_object* x_225; -x_223 = lean_ctor_get(x_222, 0); +lean_ctor_set(x_221, 3, x_182); +lean_ctor_set(x_221, 4, x_183); +x_222 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_222, 0, x_174); +lean_ctor_set(x_222, 1, x_175); +lean_ctor_set(x_222, 2, x_221); +lean_ctor_set(x_222, 3, x_176); +lean_ctor_set(x_222, 4, x_177); +lean_ctor_set(x_222, 5, x_178); +x_223 = lean_ctor_get(x_6, 0); lean_inc(x_223); -x_224 = lean_ctor_get(x_222, 1); +x_224 = lean_ctor_get(x_6, 1); lean_inc(x_224); -lean_dec(x_222); -x_225 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_225, 0, x_223); -x_177 = x_225; -x_178 = x_224; -goto block_209; -} -else -{ -lean_object* x_226; lean_object* x_227; lean_object* x_228; -x_226 = lean_ctor_get(x_222, 0); +x_225 = lean_ctor_get(x_6, 2); +lean_inc(x_225); +x_226 = lean_ctor_get(x_6, 3); lean_inc(x_226); -x_227 = lean_ctor_get(x_222, 1); +x_227 = lean_ctor_get(x_6, 4); lean_inc(x_227); -lean_dec(x_222); -x_228 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_228, 0, x_226); -x_177 = x_228; -x_178 = x_227; -goto block_209; +if (lean_is_exclusive(x_6)) { + lean_ctor_release(x_6, 0); + lean_ctor_release(x_6, 1); + lean_ctor_release(x_6, 2); + lean_ctor_release(x_6, 3); + lean_ctor_release(x_6, 4); + x_228 = x_6; +} else { + lean_dec_ref(x_6); + x_228 = lean_box(0); } -block_209: +x_229 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_229, 0, x_26); +lean_ctor_set(x_229, 1, x_13); +x_230 = lean_array_push(x_225, x_229); +if (lean_is_scalar(x_228)) { + x_231 = lean_alloc_ctor(0, 5, 0); +} else { + x_231 = x_228; +} +lean_ctor_set(x_231, 0, x_223); +lean_ctor_set(x_231, 1, x_224); +lean_ctor_set(x_231, 2, x_230); +lean_ctor_set(x_231, 3, x_226); +lean_ctor_set(x_231, 4, x_227); +x_232 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_introN___spec__3(x_1, x_2, x_3, x_4, x_28, x_231, x_222); +if (lean_obj_tag(x_232) == 0) { -if (lean_obj_tag(x_177) == 0) -{ -lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; -x_179 = lean_ctor_get(x_178, 2); -lean_inc(x_179); -x_180 = lean_ctor_get(x_177, 0); -lean_inc(x_180); -lean_dec(x_177); -x_181 = lean_ctor_get(x_178, 0); -lean_inc(x_181); -x_182 = lean_ctor_get(x_178, 1); -lean_inc(x_182); -x_183 = lean_ctor_get(x_178, 3); -lean_inc(x_183); -x_184 = lean_ctor_get(x_178, 4); -lean_inc(x_184); -x_185 = lean_ctor_get(x_178, 5); -lean_inc(x_185); -if (lean_is_exclusive(x_178)) { - lean_ctor_release(x_178, 0); - lean_ctor_release(x_178, 1); - lean_ctor_release(x_178, 2); - lean_ctor_release(x_178, 3); - lean_ctor_release(x_178, 4); - lean_ctor_release(x_178, 5); - x_186 = x_178; -} else { - lean_dec_ref(x_178); - x_186 = lean_box(0); -} -x_187 = lean_ctor_get(x_179, 0); -lean_inc(x_187); -x_188 = lean_ctor_get(x_179, 1); -lean_inc(x_188); -x_189 = lean_ctor_get(x_179, 3); -lean_inc(x_189); -if (lean_is_exclusive(x_179)) { - lean_ctor_release(x_179, 0); - lean_ctor_release(x_179, 1); - lean_ctor_release(x_179, 2); - lean_ctor_release(x_179, 3); - x_190 = x_179; -} else { - lean_dec_ref(x_179); - x_190 = lean_box(0); -} -if (lean_is_scalar(x_190)) { - x_191 = lean_alloc_ctor(0, 4, 0); -} else { - x_191 = x_190; -} -lean_ctor_set(x_191, 0, x_187); -lean_ctor_set(x_191, 1, x_188); -lean_ctor_set(x_191, 2, x_174); -lean_ctor_set(x_191, 3, x_189); -if (lean_is_scalar(x_186)) { - x_192 = lean_alloc_ctor(0, 6, 0); -} else { - x_192 = x_186; -} -lean_ctor_set(x_192, 0, x_181); -lean_ctor_set(x_192, 1, x_182); -lean_ctor_set(x_192, 2, x_191); -lean_ctor_set(x_192, 3, x_183); -lean_ctor_set(x_192, 4, x_184); -lean_ctor_set(x_192, 5, x_185); -if (lean_is_scalar(x_25)) { - x_193 = lean_alloc_ctor(1, 2, 0); -} else { - x_193 = x_25; - lean_ctor_set_tag(x_193, 1); -} -lean_ctor_set(x_193, 0, x_180); -lean_ctor_set(x_193, 1, x_192); -return x_193; +lean_object* x_233; lean_object* x_234; lean_object* x_235; +x_233 = lean_ctor_get(x_232, 0); +lean_inc(x_233); +x_234 = lean_ctor_get(x_232, 1); +lean_inc(x_234); +lean_dec(x_232); +x_235 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_235, 0, x_233); +x_185 = x_235; +x_186 = x_234; +goto block_219; } else { -lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; -x_194 = lean_ctor_get(x_178, 2); -lean_inc(x_194); -x_195 = lean_ctor_get(x_177, 0); +lean_object* x_236; lean_object* x_237; lean_object* x_238; +x_236 = lean_ctor_get(x_232, 0); +lean_inc(x_236); +x_237 = lean_ctor_get(x_232, 1); +lean_inc(x_237); +lean_dec(x_232); +x_238 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_238, 0, x_236); +x_185 = x_238; +x_186 = x_237; +goto block_219; +} +block_219: +{ +if (lean_obj_tag(x_185) == 0) +{ +lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; +x_187 = lean_ctor_get(x_186, 2); +lean_inc(x_187); +x_188 = lean_ctor_get(x_185, 0); +lean_inc(x_188); +lean_dec(x_185); +x_189 = lean_ctor_get(x_186, 0); +lean_inc(x_189); +x_190 = lean_ctor_get(x_186, 1); +lean_inc(x_190); +x_191 = lean_ctor_get(x_186, 3); +lean_inc(x_191); +x_192 = lean_ctor_get(x_186, 4); +lean_inc(x_192); +x_193 = lean_ctor_get(x_186, 5); +lean_inc(x_193); +if (lean_is_exclusive(x_186)) { + lean_ctor_release(x_186, 0); + lean_ctor_release(x_186, 1); + lean_ctor_release(x_186, 2); + lean_ctor_release(x_186, 3); + lean_ctor_release(x_186, 4); + lean_ctor_release(x_186, 5); + x_194 = x_186; +} else { + lean_dec_ref(x_186); + x_194 = lean_box(0); +} +x_195 = lean_ctor_get(x_187, 0); lean_inc(x_195); -lean_dec(x_177); -x_196 = lean_ctor_get(x_178, 0); +x_196 = lean_ctor_get(x_187, 1); lean_inc(x_196); -x_197 = lean_ctor_get(x_178, 1); +x_197 = lean_ctor_get(x_187, 3); lean_inc(x_197); -x_198 = lean_ctor_get(x_178, 3); +x_198 = lean_ctor_get(x_187, 4); lean_inc(x_198); -x_199 = lean_ctor_get(x_178, 4); -lean_inc(x_199); -x_200 = lean_ctor_get(x_178, 5); -lean_inc(x_200); -if (lean_is_exclusive(x_178)) { - lean_ctor_release(x_178, 0); - lean_ctor_release(x_178, 1); - lean_ctor_release(x_178, 2); - lean_ctor_release(x_178, 3); - lean_ctor_release(x_178, 4); - lean_ctor_release(x_178, 5); - x_201 = x_178; +if (lean_is_exclusive(x_187)) { + lean_ctor_release(x_187, 0); + lean_ctor_release(x_187, 1); + lean_ctor_release(x_187, 2); + lean_ctor_release(x_187, 3); + lean_ctor_release(x_187, 4); + x_199 = x_187; } else { - lean_dec_ref(x_178); - x_201 = lean_box(0); + lean_dec_ref(x_187); + x_199 = lean_box(0); } -x_202 = lean_ctor_get(x_194, 0); -lean_inc(x_202); -x_203 = lean_ctor_get(x_194, 1); -lean_inc(x_203); -x_204 = lean_ctor_get(x_194, 3); -lean_inc(x_204); -if (lean_is_exclusive(x_194)) { - lean_ctor_release(x_194, 0); - lean_ctor_release(x_194, 1); - lean_ctor_release(x_194, 2); - lean_ctor_release(x_194, 3); - x_205 = x_194; +if (lean_is_scalar(x_199)) { + x_200 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_194); - x_205 = lean_box(0); + x_200 = x_199; } -if (lean_is_scalar(x_205)) { - x_206 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_200, 0, x_195); +lean_ctor_set(x_200, 1, x_196); +lean_ctor_set(x_200, 2, x_181); +lean_ctor_set(x_200, 3, x_197); +lean_ctor_set(x_200, 4, x_198); +if (lean_is_scalar(x_194)) { + x_201 = lean_alloc_ctor(0, 6, 0); } else { - x_206 = x_205; + x_201 = x_194; } -lean_ctor_set(x_206, 0, x_202); -lean_ctor_set(x_206, 1, x_203); -lean_ctor_set(x_206, 2, x_174); -lean_ctor_set(x_206, 3, x_204); -if (lean_is_scalar(x_201)) { - x_207 = lean_alloc_ctor(0, 6, 0); -} else { - x_207 = x_201; -} -lean_ctor_set(x_207, 0, x_196); -lean_ctor_set(x_207, 1, x_197); -lean_ctor_set(x_207, 2, x_206); -lean_ctor_set(x_207, 3, x_198); -lean_ctor_set(x_207, 4, x_199); -lean_ctor_set(x_207, 5, x_200); +lean_ctor_set(x_201, 0, x_189); +lean_ctor_set(x_201, 1, x_190); +lean_ctor_set(x_201, 2, x_200); +lean_ctor_set(x_201, 3, x_191); +lean_ctor_set(x_201, 4, x_192); +lean_ctor_set(x_201, 5, x_193); if (lean_is_scalar(x_25)) { - x_208 = lean_alloc_ctor(0, 2, 0); + x_202 = lean_alloc_ctor(1, 2, 0); } else { - x_208 = x_25; + x_202 = x_25; + lean_ctor_set_tag(x_202, 1); } -lean_ctor_set(x_208, 0, x_195); -lean_ctor_set(x_208, 1, x_207); -return x_208; +lean_ctor_set(x_202, 0, x_188); +lean_ctor_set(x_202, 1, x_201); +return x_202; +} +else +{ +lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; +x_203 = lean_ctor_get(x_186, 2); +lean_inc(x_203); +x_204 = lean_ctor_get(x_185, 0); +lean_inc(x_204); +lean_dec(x_185); +x_205 = lean_ctor_get(x_186, 0); +lean_inc(x_205); +x_206 = lean_ctor_get(x_186, 1); +lean_inc(x_206); +x_207 = lean_ctor_get(x_186, 3); +lean_inc(x_207); +x_208 = lean_ctor_get(x_186, 4); +lean_inc(x_208); +x_209 = lean_ctor_get(x_186, 5); +lean_inc(x_209); +if (lean_is_exclusive(x_186)) { + lean_ctor_release(x_186, 0); + lean_ctor_release(x_186, 1); + lean_ctor_release(x_186, 2); + lean_ctor_release(x_186, 3); + lean_ctor_release(x_186, 4); + lean_ctor_release(x_186, 5); + x_210 = x_186; +} else { + lean_dec_ref(x_186); + x_210 = lean_box(0); +} +x_211 = lean_ctor_get(x_203, 0); +lean_inc(x_211); +x_212 = lean_ctor_get(x_203, 1); +lean_inc(x_212); +x_213 = lean_ctor_get(x_203, 3); +lean_inc(x_213); +x_214 = lean_ctor_get(x_203, 4); +lean_inc(x_214); +if (lean_is_exclusive(x_203)) { + lean_ctor_release(x_203, 0); + lean_ctor_release(x_203, 1); + lean_ctor_release(x_203, 2); + lean_ctor_release(x_203, 3); + lean_ctor_release(x_203, 4); + x_215 = x_203; +} else { + lean_dec_ref(x_203); + x_215 = lean_box(0); +} +if (lean_is_scalar(x_215)) { + x_216 = lean_alloc_ctor(0, 5, 0); +} else { + x_216 = x_215; +} +lean_ctor_set(x_216, 0, x_211); +lean_ctor_set(x_216, 1, x_212); +lean_ctor_set(x_216, 2, x_181); +lean_ctor_set(x_216, 3, x_213); +lean_ctor_set(x_216, 4, x_214); +if (lean_is_scalar(x_210)) { + x_217 = lean_alloc_ctor(0, 6, 0); +} else { + x_217 = x_210; +} +lean_ctor_set(x_217, 0, x_205); +lean_ctor_set(x_217, 1, x_206); +lean_ctor_set(x_217, 2, x_216); +lean_ctor_set(x_217, 3, x_207); +lean_ctor_set(x_217, 4, x_208); +lean_ctor_set(x_217, 5, x_209); +if (lean_is_scalar(x_25)) { + x_218 = lean_alloc_ctor(0, 2, 0); +} else { + x_218 = x_25; +} +lean_ctor_set(x_218, 0, x_204); +lean_ctor_set(x_218, 1, x_217); +return x_218; } } } } default: { -lean_object* x_229; lean_object* x_230; -x_229 = lean_ctor_get(x_18, 1); -lean_inc(x_229); +lean_object* x_239; lean_object* x_240; +x_239 = lean_ctor_get(x_18, 1); +lean_inc(x_239); lean_dec(x_18); lean_inc(x_6); -x_230 = l_Lean_Meta_isClassExpensive___main(x_17, x_6, x_229); -if (lean_obj_tag(x_230) == 0) +x_240 = l_Lean_Meta_isClassExpensive___main(x_17, x_6, x_239); +if (lean_obj_tag(x_240) == 0) { -lean_object* x_231; -x_231 = lean_ctor_get(x_230, 0); -lean_inc(x_231); -if (lean_obj_tag(x_231) == 0) +lean_object* x_241; +x_241 = lean_ctor_get(x_240, 0); +lean_inc(x_241); +if (lean_obj_tag(x_241) == 0) { -lean_object* x_232; lean_object* x_233; lean_object* x_234; +lean_object* x_242; lean_object* x_243; lean_object* x_244; lean_dec(x_13); -x_232 = lean_ctor_get(x_230, 1); -lean_inc(x_232); -lean_dec(x_230); -x_233 = lean_unsigned_to_nat(1u); -x_234 = lean_nat_add(x_5, x_233); +x_242 = lean_ctor_get(x_240, 1); +lean_inc(x_242); +lean_dec(x_240); +x_243 = lean_unsigned_to_nat(1u); +x_244 = lean_nat_add(x_5, x_243); lean_dec(x_5); -x_5 = x_234; -x_7 = x_232; +x_5 = x_244; +x_7 = x_242; goto _start; } else { -lean_object* x_236; lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_object* x_240; uint8_t x_241; -x_236 = lean_ctor_get(x_230, 1); -lean_inc(x_236); -if (lean_is_exclusive(x_230)) { - lean_ctor_release(x_230, 0); - lean_ctor_release(x_230, 1); - x_237 = x_230; +lean_object* x_246; lean_object* x_247; lean_object* x_248; lean_object* x_249; lean_object* x_250; uint8_t x_251; +x_246 = lean_ctor_get(x_240, 1); +lean_inc(x_246); +if (lean_is_exclusive(x_240)) { + lean_ctor_release(x_240, 0); + lean_ctor_release(x_240, 1); + x_247 = x_240; } else { - lean_dec_ref(x_230); - x_237 = lean_box(0); + lean_dec_ref(x_240); + x_247 = lean_box(0); } -x_238 = lean_ctor_get(x_231, 0); -lean_inc(x_238); -lean_dec(x_231); -x_239 = lean_unsigned_to_nat(1u); -x_240 = lean_nat_add(x_5, x_239); -lean_dec(x_5); -x_241 = !lean_is_exclusive(x_236); -if (x_241 == 0) -{ -lean_object* x_242; uint8_t x_243; -x_242 = lean_ctor_get(x_236, 2); -x_243 = !lean_is_exclusive(x_242); -if (x_243 == 0) -{ -lean_object* x_244; lean_object* x_245; lean_object* x_246; lean_object* x_296; uint8_t x_297; -x_244 = lean_ctor_get(x_242, 2); -x_296 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_242, 2, x_296); -x_297 = !lean_is_exclusive(x_6); -if (x_297 == 0) -{ -lean_object* x_298; lean_object* x_299; lean_object* x_300; lean_object* x_301; -x_298 = lean_ctor_get(x_6, 2); -x_299 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_299, 0, x_238); -lean_ctor_set(x_299, 1, x_13); -x_300 = lean_array_push(x_298, x_299); -lean_ctor_set(x_6, 2, x_300); -x_301 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_introN___spec__3(x_1, x_2, x_3, x_4, x_240, x_6, x_236); -if (lean_obj_tag(x_301) == 0) -{ -lean_object* x_302; lean_object* x_303; lean_object* x_304; -x_302 = lean_ctor_get(x_301, 0); -lean_inc(x_302); -x_303 = lean_ctor_get(x_301, 1); -lean_inc(x_303); -lean_dec(x_301); -x_304 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_304, 0, x_302); -x_245 = x_304; -x_246 = x_303; -goto block_295; -} -else -{ -lean_object* x_305; lean_object* x_306; lean_object* x_307; -x_305 = lean_ctor_get(x_301, 0); -lean_inc(x_305); -x_306 = lean_ctor_get(x_301, 1); -lean_inc(x_306); -lean_dec(x_301); -x_307 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_307, 0, x_305); -x_245 = x_307; -x_246 = x_306; -goto block_295; -} -} -else -{ -lean_object* x_308; lean_object* x_309; lean_object* x_310; lean_object* x_311; lean_object* x_312; lean_object* x_313; lean_object* x_314; lean_object* x_315; lean_object* x_316; -x_308 = lean_ctor_get(x_6, 0); -x_309 = lean_ctor_get(x_6, 1); -x_310 = lean_ctor_get(x_6, 2); -x_311 = lean_ctor_get(x_6, 3); -x_312 = lean_ctor_get(x_6, 4); -lean_inc(x_312); -lean_inc(x_311); -lean_inc(x_310); -lean_inc(x_309); -lean_inc(x_308); -lean_dec(x_6); -x_313 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_313, 0, x_238); -lean_ctor_set(x_313, 1, x_13); -x_314 = lean_array_push(x_310, x_313); -x_315 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_315, 0, x_308); -lean_ctor_set(x_315, 1, x_309); -lean_ctor_set(x_315, 2, x_314); -lean_ctor_set(x_315, 3, x_311); -lean_ctor_set(x_315, 4, x_312); -x_316 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_introN___spec__3(x_1, x_2, x_3, x_4, x_240, x_315, x_236); -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); -x_319 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_319, 0, x_317); -x_245 = x_319; -x_246 = x_318; -goto block_295; -} -else -{ -lean_object* x_320; lean_object* x_321; lean_object* x_322; -x_320 = lean_ctor_get(x_316, 0); -lean_inc(x_320); -x_321 = lean_ctor_get(x_316, 1); -lean_inc(x_321); -lean_dec(x_316); -x_322 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_322, 0, x_320); -x_245 = x_322; -x_246 = x_321; -goto block_295; -} -} -block_295: -{ -if (lean_obj_tag(x_245) == 0) -{ -lean_object* x_247; lean_object* x_248; uint8_t x_249; -x_247 = lean_ctor_get(x_246, 2); -lean_inc(x_247); -x_248 = lean_ctor_get(x_245, 0); +x_248 = lean_ctor_get(x_241, 0); lean_inc(x_248); -lean_dec(x_245); -x_249 = !lean_is_exclusive(x_246); -if (x_249 == 0) -{ -lean_object* x_250; uint8_t x_251; -x_250 = lean_ctor_get(x_246, 2); -lean_dec(x_250); -x_251 = !lean_is_exclusive(x_247); +lean_dec(x_241); +x_249 = lean_unsigned_to_nat(1u); +x_250 = lean_nat_add(x_5, x_249); +lean_dec(x_5); +x_251 = !lean_is_exclusive(x_246); if (x_251 == 0) { -lean_object* x_252; lean_object* x_253; -x_252 = lean_ctor_get(x_247, 2); -lean_dec(x_252); -lean_ctor_set(x_247, 2, x_244); -if (lean_is_scalar(x_237)) { - x_253 = lean_alloc_ctor(1, 2, 0); -} else { - x_253 = x_237; - lean_ctor_set_tag(x_253, 1); -} -lean_ctor_set(x_253, 0, x_248); -lean_ctor_set(x_253, 1, x_246); -return x_253; +lean_object* x_252; uint8_t x_253; +x_252 = lean_ctor_get(x_246, 2); +x_253 = !lean_is_exclusive(x_252); +if (x_253 == 0) +{ +lean_object* x_254; lean_object* x_255; lean_object* x_256; lean_object* x_310; uint8_t x_311; +x_254 = lean_ctor_get(x_252, 2); +x_310 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_252, 2, x_310); +x_311 = !lean_is_exclusive(x_6); +if (x_311 == 0) +{ +lean_object* x_312; lean_object* x_313; lean_object* x_314; lean_object* x_315; +x_312 = lean_ctor_get(x_6, 2); +x_313 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_313, 0, x_248); +lean_ctor_set(x_313, 1, x_13); +x_314 = lean_array_push(x_312, x_313); +lean_ctor_set(x_6, 2, x_314); +x_315 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_introN___spec__3(x_1, x_2, x_3, x_4, x_250, x_6, x_246); +if (lean_obj_tag(x_315) == 0) +{ +lean_object* x_316; lean_object* x_317; lean_object* x_318; +x_316 = lean_ctor_get(x_315, 0); +lean_inc(x_316); +x_317 = lean_ctor_get(x_315, 1); +lean_inc(x_317); +lean_dec(x_315); +x_318 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_318, 0, x_316); +x_255 = x_318; +x_256 = x_317; +goto block_309; } else { -lean_object* x_254; lean_object* x_255; lean_object* x_256; lean_object* x_257; lean_object* x_258; -x_254 = lean_ctor_get(x_247, 0); -x_255 = lean_ctor_get(x_247, 1); -x_256 = lean_ctor_get(x_247, 3); -lean_inc(x_256); -lean_inc(x_255); -lean_inc(x_254); -lean_dec(x_247); -x_257 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_257, 0, x_254); -lean_ctor_set(x_257, 1, x_255); -lean_ctor_set(x_257, 2, x_244); -lean_ctor_set(x_257, 3, x_256); -lean_ctor_set(x_246, 2, x_257); -if (lean_is_scalar(x_237)) { - x_258 = lean_alloc_ctor(1, 2, 0); -} else { - x_258 = x_237; - lean_ctor_set_tag(x_258, 1); -} -lean_ctor_set(x_258, 0, x_248); -lean_ctor_set(x_258, 1, x_246); -return x_258; +lean_object* x_319; lean_object* x_320; lean_object* x_321; +x_319 = lean_ctor_get(x_315, 0); +lean_inc(x_319); +x_320 = lean_ctor_get(x_315, 1); +lean_inc(x_320); +lean_dec(x_315); +x_321 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_321, 0, x_319); +x_255 = x_321; +x_256 = x_320; +goto block_309; } } else { -lean_object* x_259; lean_object* x_260; lean_object* x_261; lean_object* x_262; lean_object* x_263; lean_object* x_264; lean_object* x_265; lean_object* x_266; lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_object* x_270; -x_259 = lean_ctor_get(x_246, 0); -x_260 = lean_ctor_get(x_246, 1); -x_261 = lean_ctor_get(x_246, 3); -x_262 = lean_ctor_get(x_246, 4); -x_263 = lean_ctor_get(x_246, 5); -lean_inc(x_263); -lean_inc(x_262); -lean_inc(x_261); -lean_inc(x_260); -lean_inc(x_259); -lean_dec(x_246); -x_264 = lean_ctor_get(x_247, 0); -lean_inc(x_264); -x_265 = lean_ctor_get(x_247, 1); -lean_inc(x_265); -x_266 = lean_ctor_get(x_247, 3); +lean_object* x_322; lean_object* x_323; lean_object* x_324; lean_object* x_325; lean_object* x_326; lean_object* x_327; lean_object* x_328; lean_object* x_329; lean_object* x_330; +x_322 = lean_ctor_get(x_6, 0); +x_323 = lean_ctor_get(x_6, 1); +x_324 = lean_ctor_get(x_6, 2); +x_325 = lean_ctor_get(x_6, 3); +x_326 = lean_ctor_get(x_6, 4); +lean_inc(x_326); +lean_inc(x_325); +lean_inc(x_324); +lean_inc(x_323); +lean_inc(x_322); +lean_dec(x_6); +x_327 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_327, 0, x_248); +lean_ctor_set(x_327, 1, x_13); +x_328 = lean_array_push(x_324, x_327); +x_329 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_329, 0, x_322); +lean_ctor_set(x_329, 1, x_323); +lean_ctor_set(x_329, 2, x_328); +lean_ctor_set(x_329, 3, x_325); +lean_ctor_set(x_329, 4, x_326); +x_330 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_introN___spec__3(x_1, x_2, x_3, x_4, x_250, x_329, x_246); +if (lean_obj_tag(x_330) == 0) +{ +lean_object* x_331; lean_object* x_332; lean_object* x_333; +x_331 = lean_ctor_get(x_330, 0); +lean_inc(x_331); +x_332 = lean_ctor_get(x_330, 1); +lean_inc(x_332); +lean_dec(x_330); +x_333 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_333, 0, x_331); +x_255 = x_333; +x_256 = x_332; +goto block_309; +} +else +{ +lean_object* x_334; lean_object* x_335; lean_object* x_336; +x_334 = lean_ctor_get(x_330, 0); +lean_inc(x_334); +x_335 = lean_ctor_get(x_330, 1); +lean_inc(x_335); +lean_dec(x_330); +x_336 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_336, 0, x_334); +x_255 = x_336; +x_256 = x_335; +goto block_309; +} +} +block_309: +{ +if (lean_obj_tag(x_255) == 0) +{ +lean_object* x_257; lean_object* x_258; uint8_t x_259; +x_257 = lean_ctor_get(x_256, 2); +lean_inc(x_257); +x_258 = lean_ctor_get(x_255, 0); +lean_inc(x_258); +lean_dec(x_255); +x_259 = !lean_is_exclusive(x_256); +if (x_259 == 0) +{ +lean_object* x_260; uint8_t x_261; +x_260 = lean_ctor_get(x_256, 2); +lean_dec(x_260); +x_261 = !lean_is_exclusive(x_257); +if (x_261 == 0) +{ +lean_object* x_262; lean_object* x_263; +x_262 = lean_ctor_get(x_257, 2); +lean_dec(x_262); +lean_ctor_set(x_257, 2, x_254); +if (lean_is_scalar(x_247)) { + x_263 = lean_alloc_ctor(1, 2, 0); +} else { + x_263 = x_247; + lean_ctor_set_tag(x_263, 1); +} +lean_ctor_set(x_263, 0, x_258); +lean_ctor_set(x_263, 1, x_256); +return x_263; +} +else +{ +lean_object* x_264; lean_object* x_265; lean_object* x_266; lean_object* x_267; lean_object* x_268; lean_object* x_269; +x_264 = lean_ctor_get(x_257, 0); +x_265 = lean_ctor_get(x_257, 1); +x_266 = lean_ctor_get(x_257, 3); +x_267 = lean_ctor_get(x_257, 4); +lean_inc(x_267); lean_inc(x_266); -if (lean_is_exclusive(x_247)) { - lean_ctor_release(x_247, 0); - lean_ctor_release(x_247, 1); - lean_ctor_release(x_247, 2); - lean_ctor_release(x_247, 3); - x_267 = x_247; -} else { - lean_dec_ref(x_247); - x_267 = lean_box(0); -} -if (lean_is_scalar(x_267)) { - x_268 = lean_alloc_ctor(0, 4, 0); -} else { - x_268 = x_267; -} +lean_inc(x_265); +lean_inc(x_264); +lean_dec(x_257); +x_268 = lean_alloc_ctor(0, 5, 0); lean_ctor_set(x_268, 0, x_264); lean_ctor_set(x_268, 1, x_265); -lean_ctor_set(x_268, 2, x_244); +lean_ctor_set(x_268, 2, x_254); lean_ctor_set(x_268, 3, x_266); -x_269 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_269, 0, x_259); -lean_ctor_set(x_269, 1, x_260); -lean_ctor_set(x_269, 2, x_268); -lean_ctor_set(x_269, 3, x_261); -lean_ctor_set(x_269, 4, x_262); -lean_ctor_set(x_269, 5, x_263); -if (lean_is_scalar(x_237)) { - x_270 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_268, 4, x_267); +lean_ctor_set(x_256, 2, x_268); +if (lean_is_scalar(x_247)) { + x_269 = lean_alloc_ctor(1, 2, 0); } else { - x_270 = x_237; - lean_ctor_set_tag(x_270, 1); + x_269 = x_247; + lean_ctor_set_tag(x_269, 1); } -lean_ctor_set(x_270, 0, x_248); -lean_ctor_set(x_270, 1, x_269); -return x_270; +lean_ctor_set(x_269, 0, x_258); +lean_ctor_set(x_269, 1, x_256); +return x_269; } } else { -lean_object* x_271; lean_object* x_272; uint8_t x_273; -x_271 = lean_ctor_get(x_246, 2); -lean_inc(x_271); -x_272 = lean_ctor_get(x_245, 0); +lean_object* x_270; lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_object* x_276; lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; lean_object* x_281; lean_object* x_282; +x_270 = lean_ctor_get(x_256, 0); +x_271 = lean_ctor_get(x_256, 1); +x_272 = lean_ctor_get(x_256, 3); +x_273 = lean_ctor_get(x_256, 4); +x_274 = lean_ctor_get(x_256, 5); +lean_inc(x_274); +lean_inc(x_273); lean_inc(x_272); -lean_dec(x_245); -x_273 = !lean_is_exclusive(x_246); -if (x_273 == 0) -{ -lean_object* x_274; uint8_t x_275; -x_274 = lean_ctor_get(x_246, 2); -lean_dec(x_274); -x_275 = !lean_is_exclusive(x_271); -if (x_275 == 0) -{ -lean_object* x_276; lean_object* x_277; -x_276 = lean_ctor_get(x_271, 2); -lean_dec(x_276); -lean_ctor_set(x_271, 2, x_244); -if (lean_is_scalar(x_237)) { - x_277 = lean_alloc_ctor(0, 2, 0); -} else { - x_277 = x_237; -} -lean_ctor_set(x_277, 0, x_272); -lean_ctor_set(x_277, 1, x_246); -return x_277; -} -else -{ -lean_object* x_278; lean_object* x_279; lean_object* x_280; lean_object* x_281; lean_object* x_282; -x_278 = lean_ctor_get(x_271, 0); -x_279 = lean_ctor_get(x_271, 1); -x_280 = lean_ctor_get(x_271, 3); -lean_inc(x_280); -lean_inc(x_279); +lean_inc(x_271); +lean_inc(x_270); +lean_dec(x_256); +x_275 = lean_ctor_get(x_257, 0); +lean_inc(x_275); +x_276 = lean_ctor_get(x_257, 1); +lean_inc(x_276); +x_277 = lean_ctor_get(x_257, 3); +lean_inc(x_277); +x_278 = lean_ctor_get(x_257, 4); lean_inc(x_278); -lean_dec(x_271); -x_281 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_281, 0, x_278); -lean_ctor_set(x_281, 1, x_279); -lean_ctor_set(x_281, 2, x_244); -lean_ctor_set(x_281, 3, x_280); -lean_ctor_set(x_246, 2, x_281); -if (lean_is_scalar(x_237)) { - x_282 = lean_alloc_ctor(0, 2, 0); +if (lean_is_exclusive(x_257)) { + lean_ctor_release(x_257, 0); + lean_ctor_release(x_257, 1); + lean_ctor_release(x_257, 2); + lean_ctor_release(x_257, 3); + lean_ctor_release(x_257, 4); + x_279 = x_257; } else { - x_282 = x_237; + lean_dec_ref(x_257); + x_279 = lean_box(0); } -lean_ctor_set(x_282, 0, x_272); -lean_ctor_set(x_282, 1, x_246); +if (lean_is_scalar(x_279)) { + x_280 = lean_alloc_ctor(0, 5, 0); +} else { + x_280 = x_279; +} +lean_ctor_set(x_280, 0, x_275); +lean_ctor_set(x_280, 1, x_276); +lean_ctor_set(x_280, 2, x_254); +lean_ctor_set(x_280, 3, x_277); +lean_ctor_set(x_280, 4, x_278); +x_281 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_281, 0, x_270); +lean_ctor_set(x_281, 1, x_271); +lean_ctor_set(x_281, 2, x_280); +lean_ctor_set(x_281, 3, x_272); +lean_ctor_set(x_281, 4, x_273); +lean_ctor_set(x_281, 5, x_274); +if (lean_is_scalar(x_247)) { + x_282 = lean_alloc_ctor(1, 2, 0); +} else { + x_282 = x_247; + lean_ctor_set_tag(x_282, 1); +} +lean_ctor_set(x_282, 0, x_258); +lean_ctor_set(x_282, 1, x_281); return x_282; } } else { -lean_object* x_283; lean_object* x_284; lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; lean_object* x_289; lean_object* x_290; lean_object* x_291; lean_object* x_292; lean_object* x_293; lean_object* x_294; -x_283 = lean_ctor_get(x_246, 0); -x_284 = lean_ctor_get(x_246, 1); -x_285 = lean_ctor_get(x_246, 3); -x_286 = lean_ctor_get(x_246, 4); -x_287 = lean_ctor_get(x_246, 5); -lean_inc(x_287); -lean_inc(x_286); -lean_inc(x_285); -lean_inc(x_284); +lean_object* x_283; lean_object* x_284; uint8_t x_285; +x_283 = lean_ctor_get(x_256, 2); lean_inc(x_283); -lean_dec(x_246); -x_288 = lean_ctor_get(x_271, 0); -lean_inc(x_288); -x_289 = lean_ctor_get(x_271, 1); -lean_inc(x_289); -x_290 = lean_ctor_get(x_271, 3); +x_284 = lean_ctor_get(x_255, 0); +lean_inc(x_284); +lean_dec(x_255); +x_285 = !lean_is_exclusive(x_256); +if (x_285 == 0) +{ +lean_object* x_286; uint8_t x_287; +x_286 = lean_ctor_get(x_256, 2); +lean_dec(x_286); +x_287 = !lean_is_exclusive(x_283); +if (x_287 == 0) +{ +lean_object* x_288; lean_object* x_289; +x_288 = lean_ctor_get(x_283, 2); +lean_dec(x_288); +lean_ctor_set(x_283, 2, x_254); +if (lean_is_scalar(x_247)) { + x_289 = lean_alloc_ctor(0, 2, 0); +} else { + x_289 = x_247; +} +lean_ctor_set(x_289, 0, x_284); +lean_ctor_set(x_289, 1, x_256); +return x_289; +} +else +{ +lean_object* x_290; lean_object* x_291; lean_object* x_292; lean_object* x_293; lean_object* x_294; lean_object* x_295; +x_290 = lean_ctor_get(x_283, 0); +x_291 = lean_ctor_get(x_283, 1); +x_292 = lean_ctor_get(x_283, 3); +x_293 = lean_ctor_get(x_283, 4); +lean_inc(x_293); +lean_inc(x_292); +lean_inc(x_291); lean_inc(x_290); -if (lean_is_exclusive(x_271)) { - lean_ctor_release(x_271, 0); - lean_ctor_release(x_271, 1); - lean_ctor_release(x_271, 2); - lean_ctor_release(x_271, 3); - x_291 = x_271; +lean_dec(x_283); +x_294 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_294, 0, x_290); +lean_ctor_set(x_294, 1, x_291); +lean_ctor_set(x_294, 2, x_254); +lean_ctor_set(x_294, 3, x_292); +lean_ctor_set(x_294, 4, x_293); +lean_ctor_set(x_256, 2, x_294); +if (lean_is_scalar(x_247)) { + x_295 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_271); - x_291 = lean_box(0); + x_295 = x_247; } -if (lean_is_scalar(x_291)) { - x_292 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_295, 0, x_284); +lean_ctor_set(x_295, 1, x_256); +return x_295; +} +} +else +{ +lean_object* x_296; lean_object* x_297; lean_object* x_298; lean_object* x_299; lean_object* x_300; lean_object* x_301; lean_object* x_302; lean_object* x_303; lean_object* x_304; lean_object* x_305; lean_object* x_306; lean_object* x_307; lean_object* x_308; +x_296 = lean_ctor_get(x_256, 0); +x_297 = lean_ctor_get(x_256, 1); +x_298 = lean_ctor_get(x_256, 3); +x_299 = lean_ctor_get(x_256, 4); +x_300 = lean_ctor_get(x_256, 5); +lean_inc(x_300); +lean_inc(x_299); +lean_inc(x_298); +lean_inc(x_297); +lean_inc(x_296); +lean_dec(x_256); +x_301 = lean_ctor_get(x_283, 0); +lean_inc(x_301); +x_302 = lean_ctor_get(x_283, 1); +lean_inc(x_302); +x_303 = lean_ctor_get(x_283, 3); +lean_inc(x_303); +x_304 = lean_ctor_get(x_283, 4); +lean_inc(x_304); +if (lean_is_exclusive(x_283)) { + lean_ctor_release(x_283, 0); + lean_ctor_release(x_283, 1); + lean_ctor_release(x_283, 2); + lean_ctor_release(x_283, 3); + lean_ctor_release(x_283, 4); + x_305 = x_283; } else { - x_292 = x_291; + lean_dec_ref(x_283); + x_305 = lean_box(0); } -lean_ctor_set(x_292, 0, x_288); -lean_ctor_set(x_292, 1, x_289); -lean_ctor_set(x_292, 2, x_244); -lean_ctor_set(x_292, 3, x_290); -x_293 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_293, 0, x_283); -lean_ctor_set(x_293, 1, x_284); -lean_ctor_set(x_293, 2, x_292); -lean_ctor_set(x_293, 3, x_285); -lean_ctor_set(x_293, 4, x_286); -lean_ctor_set(x_293, 5, x_287); -if (lean_is_scalar(x_237)) { - x_294 = lean_alloc_ctor(0, 2, 0); +if (lean_is_scalar(x_305)) { + x_306 = lean_alloc_ctor(0, 5, 0); } else { - x_294 = x_237; + x_306 = x_305; } -lean_ctor_set(x_294, 0, x_272); -lean_ctor_set(x_294, 1, x_293); -return x_294; +lean_ctor_set(x_306, 0, x_301); +lean_ctor_set(x_306, 1, x_302); +lean_ctor_set(x_306, 2, x_254); +lean_ctor_set(x_306, 3, x_303); +lean_ctor_set(x_306, 4, x_304); +x_307 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_307, 0, x_296); +lean_ctor_set(x_307, 1, x_297); +lean_ctor_set(x_307, 2, x_306); +lean_ctor_set(x_307, 3, x_298); +lean_ctor_set(x_307, 4, x_299); +lean_ctor_set(x_307, 5, x_300); +if (lean_is_scalar(x_247)) { + x_308 = lean_alloc_ctor(0, 2, 0); +} else { + x_308 = x_247; +} +lean_ctor_set(x_308, 0, x_284); +lean_ctor_set(x_308, 1, x_307); +return x_308; } } } } else { -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_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; -x_323 = lean_ctor_get(x_242, 0); -x_324 = lean_ctor_get(x_242, 1); -x_325 = lean_ctor_get(x_242, 2); -x_326 = lean_ctor_get(x_242, 3); -lean_inc(x_326); -lean_inc(x_325); -lean_inc(x_324); -lean_inc(x_323); -lean_dec(x_242); -x_360 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_361 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_361, 0, x_323); -lean_ctor_set(x_361, 1, x_324); -lean_ctor_set(x_361, 2, x_360); -lean_ctor_set(x_361, 3, x_326); -lean_ctor_set(x_236, 2, x_361); -x_362 = lean_ctor_get(x_6, 0); -lean_inc(x_362); -x_363 = lean_ctor_get(x_6, 1); -lean_inc(x_363); -x_364 = lean_ctor_get(x_6, 2); -lean_inc(x_364); -x_365 = lean_ctor_get(x_6, 3); -lean_inc(x_365); -x_366 = lean_ctor_get(x_6, 4); -lean_inc(x_366); +lean_object* x_337; lean_object* x_338; lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_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; +x_337 = lean_ctor_get(x_252, 0); +x_338 = lean_ctor_get(x_252, 1); +x_339 = lean_ctor_get(x_252, 2); +x_340 = lean_ctor_get(x_252, 3); +x_341 = lean_ctor_get(x_252, 4); +lean_inc(x_341); +lean_inc(x_340); +lean_inc(x_339); +lean_inc(x_338); +lean_inc(x_337); +lean_dec(x_252); +x_377 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_378 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_378, 0, x_337); +lean_ctor_set(x_378, 1, x_338); +lean_ctor_set(x_378, 2, x_377); +lean_ctor_set(x_378, 3, x_340); +lean_ctor_set(x_378, 4, x_341); +lean_ctor_set(x_246, 2, x_378); +x_379 = lean_ctor_get(x_6, 0); +lean_inc(x_379); +x_380 = lean_ctor_get(x_6, 1); +lean_inc(x_380); +x_381 = lean_ctor_get(x_6, 2); +lean_inc(x_381); +x_382 = lean_ctor_get(x_6, 3); +lean_inc(x_382); +x_383 = lean_ctor_get(x_6, 4); +lean_inc(x_383); if (lean_is_exclusive(x_6)) { lean_ctor_release(x_6, 0); lean_ctor_release(x_6, 1); lean_ctor_release(x_6, 2); lean_ctor_release(x_6, 3); lean_ctor_release(x_6, 4); - x_367 = x_6; + x_384 = x_6; } else { lean_dec_ref(x_6); - x_367 = lean_box(0); + x_384 = lean_box(0); } -x_368 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_368, 0, x_238); -lean_ctor_set(x_368, 1, x_13); -x_369 = lean_array_push(x_364, x_368); -if (lean_is_scalar(x_367)) { - x_370 = lean_alloc_ctor(0, 5, 0); +x_385 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_385, 0, x_248); +lean_ctor_set(x_385, 1, x_13); +x_386 = lean_array_push(x_381, x_385); +if (lean_is_scalar(x_384)) { + x_387 = lean_alloc_ctor(0, 5, 0); } else { - x_370 = x_367; + x_387 = x_384; } -lean_ctor_set(x_370, 0, x_362); -lean_ctor_set(x_370, 1, x_363); -lean_ctor_set(x_370, 2, x_369); -lean_ctor_set(x_370, 3, x_365); -lean_ctor_set(x_370, 4, x_366); -x_371 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_introN___spec__3(x_1, x_2, x_3, x_4, x_240, x_370, x_236); -if (lean_obj_tag(x_371) == 0) +lean_ctor_set(x_387, 0, x_379); +lean_ctor_set(x_387, 1, x_380); +lean_ctor_set(x_387, 2, x_386); +lean_ctor_set(x_387, 3, x_382); +lean_ctor_set(x_387, 4, x_383); +x_388 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_introN___spec__3(x_1, x_2, x_3, x_4, x_250, x_387, x_246); +if (lean_obj_tag(x_388) == 0) { -lean_object* x_372; lean_object* x_373; lean_object* x_374; -x_372 = lean_ctor_get(x_371, 0); -lean_inc(x_372); -x_373 = lean_ctor_get(x_371, 1); -lean_inc(x_373); -lean_dec(x_371); -x_374 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_374, 0, x_372); -x_327 = x_374; -x_328 = x_373; -goto block_359; +lean_object* x_389; lean_object* x_390; lean_object* x_391; +x_389 = lean_ctor_get(x_388, 0); +lean_inc(x_389); +x_390 = lean_ctor_get(x_388, 1); +lean_inc(x_390); +lean_dec(x_388); +x_391 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_391, 0, x_389); +x_342 = x_391; +x_343 = x_390; +goto block_376; } else { -lean_object* x_375; lean_object* x_376; lean_object* x_377; -x_375 = lean_ctor_get(x_371, 0); -lean_inc(x_375); -x_376 = lean_ctor_get(x_371, 1); -lean_inc(x_376); -lean_dec(x_371); -x_377 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_377, 0, x_375); -x_327 = x_377; -x_328 = x_376; -goto block_359; +lean_object* x_392; lean_object* x_393; lean_object* x_394; +x_392 = lean_ctor_get(x_388, 0); +lean_inc(x_392); +x_393 = lean_ctor_get(x_388, 1); +lean_inc(x_393); +lean_dec(x_388); +x_394 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_394, 0, x_392); +x_342 = x_394; +x_343 = x_393; +goto block_376; } -block_359: +block_376: { -if (lean_obj_tag(x_327) == 0) +if (lean_obj_tag(x_342) == 0) { -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; lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; -x_329 = lean_ctor_get(x_328, 2); -lean_inc(x_329); -x_330 = lean_ctor_get(x_327, 0); -lean_inc(x_330); -lean_dec(x_327); -x_331 = lean_ctor_get(x_328, 0); -lean_inc(x_331); -x_332 = lean_ctor_get(x_328, 1); -lean_inc(x_332); -x_333 = lean_ctor_get(x_328, 3); -lean_inc(x_333); -x_334 = lean_ctor_get(x_328, 4); -lean_inc(x_334); -x_335 = lean_ctor_get(x_328, 5); -lean_inc(x_335); -if (lean_is_exclusive(x_328)) { - lean_ctor_release(x_328, 0); - lean_ctor_release(x_328, 1); - lean_ctor_release(x_328, 2); - lean_ctor_release(x_328, 3); - lean_ctor_release(x_328, 4); - lean_ctor_release(x_328, 5); - x_336 = x_328; -} else { - lean_dec_ref(x_328); - x_336 = lean_box(0); -} -x_337 = lean_ctor_get(x_329, 0); -lean_inc(x_337); -x_338 = lean_ctor_get(x_329, 1); -lean_inc(x_338); -x_339 = lean_ctor_get(x_329, 3); -lean_inc(x_339); -if (lean_is_exclusive(x_329)) { - lean_ctor_release(x_329, 0); - lean_ctor_release(x_329, 1); - lean_ctor_release(x_329, 2); - lean_ctor_release(x_329, 3); - x_340 = x_329; -} else { - lean_dec_ref(x_329); - x_340 = lean_box(0); -} -if (lean_is_scalar(x_340)) { - x_341 = lean_alloc_ctor(0, 4, 0); -} else { - x_341 = x_340; -} -lean_ctor_set(x_341, 0, x_337); -lean_ctor_set(x_341, 1, x_338); -lean_ctor_set(x_341, 2, x_325); -lean_ctor_set(x_341, 3, x_339); -if (lean_is_scalar(x_336)) { - x_342 = lean_alloc_ctor(0, 6, 0); -} else { - x_342 = x_336; -} -lean_ctor_set(x_342, 0, x_331); -lean_ctor_set(x_342, 1, x_332); -lean_ctor_set(x_342, 2, x_341); -lean_ctor_set(x_342, 3, x_333); -lean_ctor_set(x_342, 4, x_334); -lean_ctor_set(x_342, 5, x_335); -if (lean_is_scalar(x_237)) { - x_343 = lean_alloc_ctor(1, 2, 0); -} else { - x_343 = x_237; - lean_ctor_set_tag(x_343, 1); -} -lean_ctor_set(x_343, 0, x_330); -lean_ctor_set(x_343, 1, x_342); -return x_343; -} -else -{ -lean_object* x_344; lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; lean_object* x_350; lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; lean_object* x_358; -x_344 = lean_ctor_get(x_328, 2); +lean_object* x_344; lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; lean_object* x_350; lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; lean_object* x_358; lean_object* x_359; +x_344 = lean_ctor_get(x_343, 2); lean_inc(x_344); -x_345 = lean_ctor_get(x_327, 0); +x_345 = lean_ctor_get(x_342, 0); lean_inc(x_345); -lean_dec(x_327); -x_346 = lean_ctor_get(x_328, 0); +lean_dec(x_342); +x_346 = lean_ctor_get(x_343, 0); lean_inc(x_346); -x_347 = lean_ctor_get(x_328, 1); +x_347 = lean_ctor_get(x_343, 1); lean_inc(x_347); -x_348 = lean_ctor_get(x_328, 3); +x_348 = lean_ctor_get(x_343, 3); lean_inc(x_348); -x_349 = lean_ctor_get(x_328, 4); +x_349 = lean_ctor_get(x_343, 4); lean_inc(x_349); -x_350 = lean_ctor_get(x_328, 5); +x_350 = lean_ctor_get(x_343, 5); lean_inc(x_350); -if (lean_is_exclusive(x_328)) { - lean_ctor_release(x_328, 0); - lean_ctor_release(x_328, 1); - lean_ctor_release(x_328, 2); - lean_ctor_release(x_328, 3); - lean_ctor_release(x_328, 4); - lean_ctor_release(x_328, 5); - x_351 = x_328; +if (lean_is_exclusive(x_343)) { + lean_ctor_release(x_343, 0); + lean_ctor_release(x_343, 1); + lean_ctor_release(x_343, 2); + lean_ctor_release(x_343, 3); + lean_ctor_release(x_343, 4); + lean_ctor_release(x_343, 5); + x_351 = x_343; } else { - lean_dec_ref(x_328); + lean_dec_ref(x_343); x_351 = lean_box(0); } x_352 = lean_ctor_get(x_344, 0); @@ -2440,315 +2418,411 @@ x_353 = lean_ctor_get(x_344, 1); lean_inc(x_353); x_354 = lean_ctor_get(x_344, 3); lean_inc(x_354); +x_355 = lean_ctor_get(x_344, 4); +lean_inc(x_355); if (lean_is_exclusive(x_344)) { lean_ctor_release(x_344, 0); lean_ctor_release(x_344, 1); lean_ctor_release(x_344, 2); lean_ctor_release(x_344, 3); - x_355 = x_344; + lean_ctor_release(x_344, 4); + x_356 = x_344; } else { lean_dec_ref(x_344); - x_355 = lean_box(0); + x_356 = lean_box(0); } -if (lean_is_scalar(x_355)) { - x_356 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_356)) { + x_357 = lean_alloc_ctor(0, 5, 0); } else { - x_356 = x_355; + x_357 = x_356; } -lean_ctor_set(x_356, 0, x_352); -lean_ctor_set(x_356, 1, x_353); -lean_ctor_set(x_356, 2, x_325); -lean_ctor_set(x_356, 3, x_354); +lean_ctor_set(x_357, 0, x_352); +lean_ctor_set(x_357, 1, x_353); +lean_ctor_set(x_357, 2, x_339); +lean_ctor_set(x_357, 3, x_354); +lean_ctor_set(x_357, 4, x_355); if (lean_is_scalar(x_351)) { - x_357 = lean_alloc_ctor(0, 6, 0); + x_358 = lean_alloc_ctor(0, 6, 0); } else { - x_357 = x_351; + x_358 = x_351; } -lean_ctor_set(x_357, 0, x_346); -lean_ctor_set(x_357, 1, x_347); -lean_ctor_set(x_357, 2, x_356); -lean_ctor_set(x_357, 3, x_348); -lean_ctor_set(x_357, 4, x_349); -lean_ctor_set(x_357, 5, x_350); -if (lean_is_scalar(x_237)) { - x_358 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_358, 0, x_346); +lean_ctor_set(x_358, 1, x_347); +lean_ctor_set(x_358, 2, x_357); +lean_ctor_set(x_358, 3, x_348); +lean_ctor_set(x_358, 4, x_349); +lean_ctor_set(x_358, 5, x_350); +if (lean_is_scalar(x_247)) { + x_359 = lean_alloc_ctor(1, 2, 0); } else { - x_358 = x_237; + x_359 = x_247; + lean_ctor_set_tag(x_359, 1); } -lean_ctor_set(x_358, 0, x_345); -lean_ctor_set(x_358, 1, x_357); -return x_358; +lean_ctor_set(x_359, 0, x_345); +lean_ctor_set(x_359, 1, x_358); +return x_359; +} +else +{ +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; lean_object* x_374; lean_object* x_375; +x_360 = lean_ctor_get(x_343, 2); +lean_inc(x_360); +x_361 = lean_ctor_get(x_342, 0); +lean_inc(x_361); +lean_dec(x_342); +x_362 = lean_ctor_get(x_343, 0); +lean_inc(x_362); +x_363 = lean_ctor_get(x_343, 1); +lean_inc(x_363); +x_364 = lean_ctor_get(x_343, 3); +lean_inc(x_364); +x_365 = lean_ctor_get(x_343, 4); +lean_inc(x_365); +x_366 = lean_ctor_get(x_343, 5); +lean_inc(x_366); +if (lean_is_exclusive(x_343)) { + lean_ctor_release(x_343, 0); + lean_ctor_release(x_343, 1); + lean_ctor_release(x_343, 2); + lean_ctor_release(x_343, 3); + lean_ctor_release(x_343, 4); + lean_ctor_release(x_343, 5); + x_367 = x_343; +} else { + lean_dec_ref(x_343); + x_367 = lean_box(0); +} +x_368 = lean_ctor_get(x_360, 0); +lean_inc(x_368); +x_369 = lean_ctor_get(x_360, 1); +lean_inc(x_369); +x_370 = lean_ctor_get(x_360, 3); +lean_inc(x_370); +x_371 = lean_ctor_get(x_360, 4); +lean_inc(x_371); +if (lean_is_exclusive(x_360)) { + lean_ctor_release(x_360, 0); + lean_ctor_release(x_360, 1); + lean_ctor_release(x_360, 2); + lean_ctor_release(x_360, 3); + lean_ctor_release(x_360, 4); + x_372 = x_360; +} else { + lean_dec_ref(x_360); + x_372 = lean_box(0); +} +if (lean_is_scalar(x_372)) { + x_373 = lean_alloc_ctor(0, 5, 0); +} else { + x_373 = x_372; +} +lean_ctor_set(x_373, 0, x_368); +lean_ctor_set(x_373, 1, x_369); +lean_ctor_set(x_373, 2, x_339); +lean_ctor_set(x_373, 3, x_370); +lean_ctor_set(x_373, 4, x_371); +if (lean_is_scalar(x_367)) { + x_374 = lean_alloc_ctor(0, 6, 0); +} else { + x_374 = x_367; +} +lean_ctor_set(x_374, 0, x_362); +lean_ctor_set(x_374, 1, x_363); +lean_ctor_set(x_374, 2, x_373); +lean_ctor_set(x_374, 3, x_364); +lean_ctor_set(x_374, 4, x_365); +lean_ctor_set(x_374, 5, x_366); +if (lean_is_scalar(x_247)) { + x_375 = lean_alloc_ctor(0, 2, 0); +} else { + x_375 = x_247; +} +lean_ctor_set(x_375, 0, x_361); +lean_ctor_set(x_375, 1, x_374); +return x_375; } } } } else { -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; lean_object* x_422; lean_object* x_423; lean_object* x_424; lean_object* x_425; lean_object* x_426; lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; lean_object* x_432; lean_object* x_433; lean_object* x_434; -x_378 = lean_ctor_get(x_236, 2); -x_379 = lean_ctor_get(x_236, 0); -x_380 = lean_ctor_get(x_236, 1); -x_381 = lean_ctor_get(x_236, 3); -x_382 = lean_ctor_get(x_236, 4); -x_383 = lean_ctor_get(x_236, 5); -lean_inc(x_383); -lean_inc(x_382); -lean_inc(x_381); -lean_inc(x_378); -lean_inc(x_380); -lean_inc(x_379); -lean_dec(x_236); -x_384 = lean_ctor_get(x_378, 0); -lean_inc(x_384); -x_385 = lean_ctor_get(x_378, 1); -lean_inc(x_385); -x_386 = lean_ctor_get(x_378, 2); -lean_inc(x_386); -x_387 = lean_ctor_get(x_378, 3); -lean_inc(x_387); -if (lean_is_exclusive(x_378)) { - lean_ctor_release(x_378, 0); - lean_ctor_release(x_378, 1); - lean_ctor_release(x_378, 2); - lean_ctor_release(x_378, 3); - x_388 = x_378; +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; lean_object* x_408; lean_object* x_442; lean_object* x_443; lean_object* x_444; lean_object* x_445; lean_object* x_446; lean_object* x_447; lean_object* x_448; lean_object* x_449; lean_object* x_450; lean_object* x_451; lean_object* x_452; lean_object* x_453; lean_object* x_454; +x_395 = lean_ctor_get(x_246, 2); +x_396 = lean_ctor_get(x_246, 0); +x_397 = lean_ctor_get(x_246, 1); +x_398 = lean_ctor_get(x_246, 3); +x_399 = lean_ctor_get(x_246, 4); +x_400 = lean_ctor_get(x_246, 5); +lean_inc(x_400); +lean_inc(x_399); +lean_inc(x_398); +lean_inc(x_395); +lean_inc(x_397); +lean_inc(x_396); +lean_dec(x_246); +x_401 = lean_ctor_get(x_395, 0); +lean_inc(x_401); +x_402 = lean_ctor_get(x_395, 1); +lean_inc(x_402); +x_403 = lean_ctor_get(x_395, 2); +lean_inc(x_403); +x_404 = lean_ctor_get(x_395, 3); +lean_inc(x_404); +x_405 = lean_ctor_get(x_395, 4); +lean_inc(x_405); +if (lean_is_exclusive(x_395)) { + lean_ctor_release(x_395, 0); + lean_ctor_release(x_395, 1); + lean_ctor_release(x_395, 2); + lean_ctor_release(x_395, 3); + lean_ctor_release(x_395, 4); + x_406 = x_395; } else { - lean_dec_ref(x_378); - x_388 = lean_box(0); + lean_dec_ref(x_395); + x_406 = lean_box(0); } -x_422 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_388)) { - x_423 = lean_alloc_ctor(0, 4, 0); +x_442 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_406)) { + x_443 = lean_alloc_ctor(0, 5, 0); } else { - x_423 = x_388; + x_443 = x_406; } -lean_ctor_set(x_423, 0, x_384); -lean_ctor_set(x_423, 1, x_385); -lean_ctor_set(x_423, 2, x_422); -lean_ctor_set(x_423, 3, x_387); -x_424 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_424, 0, x_379); -lean_ctor_set(x_424, 1, x_380); -lean_ctor_set(x_424, 2, x_423); -lean_ctor_set(x_424, 3, x_381); -lean_ctor_set(x_424, 4, x_382); -lean_ctor_set(x_424, 5, x_383); -x_425 = lean_ctor_get(x_6, 0); -lean_inc(x_425); -x_426 = lean_ctor_get(x_6, 1); -lean_inc(x_426); -x_427 = lean_ctor_get(x_6, 2); -lean_inc(x_427); -x_428 = lean_ctor_get(x_6, 3); -lean_inc(x_428); -x_429 = lean_ctor_get(x_6, 4); -lean_inc(x_429); +lean_ctor_set(x_443, 0, x_401); +lean_ctor_set(x_443, 1, x_402); +lean_ctor_set(x_443, 2, x_442); +lean_ctor_set(x_443, 3, x_404); +lean_ctor_set(x_443, 4, x_405); +x_444 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_444, 0, x_396); +lean_ctor_set(x_444, 1, x_397); +lean_ctor_set(x_444, 2, x_443); +lean_ctor_set(x_444, 3, x_398); +lean_ctor_set(x_444, 4, x_399); +lean_ctor_set(x_444, 5, x_400); +x_445 = lean_ctor_get(x_6, 0); +lean_inc(x_445); +x_446 = lean_ctor_get(x_6, 1); +lean_inc(x_446); +x_447 = lean_ctor_get(x_6, 2); +lean_inc(x_447); +x_448 = lean_ctor_get(x_6, 3); +lean_inc(x_448); +x_449 = lean_ctor_get(x_6, 4); +lean_inc(x_449); if (lean_is_exclusive(x_6)) { lean_ctor_release(x_6, 0); lean_ctor_release(x_6, 1); lean_ctor_release(x_6, 2); lean_ctor_release(x_6, 3); lean_ctor_release(x_6, 4); - x_430 = x_6; + x_450 = x_6; } else { lean_dec_ref(x_6); - x_430 = lean_box(0); + x_450 = lean_box(0); } -x_431 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_431, 0, x_238); -lean_ctor_set(x_431, 1, x_13); -x_432 = lean_array_push(x_427, x_431); -if (lean_is_scalar(x_430)) { - x_433 = lean_alloc_ctor(0, 5, 0); +x_451 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_451, 0, x_248); +lean_ctor_set(x_451, 1, x_13); +x_452 = lean_array_push(x_447, x_451); +if (lean_is_scalar(x_450)) { + x_453 = lean_alloc_ctor(0, 5, 0); } else { - x_433 = x_430; + x_453 = x_450; } -lean_ctor_set(x_433, 0, x_425); -lean_ctor_set(x_433, 1, x_426); -lean_ctor_set(x_433, 2, x_432); -lean_ctor_set(x_433, 3, x_428); -lean_ctor_set(x_433, 4, x_429); -x_434 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_introN___spec__3(x_1, x_2, x_3, x_4, x_240, x_433, x_424); -if (lean_obj_tag(x_434) == 0) +lean_ctor_set(x_453, 0, x_445); +lean_ctor_set(x_453, 1, x_446); +lean_ctor_set(x_453, 2, x_452); +lean_ctor_set(x_453, 3, x_448); +lean_ctor_set(x_453, 4, x_449); +x_454 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_introN___spec__3(x_1, x_2, x_3, x_4, x_250, x_453, x_444); +if (lean_obj_tag(x_454) == 0) { -lean_object* x_435; lean_object* x_436; lean_object* x_437; -x_435 = lean_ctor_get(x_434, 0); -lean_inc(x_435); -x_436 = lean_ctor_get(x_434, 1); -lean_inc(x_436); -lean_dec(x_434); -x_437 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_437, 0, x_435); -x_389 = x_437; -x_390 = x_436; -goto block_421; +lean_object* x_455; lean_object* x_456; lean_object* x_457; +x_455 = lean_ctor_get(x_454, 0); +lean_inc(x_455); +x_456 = lean_ctor_get(x_454, 1); +lean_inc(x_456); +lean_dec(x_454); +x_457 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_457, 0, x_455); +x_407 = x_457; +x_408 = x_456; +goto block_441; } else { -lean_object* x_438; lean_object* x_439; lean_object* x_440; -x_438 = lean_ctor_get(x_434, 0); -lean_inc(x_438); -x_439 = lean_ctor_get(x_434, 1); -lean_inc(x_439); -lean_dec(x_434); -x_440 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_440, 0, x_438); -x_389 = x_440; -x_390 = x_439; -goto block_421; +lean_object* x_458; lean_object* x_459; lean_object* x_460; +x_458 = lean_ctor_get(x_454, 0); +lean_inc(x_458); +x_459 = lean_ctor_get(x_454, 1); +lean_inc(x_459); +lean_dec(x_454); +x_460 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_460, 0, x_458); +x_407 = x_460; +x_408 = x_459; +goto block_441; } -block_421: +block_441: { -if (lean_obj_tag(x_389) == 0) +if (lean_obj_tag(x_407) == 0) { -lean_object* x_391; lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; lean_object* x_400; lean_object* x_401; lean_object* x_402; lean_object* x_403; lean_object* x_404; lean_object* x_405; -x_391 = lean_ctor_get(x_390, 2); -lean_inc(x_391); -x_392 = lean_ctor_get(x_389, 0); -lean_inc(x_392); -lean_dec(x_389); -x_393 = lean_ctor_get(x_390, 0); -lean_inc(x_393); -x_394 = lean_ctor_get(x_390, 1); -lean_inc(x_394); -x_395 = lean_ctor_get(x_390, 3); -lean_inc(x_395); -x_396 = lean_ctor_get(x_390, 4); -lean_inc(x_396); -x_397 = lean_ctor_get(x_390, 5); -lean_inc(x_397); -if (lean_is_exclusive(x_390)) { - lean_ctor_release(x_390, 0); - lean_ctor_release(x_390, 1); - lean_ctor_release(x_390, 2); - lean_ctor_release(x_390, 3); - lean_ctor_release(x_390, 4); - lean_ctor_release(x_390, 5); - x_398 = x_390; -} else { - lean_dec_ref(x_390); - x_398 = lean_box(0); -} -x_399 = lean_ctor_get(x_391, 0); -lean_inc(x_399); -x_400 = lean_ctor_get(x_391, 1); -lean_inc(x_400); -x_401 = lean_ctor_get(x_391, 3); -lean_inc(x_401); -if (lean_is_exclusive(x_391)) { - lean_ctor_release(x_391, 0); - lean_ctor_release(x_391, 1); - lean_ctor_release(x_391, 2); - lean_ctor_release(x_391, 3); - x_402 = x_391; -} else { - lean_dec_ref(x_391); - x_402 = lean_box(0); -} -if (lean_is_scalar(x_402)) { - x_403 = lean_alloc_ctor(0, 4, 0); -} else { - x_403 = x_402; -} -lean_ctor_set(x_403, 0, x_399); -lean_ctor_set(x_403, 1, x_400); -lean_ctor_set(x_403, 2, x_386); -lean_ctor_set(x_403, 3, x_401); -if (lean_is_scalar(x_398)) { - x_404 = lean_alloc_ctor(0, 6, 0); -} else { - x_404 = x_398; -} -lean_ctor_set(x_404, 0, x_393); -lean_ctor_set(x_404, 1, x_394); -lean_ctor_set(x_404, 2, x_403); -lean_ctor_set(x_404, 3, x_395); -lean_ctor_set(x_404, 4, x_396); -lean_ctor_set(x_404, 5, x_397); -if (lean_is_scalar(x_237)) { - x_405 = lean_alloc_ctor(1, 2, 0); -} else { - x_405 = x_237; - lean_ctor_set_tag(x_405, 1); -} -lean_ctor_set(x_405, 0, x_392); -lean_ctor_set(x_405, 1, x_404); -return x_405; -} -else -{ -lean_object* x_406; lean_object* x_407; lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_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; -x_406 = lean_ctor_get(x_390, 2); -lean_inc(x_406); -x_407 = lean_ctor_get(x_389, 0); -lean_inc(x_407); -lean_dec(x_389); -x_408 = lean_ctor_get(x_390, 0); -lean_inc(x_408); -x_409 = lean_ctor_get(x_390, 1); +lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_object* x_412; lean_object* x_413; lean_object* x_414; lean_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; +x_409 = lean_ctor_get(x_408, 2); lean_inc(x_409); -x_410 = lean_ctor_get(x_390, 3); +x_410 = lean_ctor_get(x_407, 0); lean_inc(x_410); -x_411 = lean_ctor_get(x_390, 4); +lean_dec(x_407); +x_411 = lean_ctor_get(x_408, 0); lean_inc(x_411); -x_412 = lean_ctor_get(x_390, 5); +x_412 = lean_ctor_get(x_408, 1); lean_inc(x_412); -if (lean_is_exclusive(x_390)) { - lean_ctor_release(x_390, 0); - lean_ctor_release(x_390, 1); - lean_ctor_release(x_390, 2); - lean_ctor_release(x_390, 3); - lean_ctor_release(x_390, 4); - lean_ctor_release(x_390, 5); - x_413 = x_390; -} else { - lean_dec_ref(x_390); - x_413 = lean_box(0); -} -x_414 = lean_ctor_get(x_406, 0); +x_413 = lean_ctor_get(x_408, 3); +lean_inc(x_413); +x_414 = lean_ctor_get(x_408, 4); lean_inc(x_414); -x_415 = lean_ctor_get(x_406, 1); +x_415 = lean_ctor_get(x_408, 5); lean_inc(x_415); -x_416 = lean_ctor_get(x_406, 3); -lean_inc(x_416); -if (lean_is_exclusive(x_406)) { - lean_ctor_release(x_406, 0); - lean_ctor_release(x_406, 1); - lean_ctor_release(x_406, 2); - lean_ctor_release(x_406, 3); - x_417 = x_406; +if (lean_is_exclusive(x_408)) { + lean_ctor_release(x_408, 0); + lean_ctor_release(x_408, 1); + lean_ctor_release(x_408, 2); + lean_ctor_release(x_408, 3); + lean_ctor_release(x_408, 4); + lean_ctor_release(x_408, 5); + x_416 = x_408; } else { - lean_dec_ref(x_406); - x_417 = lean_box(0); + lean_dec_ref(x_408); + x_416 = lean_box(0); } -if (lean_is_scalar(x_417)) { - x_418 = lean_alloc_ctor(0, 4, 0); +x_417 = lean_ctor_get(x_409, 0); +lean_inc(x_417); +x_418 = lean_ctor_get(x_409, 1); +lean_inc(x_418); +x_419 = lean_ctor_get(x_409, 3); +lean_inc(x_419); +x_420 = lean_ctor_get(x_409, 4); +lean_inc(x_420); +if (lean_is_exclusive(x_409)) { + lean_ctor_release(x_409, 0); + lean_ctor_release(x_409, 1); + lean_ctor_release(x_409, 2); + lean_ctor_release(x_409, 3); + lean_ctor_release(x_409, 4); + x_421 = x_409; } else { - x_418 = x_417; + lean_dec_ref(x_409); + x_421 = lean_box(0); } -lean_ctor_set(x_418, 0, x_414); -lean_ctor_set(x_418, 1, x_415); -lean_ctor_set(x_418, 2, x_386); -lean_ctor_set(x_418, 3, x_416); -if (lean_is_scalar(x_413)) { - x_419 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_421)) { + x_422 = lean_alloc_ctor(0, 5, 0); } else { - x_419 = x_413; + x_422 = x_421; } -lean_ctor_set(x_419, 0, x_408); -lean_ctor_set(x_419, 1, x_409); -lean_ctor_set(x_419, 2, x_418); -lean_ctor_set(x_419, 3, x_410); -lean_ctor_set(x_419, 4, x_411); -lean_ctor_set(x_419, 5, x_412); -if (lean_is_scalar(x_237)) { - x_420 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_422, 0, x_417); +lean_ctor_set(x_422, 1, x_418); +lean_ctor_set(x_422, 2, x_403); +lean_ctor_set(x_422, 3, x_419); +lean_ctor_set(x_422, 4, x_420); +if (lean_is_scalar(x_416)) { + x_423 = lean_alloc_ctor(0, 6, 0); } else { - x_420 = x_237; + x_423 = x_416; } -lean_ctor_set(x_420, 0, x_407); -lean_ctor_set(x_420, 1, x_419); -return x_420; +lean_ctor_set(x_423, 0, x_411); +lean_ctor_set(x_423, 1, x_412); +lean_ctor_set(x_423, 2, x_422); +lean_ctor_set(x_423, 3, x_413); +lean_ctor_set(x_423, 4, x_414); +lean_ctor_set(x_423, 5, x_415); +if (lean_is_scalar(x_247)) { + x_424 = lean_alloc_ctor(1, 2, 0); +} else { + x_424 = x_247; + lean_ctor_set_tag(x_424, 1); +} +lean_ctor_set(x_424, 0, x_410); +lean_ctor_set(x_424, 1, x_423); +return x_424; +} +else +{ +lean_object* x_425; lean_object* x_426; lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; lean_object* x_432; lean_object* x_433; lean_object* x_434; lean_object* x_435; lean_object* x_436; lean_object* x_437; lean_object* x_438; lean_object* x_439; lean_object* x_440; +x_425 = lean_ctor_get(x_408, 2); +lean_inc(x_425); +x_426 = lean_ctor_get(x_407, 0); +lean_inc(x_426); +lean_dec(x_407); +x_427 = lean_ctor_get(x_408, 0); +lean_inc(x_427); +x_428 = lean_ctor_get(x_408, 1); +lean_inc(x_428); +x_429 = lean_ctor_get(x_408, 3); +lean_inc(x_429); +x_430 = lean_ctor_get(x_408, 4); +lean_inc(x_430); +x_431 = lean_ctor_get(x_408, 5); +lean_inc(x_431); +if (lean_is_exclusive(x_408)) { + lean_ctor_release(x_408, 0); + lean_ctor_release(x_408, 1); + lean_ctor_release(x_408, 2); + lean_ctor_release(x_408, 3); + lean_ctor_release(x_408, 4); + lean_ctor_release(x_408, 5); + x_432 = x_408; +} else { + lean_dec_ref(x_408); + x_432 = lean_box(0); +} +x_433 = lean_ctor_get(x_425, 0); +lean_inc(x_433); +x_434 = lean_ctor_get(x_425, 1); +lean_inc(x_434); +x_435 = lean_ctor_get(x_425, 3); +lean_inc(x_435); +x_436 = lean_ctor_get(x_425, 4); +lean_inc(x_436); +if (lean_is_exclusive(x_425)) { + lean_ctor_release(x_425, 0); + lean_ctor_release(x_425, 1); + lean_ctor_release(x_425, 2); + lean_ctor_release(x_425, 3); + lean_ctor_release(x_425, 4); + x_437 = x_425; +} else { + lean_dec_ref(x_425); + x_437 = lean_box(0); +} +if (lean_is_scalar(x_437)) { + x_438 = lean_alloc_ctor(0, 5, 0); +} else { + x_438 = x_437; +} +lean_ctor_set(x_438, 0, x_433); +lean_ctor_set(x_438, 1, x_434); +lean_ctor_set(x_438, 2, x_403); +lean_ctor_set(x_438, 3, x_435); +lean_ctor_set(x_438, 4, x_436); +if (lean_is_scalar(x_432)) { + x_439 = lean_alloc_ctor(0, 6, 0); +} else { + x_439 = x_432; +} +lean_ctor_set(x_439, 0, x_427); +lean_ctor_set(x_439, 1, x_428); +lean_ctor_set(x_439, 2, x_438); +lean_ctor_set(x_439, 3, x_429); +lean_ctor_set(x_439, 4, x_430); +lean_ctor_set(x_439, 5, x_431); +if (lean_is_scalar(x_247)) { + x_440 = lean_alloc_ctor(0, 2, 0); +} else { + x_440 = x_247; +} +lean_ctor_set(x_440, 0, x_426); +lean_ctor_set(x_440, 1, x_439); +return x_440; } } } @@ -2756,30 +2830,30 @@ return x_420; } else { -uint8_t x_441; +uint8_t x_461; lean_dec(x_13); lean_dec(x_6); lean_dec(x_5); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_441 = !lean_is_exclusive(x_230); -if (x_441 == 0) +x_461 = !lean_is_exclusive(x_240); +if (x_461 == 0) { -return x_230; +return x_240; } else { -lean_object* x_442; lean_object* x_443; lean_object* x_444; -x_442 = lean_ctor_get(x_230, 0); -x_443 = lean_ctor_get(x_230, 1); -lean_inc(x_443); -lean_inc(x_442); -lean_dec(x_230); -x_444 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_444, 0, x_442); -lean_ctor_set(x_444, 1, x_443); -return x_444; +lean_object* x_462; lean_object* x_463; lean_object* x_464; +x_462 = lean_ctor_get(x_240, 0); +x_463 = lean_ctor_get(x_240, 1); +lean_inc(x_463); +lean_inc(x_462); +lean_dec(x_240); +x_464 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_464, 0, x_462); +lean_ctor_set(x_464, 1, x_463); +return x_464; } } } @@ -2787,7 +2861,7 @@ return x_444; } else { -uint8_t x_445; +uint8_t x_465; lean_dec(x_17); lean_dec(x_13); lean_dec(x_6); @@ -2795,52 +2869,52 @@ lean_dec(x_5); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_445 = !lean_is_exclusive(x_18); -if (x_445 == 0) +x_465 = !lean_is_exclusive(x_18); +if (x_465 == 0) { return x_18; } else { -lean_object* x_446; lean_object* x_447; lean_object* x_448; -x_446 = lean_ctor_get(x_18, 0); -x_447 = lean_ctor_get(x_18, 1); -lean_inc(x_447); -lean_inc(x_446); +lean_object* x_466; lean_object* x_467; lean_object* x_468; +x_466 = lean_ctor_get(x_18, 0); +x_467 = lean_ctor_get(x_18, 1); +lean_inc(x_467); +lean_inc(x_466); lean_dec(x_18); -x_448 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_448, 0, x_446); -lean_ctor_set(x_448, 1, x_447); -return x_448; +x_468 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_468, 0, x_466); +lean_ctor_set(x_468, 1, x_467); +return x_468; } } } else { -uint8_t x_449; +uint8_t x_469; lean_dec(x_13); lean_dec(x_6); lean_dec(x_5); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_449 = !lean_is_exclusive(x_14); -if (x_449 == 0) +x_469 = !lean_is_exclusive(x_14); +if (x_469 == 0) { return x_14; } else { -lean_object* x_450; lean_object* x_451; lean_object* x_452; -x_450 = lean_ctor_get(x_14, 0); -x_451 = lean_ctor_get(x_14, 1); -lean_inc(x_451); -lean_inc(x_450); +lean_object* x_470; lean_object* x_471; lean_object* x_472; +x_470 = lean_ctor_get(x_14, 0); +x_471 = lean_ctor_get(x_14, 1); +lean_inc(x_471); +lean_inc(x_470); lean_dec(x_14); -x_452 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_452, 0, x_450); -lean_ctor_set(x_452, 1, x_451); -return x_452; +x_472 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_472, 0, x_470); +lean_ctor_set(x_472, 1, x_471); +return x_472; } } } @@ -2982,105 +3056,105 @@ x_38 = lean_ctor_get(x_32, 2); x_39 = !lean_is_exclusive(x_38); if (x_39 == 0) { -lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_92; uint8_t x_93; +lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_96; uint8_t x_97; x_40 = lean_ctor_get(x_38, 2); -x_92 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_38, 2, x_92); -x_93 = !lean_is_exclusive(x_12); -if (x_93 == 0) +x_96 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_38, 2, x_96); +x_97 = !lean_is_exclusive(x_12); +if (x_97 == 0) { -lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; -x_94 = lean_ctor_get(x_12, 2); -x_95 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_95, 0, x_34); -lean_ctor_set(x_95, 1, x_21); -x_96 = lean_array_push(x_94, x_95); -lean_ctor_set(x_12, 2, x_96); -x_97 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_introN___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_36, x_12, x_32); -if (lean_obj_tag(x_97) == 0) +lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; +x_98 = lean_ctor_get(x_12, 2); +x_99 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_99, 0, x_34); +lean_ctor_set(x_99, 1, x_21); +x_100 = lean_array_push(x_98, x_99); +lean_ctor_set(x_12, 2, x_100); +x_101 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_introN___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_36, x_12, x_32); +if (lean_obj_tag(x_101) == 0) { -lean_object* x_98; lean_object* x_99; lean_object* x_100; -x_98 = lean_ctor_get(x_97, 0); -lean_inc(x_98); -x_99 = lean_ctor_get(x_97, 1); -lean_inc(x_99); -lean_dec(x_97); -x_100 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_100, 0, x_98); -x_41 = x_100; -x_42 = x_99; -goto block_91; -} -else -{ -lean_object* x_101; lean_object* x_102; lean_object* x_103; -x_101 = lean_ctor_get(x_97, 0); -lean_inc(x_101); -x_102 = lean_ctor_get(x_97, 1); +lean_object* x_102; lean_object* x_103; lean_object* x_104; +x_102 = lean_ctor_get(x_101, 0); lean_inc(x_102); -lean_dec(x_97); -x_103 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_103, 0, x_101); -x_41 = x_103; -x_42 = x_102; -goto block_91; -} +x_103 = lean_ctor_get(x_101, 1); +lean_inc(x_103); +lean_dec(x_101); +x_104 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_104, 0, x_102); +x_41 = x_104; +x_42 = x_103; +goto block_95; } else { -lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; -x_104 = lean_ctor_get(x_12, 0); -x_105 = lean_ctor_get(x_12, 1); -x_106 = lean_ctor_get(x_12, 2); -x_107 = lean_ctor_get(x_12, 3); -x_108 = lean_ctor_get(x_12, 4); -lean_inc(x_108); -lean_inc(x_107); -lean_inc(x_106); +lean_object* x_105; lean_object* x_106; lean_object* x_107; +x_105 = lean_ctor_get(x_101, 0); lean_inc(x_105); -lean_inc(x_104); -lean_dec(x_12); -x_109 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_109, 0, x_34); -lean_ctor_set(x_109, 1, x_21); -x_110 = lean_array_push(x_106, x_109); -x_111 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_111, 0, x_104); -lean_ctor_set(x_111, 1, x_105); -lean_ctor_set(x_111, 2, x_110); -lean_ctor_set(x_111, 3, x_107); -lean_ctor_set(x_111, 4, x_108); -x_112 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_introN___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_36, x_111, x_32); -if (lean_obj_tag(x_112) == 0) -{ -lean_object* x_113; lean_object* x_114; lean_object* x_115; -x_113 = lean_ctor_get(x_112, 0); -lean_inc(x_113); -x_114 = lean_ctor_get(x_112, 1); -lean_inc(x_114); -lean_dec(x_112); -x_115 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_115, 0, x_113); -x_41 = x_115; -x_42 = x_114; -goto block_91; +x_106 = lean_ctor_get(x_101, 1); +lean_inc(x_106); +lean_dec(x_101); +x_107 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_107, 0, x_105); +x_41 = x_107; +x_42 = x_106; +goto block_95; +} } else { -lean_object* x_116; lean_object* x_117; lean_object* x_118; -x_116 = lean_ctor_get(x_112, 0); -lean_inc(x_116); -x_117 = lean_ctor_get(x_112, 1); +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; +x_108 = lean_ctor_get(x_12, 0); +x_109 = lean_ctor_get(x_12, 1); +x_110 = lean_ctor_get(x_12, 2); +x_111 = lean_ctor_get(x_12, 3); +x_112 = lean_ctor_get(x_12, 4); +lean_inc(x_112); +lean_inc(x_111); +lean_inc(x_110); +lean_inc(x_109); +lean_inc(x_108); +lean_dec(x_12); +x_113 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_113, 0, x_34); +lean_ctor_set(x_113, 1, x_21); +x_114 = lean_array_push(x_110, x_113); +x_115 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_115, 0, x_108); +lean_ctor_set(x_115, 1, x_109); +lean_ctor_set(x_115, 2, x_114); +lean_ctor_set(x_115, 3, x_111); +lean_ctor_set(x_115, 4, x_112); +x_116 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_introN___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_36, x_115, x_32); +if (lean_obj_tag(x_116) == 0) +{ +lean_object* x_117; lean_object* x_118; lean_object* x_119; +x_117 = lean_ctor_get(x_116, 0); lean_inc(x_117); -lean_dec(x_112); -x_118 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_118, 0, x_116); -x_41 = x_118; -x_42 = x_117; -goto block_91; +x_118 = lean_ctor_get(x_116, 1); +lean_inc(x_118); +lean_dec(x_116); +x_119 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_119, 0, x_117); +x_41 = x_119; +x_42 = x_118; +goto block_95; +} +else +{ +lean_object* x_120; lean_object* x_121; lean_object* x_122; +x_120 = lean_ctor_get(x_116, 0); +lean_inc(x_120); +x_121 = lean_ctor_get(x_116, 1); +lean_inc(x_121); +lean_dec(x_116); +x_122 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_122, 0, x_120); +x_41 = x_122; +x_42 = x_121; +goto block_95; } } -block_91: +block_95: { if (lean_obj_tag(x_41) == 0) { @@ -3115,1284 +3189,1262 @@ 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_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; x_50 = lean_ctor_get(x_43, 0); x_51 = lean_ctor_get(x_43, 1); x_52 = lean_ctor_get(x_43, 3); +x_53 = lean_ctor_get(x_43, 4); +lean_inc(x_53); lean_inc(x_52); lean_inc(x_51); lean_inc(x_50); lean_dec(x_43); -x_53 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_53, 0, x_50); -lean_ctor_set(x_53, 1, x_51); -lean_ctor_set(x_53, 2, x_40); -lean_ctor_set(x_53, 3, x_52); -lean_ctor_set(x_42, 2, x_53); +x_54 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_54, 0, x_50); +lean_ctor_set(x_54, 1, x_51); +lean_ctor_set(x_54, 2, x_40); +lean_ctor_set(x_54, 3, x_52); +lean_ctor_set(x_54, 4, x_53); +lean_ctor_set(x_42, 2, x_54); if (lean_is_scalar(x_33)) { - x_54 = lean_alloc_ctor(1, 2, 0); + x_55 = lean_alloc_ctor(1, 2, 0); } else { - x_54 = x_33; - lean_ctor_set_tag(x_54, 1); + x_55 = x_33; + lean_ctor_set_tag(x_55, 1); } -lean_ctor_set(x_54, 0, x_44); -lean_ctor_set(x_54, 1, x_42); -return x_54; +lean_ctor_set(x_55, 0, x_44); +lean_ctor_set(x_55, 1, x_42); +return x_55; } } else { -lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; -x_55 = lean_ctor_get(x_42, 0); -x_56 = lean_ctor_get(x_42, 1); -x_57 = lean_ctor_get(x_42, 3); -x_58 = lean_ctor_get(x_42, 4); -x_59 = lean_ctor_get(x_42, 5); +lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; +x_56 = lean_ctor_get(x_42, 0); +x_57 = lean_ctor_get(x_42, 1); +x_58 = lean_ctor_get(x_42, 3); +x_59 = lean_ctor_get(x_42, 4); +x_60 = lean_ctor_get(x_42, 5); +lean_inc(x_60); lean_inc(x_59); lean_inc(x_58); lean_inc(x_57); lean_inc(x_56); -lean_inc(x_55); lean_dec(x_42); -x_60 = lean_ctor_get(x_43, 0); -lean_inc(x_60); -x_61 = lean_ctor_get(x_43, 1); +x_61 = lean_ctor_get(x_43, 0); lean_inc(x_61); -x_62 = lean_ctor_get(x_43, 3); +x_62 = lean_ctor_get(x_43, 1); lean_inc(x_62); +x_63 = lean_ctor_get(x_43, 3); +lean_inc(x_63); +x_64 = lean_ctor_get(x_43, 4); +lean_inc(x_64); if (lean_is_exclusive(x_43)) { lean_ctor_release(x_43, 0); lean_ctor_release(x_43, 1); lean_ctor_release(x_43, 2); lean_ctor_release(x_43, 3); - x_63 = x_43; + lean_ctor_release(x_43, 4); + x_65 = x_43; } else { lean_dec_ref(x_43); - x_63 = lean_box(0); + x_65 = lean_box(0); } -if (lean_is_scalar(x_63)) { - x_64 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_65)) { + x_66 = lean_alloc_ctor(0, 5, 0); } else { - x_64 = x_63; + x_66 = x_65; } -lean_ctor_set(x_64, 0, x_60); -lean_ctor_set(x_64, 1, x_61); -lean_ctor_set(x_64, 2, x_40); -lean_ctor_set(x_64, 3, x_62); -x_65 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_65, 0, x_55); -lean_ctor_set(x_65, 1, x_56); -lean_ctor_set(x_65, 2, x_64); -lean_ctor_set(x_65, 3, x_57); -lean_ctor_set(x_65, 4, x_58); -lean_ctor_set(x_65, 5, x_59); +lean_ctor_set(x_66, 0, x_61); +lean_ctor_set(x_66, 1, x_62); +lean_ctor_set(x_66, 2, x_40); +lean_ctor_set(x_66, 3, x_63); +lean_ctor_set(x_66, 4, x_64); +x_67 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_67, 0, x_56); +lean_ctor_set(x_67, 1, x_57); +lean_ctor_set(x_67, 2, x_66); +lean_ctor_set(x_67, 3, x_58); +lean_ctor_set(x_67, 4, x_59); +lean_ctor_set(x_67, 5, x_60); if (lean_is_scalar(x_33)) { - x_66 = lean_alloc_ctor(1, 2, 0); + x_68 = lean_alloc_ctor(1, 2, 0); } else { - x_66 = x_33; - lean_ctor_set_tag(x_66, 1); + x_68 = x_33; + lean_ctor_set_tag(x_68, 1); } -lean_ctor_set(x_66, 0, x_44); -lean_ctor_set(x_66, 1, x_65); -return x_66; +lean_ctor_set(x_68, 0, x_44); +lean_ctor_set(x_68, 1, x_67); +return x_68; } } else { -lean_object* x_67; lean_object* x_68; uint8_t x_69; -x_67 = lean_ctor_get(x_42, 2); -lean_inc(x_67); -x_68 = lean_ctor_get(x_41, 0); -lean_inc(x_68); +lean_object* x_69; lean_object* x_70; uint8_t x_71; +x_69 = lean_ctor_get(x_42, 2); +lean_inc(x_69); +x_70 = lean_ctor_get(x_41, 0); +lean_inc(x_70); lean_dec(x_41); -x_69 = !lean_is_exclusive(x_42); -if (x_69 == 0) -{ -lean_object* x_70; uint8_t x_71; -x_70 = lean_ctor_get(x_42, 2); -lean_dec(x_70); -x_71 = !lean_is_exclusive(x_67); +x_71 = !lean_is_exclusive(x_42); if (x_71 == 0) { -lean_object* x_72; lean_object* x_73; -x_72 = lean_ctor_get(x_67, 2); +lean_object* x_72; uint8_t x_73; +x_72 = lean_ctor_get(x_42, 2); lean_dec(x_72); -lean_ctor_set(x_67, 2, x_40); +x_73 = !lean_is_exclusive(x_69); +if (x_73 == 0) +{ +lean_object* x_74; lean_object* x_75; +x_74 = lean_ctor_get(x_69, 2); +lean_dec(x_74); +lean_ctor_set(x_69, 2, x_40); if (lean_is_scalar(x_33)) { - x_73 = lean_alloc_ctor(0, 2, 0); + x_75 = lean_alloc_ctor(0, 2, 0); } else { - x_73 = x_33; + x_75 = x_33; } -lean_ctor_set(x_73, 0, x_68); -lean_ctor_set(x_73, 1, x_42); -return x_73; +lean_ctor_set(x_75, 0, x_70); +lean_ctor_set(x_75, 1, x_42); +return x_75; } else { -lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; -x_74 = lean_ctor_get(x_67, 0); -x_75 = lean_ctor_get(x_67, 1); -x_76 = lean_ctor_get(x_67, 3); +lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; +x_76 = lean_ctor_get(x_69, 0); +x_77 = lean_ctor_get(x_69, 1); +x_78 = lean_ctor_get(x_69, 3); +x_79 = lean_ctor_get(x_69, 4); +lean_inc(x_79); +lean_inc(x_78); +lean_inc(x_77); lean_inc(x_76); -lean_inc(x_75); -lean_inc(x_74); -lean_dec(x_67); -x_77 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_77, 0, x_74); -lean_ctor_set(x_77, 1, x_75); -lean_ctor_set(x_77, 2, x_40); -lean_ctor_set(x_77, 3, x_76); -lean_ctor_set(x_42, 2, x_77); +lean_dec(x_69); +x_80 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_80, 0, x_76); +lean_ctor_set(x_80, 1, x_77); +lean_ctor_set(x_80, 2, x_40); +lean_ctor_set(x_80, 3, x_78); +lean_ctor_set(x_80, 4, x_79); +lean_ctor_set(x_42, 2, x_80); if (lean_is_scalar(x_33)) { - x_78 = lean_alloc_ctor(0, 2, 0); + x_81 = lean_alloc_ctor(0, 2, 0); } else { - x_78 = x_33; + x_81 = x_33; } -lean_ctor_set(x_78, 0, x_68); -lean_ctor_set(x_78, 1, x_42); -return x_78; +lean_ctor_set(x_81, 0, x_70); +lean_ctor_set(x_81, 1, x_42); +return x_81; } } else { -lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; -x_79 = lean_ctor_get(x_42, 0); -x_80 = lean_ctor_get(x_42, 1); -x_81 = lean_ctor_get(x_42, 3); -x_82 = lean_ctor_get(x_42, 4); -x_83 = lean_ctor_get(x_42, 5); +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; +x_82 = lean_ctor_get(x_42, 0); +x_83 = lean_ctor_get(x_42, 1); +x_84 = lean_ctor_get(x_42, 3); +x_85 = lean_ctor_get(x_42, 4); +x_86 = lean_ctor_get(x_42, 5); +lean_inc(x_86); +lean_inc(x_85); +lean_inc(x_84); lean_inc(x_83); lean_inc(x_82); -lean_inc(x_81); -lean_inc(x_80); -lean_inc(x_79); lean_dec(x_42); -x_84 = lean_ctor_get(x_67, 0); -lean_inc(x_84); -x_85 = lean_ctor_get(x_67, 1); -lean_inc(x_85); -x_86 = lean_ctor_get(x_67, 3); -lean_inc(x_86); -if (lean_is_exclusive(x_67)) { - lean_ctor_release(x_67, 0); - lean_ctor_release(x_67, 1); - lean_ctor_release(x_67, 2); - lean_ctor_release(x_67, 3); - x_87 = x_67; +x_87 = lean_ctor_get(x_69, 0); +lean_inc(x_87); +x_88 = lean_ctor_get(x_69, 1); +lean_inc(x_88); +x_89 = lean_ctor_get(x_69, 3); +lean_inc(x_89); +x_90 = lean_ctor_get(x_69, 4); +lean_inc(x_90); +if (lean_is_exclusive(x_69)) { + lean_ctor_release(x_69, 0); + lean_ctor_release(x_69, 1); + lean_ctor_release(x_69, 2); + lean_ctor_release(x_69, 3); + lean_ctor_release(x_69, 4); + x_91 = x_69; } else { - lean_dec_ref(x_67); - x_87 = lean_box(0); + lean_dec_ref(x_69); + x_91 = lean_box(0); } -if (lean_is_scalar(x_87)) { - x_88 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_91)) { + x_92 = lean_alloc_ctor(0, 5, 0); } else { - x_88 = x_87; + x_92 = x_91; } -lean_ctor_set(x_88, 0, x_84); -lean_ctor_set(x_88, 1, x_85); -lean_ctor_set(x_88, 2, x_40); -lean_ctor_set(x_88, 3, x_86); -x_89 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_89, 0, x_79); -lean_ctor_set(x_89, 1, x_80); -lean_ctor_set(x_89, 2, x_88); -lean_ctor_set(x_89, 3, x_81); -lean_ctor_set(x_89, 4, x_82); -lean_ctor_set(x_89, 5, x_83); +lean_ctor_set(x_92, 0, x_87); +lean_ctor_set(x_92, 1, x_88); +lean_ctor_set(x_92, 2, x_40); +lean_ctor_set(x_92, 3, x_89); +lean_ctor_set(x_92, 4, x_90); +x_93 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_93, 0, x_82); +lean_ctor_set(x_93, 1, x_83); +lean_ctor_set(x_93, 2, x_92); +lean_ctor_set(x_93, 3, x_84); +lean_ctor_set(x_93, 4, x_85); +lean_ctor_set(x_93, 5, x_86); if (lean_is_scalar(x_33)) { - x_90 = lean_alloc_ctor(0, 2, 0); + x_94 = lean_alloc_ctor(0, 2, 0); } else { - x_90 = x_33; + x_94 = x_33; } -lean_ctor_set(x_90, 0, x_68); -lean_ctor_set(x_90, 1, x_89); -return x_90; +lean_ctor_set(x_94, 0, x_70); +lean_ctor_set(x_94, 1, x_93); +return x_94; } } } } else { -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_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; -x_119 = lean_ctor_get(x_38, 0); -x_120 = lean_ctor_get(x_38, 1); -x_121 = lean_ctor_get(x_38, 2); -x_122 = lean_ctor_get(x_38, 3); -lean_inc(x_122); -lean_inc(x_121); -lean_inc(x_120); -lean_inc(x_119); -lean_dec(x_38); -x_156 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_157 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_157, 0, x_119); -lean_ctor_set(x_157, 1, x_120); -lean_ctor_set(x_157, 2, x_156); -lean_ctor_set(x_157, 3, x_122); -lean_ctor_set(x_32, 2, x_157); -x_158 = lean_ctor_get(x_12, 0); -lean_inc(x_158); -x_159 = lean_ctor_get(x_12, 1); -lean_inc(x_159); -x_160 = lean_ctor_get(x_12, 2); -lean_inc(x_160); -x_161 = lean_ctor_get(x_12, 3); -lean_inc(x_161); -x_162 = lean_ctor_get(x_12, 4); -lean_inc(x_162); -if (lean_is_exclusive(x_12)) { - lean_ctor_release(x_12, 0); - lean_ctor_release(x_12, 1); - lean_ctor_release(x_12, 2); - lean_ctor_release(x_12, 3); - lean_ctor_release(x_12, 4); - x_163 = x_12; -} else { - lean_dec_ref(x_12); - x_163 = lean_box(0); -} -x_164 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_164, 0, x_34); -lean_ctor_set(x_164, 1, x_21); -x_165 = lean_array_push(x_160, x_164); -if (lean_is_scalar(x_163)) { - x_166 = lean_alloc_ctor(0, 5, 0); -} else { - x_166 = x_163; -} -lean_ctor_set(x_166, 0, x_158); -lean_ctor_set(x_166, 1, x_159); -lean_ctor_set(x_166, 2, x_165); -lean_ctor_set(x_166, 3, x_161); -lean_ctor_set(x_166, 4, x_162); -x_167 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_introN___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_36, x_166, x_32); -if (lean_obj_tag(x_167) == 0) -{ -lean_object* x_168; lean_object* x_169; lean_object* x_170; -x_168 = lean_ctor_get(x_167, 0); -lean_inc(x_168); -x_169 = lean_ctor_get(x_167, 1); -lean_inc(x_169); -lean_dec(x_167); -x_170 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_170, 0, x_168); -x_123 = x_170; -x_124 = x_169; -goto block_155; -} -else -{ -lean_object* x_171; lean_object* x_172; lean_object* x_173; -x_171 = lean_ctor_get(x_167, 0); -lean_inc(x_171); -x_172 = lean_ctor_get(x_167, 1); -lean_inc(x_172); -lean_dec(x_167); -x_173 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_173, 0, x_171); -x_123 = x_173; -x_124 = x_172; -goto block_155; -} -block_155: -{ -if (lean_obj_tag(x_123) == 0) -{ -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; -x_125 = lean_ctor_get(x_124, 2); -lean_inc(x_125); -x_126 = lean_ctor_get(x_123, 0); -lean_inc(x_126); -lean_dec(x_123); -x_127 = lean_ctor_get(x_124, 0); +lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; lean_object* x_173; lean_object* x_174; +x_123 = lean_ctor_get(x_38, 0); +x_124 = lean_ctor_get(x_38, 1); +x_125 = lean_ctor_get(x_38, 2); +x_126 = lean_ctor_get(x_38, 3); +x_127 = lean_ctor_get(x_38, 4); lean_inc(x_127); -x_128 = lean_ctor_get(x_124, 1); -lean_inc(x_128); -x_129 = lean_ctor_get(x_124, 3); -lean_inc(x_129); -x_130 = lean_ctor_get(x_124, 4); -lean_inc(x_130); -x_131 = lean_ctor_get(x_124, 5); -lean_inc(x_131); -if (lean_is_exclusive(x_124)) { - lean_ctor_release(x_124, 0); - lean_ctor_release(x_124, 1); - lean_ctor_release(x_124, 2); - lean_ctor_release(x_124, 3); - lean_ctor_release(x_124, 4); - lean_ctor_release(x_124, 5); - x_132 = x_124; -} else { - lean_dec_ref(x_124); - x_132 = lean_box(0); -} -x_133 = lean_ctor_get(x_125, 0); -lean_inc(x_133); -x_134 = lean_ctor_get(x_125, 1); -lean_inc(x_134); -x_135 = lean_ctor_get(x_125, 3); -lean_inc(x_135); -if (lean_is_exclusive(x_125)) { - lean_ctor_release(x_125, 0); - lean_ctor_release(x_125, 1); - lean_ctor_release(x_125, 2); - lean_ctor_release(x_125, 3); - x_136 = x_125; -} else { - lean_dec_ref(x_125); - x_136 = lean_box(0); -} -if (lean_is_scalar(x_136)) { - x_137 = lean_alloc_ctor(0, 4, 0); -} else { - x_137 = x_136; -} -lean_ctor_set(x_137, 0, x_133); -lean_ctor_set(x_137, 1, x_134); -lean_ctor_set(x_137, 2, x_121); -lean_ctor_set(x_137, 3, x_135); -if (lean_is_scalar(x_132)) { - x_138 = lean_alloc_ctor(0, 6, 0); -} else { - x_138 = x_132; -} -lean_ctor_set(x_138, 0, x_127); -lean_ctor_set(x_138, 1, x_128); -lean_ctor_set(x_138, 2, x_137); -lean_ctor_set(x_138, 3, x_129); -lean_ctor_set(x_138, 4, x_130); -lean_ctor_set(x_138, 5, x_131); -if (lean_is_scalar(x_33)) { - x_139 = lean_alloc_ctor(1, 2, 0); -} else { - x_139 = x_33; - lean_ctor_set_tag(x_139, 1); -} -lean_ctor_set(x_139, 0, x_126); -lean_ctor_set(x_139, 1, x_138); -return x_139; -} -else -{ -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; -x_140 = lean_ctor_get(x_124, 2); -lean_inc(x_140); -x_141 = lean_ctor_get(x_123, 0); -lean_inc(x_141); -lean_dec(x_123); -x_142 = lean_ctor_get(x_124, 0); -lean_inc(x_142); -x_143 = lean_ctor_get(x_124, 1); -lean_inc(x_143); -x_144 = lean_ctor_get(x_124, 3); -lean_inc(x_144); -x_145 = lean_ctor_get(x_124, 4); -lean_inc(x_145); -x_146 = lean_ctor_get(x_124, 5); -lean_inc(x_146); -if (lean_is_exclusive(x_124)) { - lean_ctor_release(x_124, 0); - lean_ctor_release(x_124, 1); - lean_ctor_release(x_124, 2); - lean_ctor_release(x_124, 3); - lean_ctor_release(x_124, 4); - lean_ctor_release(x_124, 5); - x_147 = x_124; -} else { - lean_dec_ref(x_124); - x_147 = lean_box(0); -} -x_148 = lean_ctor_get(x_140, 0); -lean_inc(x_148); -x_149 = lean_ctor_get(x_140, 1); -lean_inc(x_149); -x_150 = lean_ctor_get(x_140, 3); -lean_inc(x_150); -if (lean_is_exclusive(x_140)) { - lean_ctor_release(x_140, 0); - lean_ctor_release(x_140, 1); - lean_ctor_release(x_140, 2); - lean_ctor_release(x_140, 3); - x_151 = x_140; -} else { - lean_dec_ref(x_140); - x_151 = lean_box(0); -} -if (lean_is_scalar(x_151)) { - x_152 = lean_alloc_ctor(0, 4, 0); -} else { - x_152 = x_151; -} -lean_ctor_set(x_152, 0, x_148); -lean_ctor_set(x_152, 1, x_149); -lean_ctor_set(x_152, 2, x_121); -lean_ctor_set(x_152, 3, x_150); -if (lean_is_scalar(x_147)) { - x_153 = lean_alloc_ctor(0, 6, 0); -} else { - x_153 = x_147; -} -lean_ctor_set(x_153, 0, x_142); -lean_ctor_set(x_153, 1, x_143); -lean_ctor_set(x_153, 2, x_152); -lean_ctor_set(x_153, 3, x_144); -lean_ctor_set(x_153, 4, x_145); -lean_ctor_set(x_153, 5, x_146); -if (lean_is_scalar(x_33)) { - x_154 = lean_alloc_ctor(0, 2, 0); -} else { - x_154 = x_33; -} -lean_ctor_set(x_154, 0, x_141); -lean_ctor_set(x_154, 1, x_153); -return x_154; -} -} -} -} -else -{ -lean_object* x_174; lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; 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_174 = lean_ctor_get(x_32, 2); -x_175 = lean_ctor_get(x_32, 0); -x_176 = lean_ctor_get(x_32, 1); -x_177 = lean_ctor_get(x_32, 3); -x_178 = lean_ctor_get(x_32, 4); -x_179 = lean_ctor_get(x_32, 5); -lean_inc(x_179); -lean_inc(x_178); -lean_inc(x_177); -lean_inc(x_174); -lean_inc(x_176); -lean_inc(x_175); -lean_dec(x_32); -x_180 = lean_ctor_get(x_174, 0); -lean_inc(x_180); -x_181 = lean_ctor_get(x_174, 1); -lean_inc(x_181); -x_182 = lean_ctor_get(x_174, 2); -lean_inc(x_182); -x_183 = lean_ctor_get(x_174, 3); -lean_inc(x_183); -if (lean_is_exclusive(x_174)) { - lean_ctor_release(x_174, 0); - lean_ctor_release(x_174, 1); - lean_ctor_release(x_174, 2); - lean_ctor_release(x_174, 3); - x_184 = x_174; -} else { - lean_dec_ref(x_174); - x_184 = lean_box(0); -} -x_218 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_184)) { - x_219 = lean_alloc_ctor(0, 4, 0); -} else { - x_219 = x_184; -} -lean_ctor_set(x_219, 0, x_180); -lean_ctor_set(x_219, 1, x_181); -lean_ctor_set(x_219, 2, x_218); -lean_ctor_set(x_219, 3, x_183); -x_220 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_220, 0, x_175); -lean_ctor_set(x_220, 1, x_176); -lean_ctor_set(x_220, 2, x_219); -lean_ctor_set(x_220, 3, x_177); -lean_ctor_set(x_220, 4, x_178); -lean_ctor_set(x_220, 5, x_179); -x_221 = lean_ctor_get(x_12, 0); -lean_inc(x_221); -x_222 = lean_ctor_get(x_12, 1); -lean_inc(x_222); -x_223 = lean_ctor_get(x_12, 2); -lean_inc(x_223); -x_224 = lean_ctor_get(x_12, 3); -lean_inc(x_224); -x_225 = lean_ctor_get(x_12, 4); -lean_inc(x_225); +lean_inc(x_126); +lean_inc(x_125); +lean_inc(x_124); +lean_inc(x_123); +lean_dec(x_38); +x_163 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_164 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_164, 0, x_123); +lean_ctor_set(x_164, 1, x_124); +lean_ctor_set(x_164, 2, x_163); +lean_ctor_set(x_164, 3, x_126); +lean_ctor_set(x_164, 4, x_127); +lean_ctor_set(x_32, 2, x_164); +x_165 = lean_ctor_get(x_12, 0); +lean_inc(x_165); +x_166 = lean_ctor_get(x_12, 1); +lean_inc(x_166); +x_167 = lean_ctor_get(x_12, 2); +lean_inc(x_167); +x_168 = lean_ctor_get(x_12, 3); +lean_inc(x_168); +x_169 = lean_ctor_get(x_12, 4); +lean_inc(x_169); if (lean_is_exclusive(x_12)) { lean_ctor_release(x_12, 0); lean_ctor_release(x_12, 1); lean_ctor_release(x_12, 2); lean_ctor_release(x_12, 3); lean_ctor_release(x_12, 4); - x_226 = x_12; + x_170 = x_12; } else { lean_dec_ref(x_12); - x_226 = lean_box(0); + x_170 = lean_box(0); } -x_227 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_227, 0, x_34); -lean_ctor_set(x_227, 1, x_21); -x_228 = lean_array_push(x_223, x_227); -if (lean_is_scalar(x_226)) { +x_171 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_171, 0, x_34); +lean_ctor_set(x_171, 1, x_21); +x_172 = lean_array_push(x_167, x_171); +if (lean_is_scalar(x_170)) { + x_173 = lean_alloc_ctor(0, 5, 0); +} else { + x_173 = x_170; +} +lean_ctor_set(x_173, 0, x_165); +lean_ctor_set(x_173, 1, x_166); +lean_ctor_set(x_173, 2, x_172); +lean_ctor_set(x_173, 3, x_168); +lean_ctor_set(x_173, 4, x_169); +x_174 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_introN___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_36, x_173, x_32); +if (lean_obj_tag(x_174) == 0) +{ +lean_object* x_175; lean_object* x_176; lean_object* x_177; +x_175 = lean_ctor_get(x_174, 0); +lean_inc(x_175); +x_176 = lean_ctor_get(x_174, 1); +lean_inc(x_176); +lean_dec(x_174); +x_177 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_177, 0, x_175); +x_128 = x_177; +x_129 = x_176; +goto block_162; +} +else +{ +lean_object* x_178; lean_object* x_179; lean_object* x_180; +x_178 = lean_ctor_get(x_174, 0); +lean_inc(x_178); +x_179 = lean_ctor_get(x_174, 1); +lean_inc(x_179); +lean_dec(x_174); +x_180 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_180, 0, x_178); +x_128 = x_180; +x_129 = x_179; +goto block_162; +} +block_162: +{ +if (lean_obj_tag(x_128) == 0) +{ +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, 2); +lean_inc(x_130); +x_131 = lean_ctor_get(x_128, 0); +lean_inc(x_131); +lean_dec(x_128); +x_132 = lean_ctor_get(x_129, 0); +lean_inc(x_132); +x_133 = lean_ctor_get(x_129, 1); +lean_inc(x_133); +x_134 = lean_ctor_get(x_129, 3); +lean_inc(x_134); +x_135 = lean_ctor_get(x_129, 4); +lean_inc(x_135); +x_136 = lean_ctor_get(x_129, 5); +lean_inc(x_136); +if (lean_is_exclusive(x_129)) { + lean_ctor_release(x_129, 0); + lean_ctor_release(x_129, 1); + lean_ctor_release(x_129, 2); + lean_ctor_release(x_129, 3); + lean_ctor_release(x_129, 4); + lean_ctor_release(x_129, 5); + x_137 = x_129; +} else { + lean_dec_ref(x_129); + x_137 = lean_box(0); +} +x_138 = lean_ctor_get(x_130, 0); +lean_inc(x_138); +x_139 = lean_ctor_get(x_130, 1); +lean_inc(x_139); +x_140 = lean_ctor_get(x_130, 3); +lean_inc(x_140); +x_141 = lean_ctor_get(x_130, 4); +lean_inc(x_141); +if (lean_is_exclusive(x_130)) { + lean_ctor_release(x_130, 0); + lean_ctor_release(x_130, 1); + lean_ctor_release(x_130, 2); + lean_ctor_release(x_130, 3); + lean_ctor_release(x_130, 4); + x_142 = x_130; +} else { + lean_dec_ref(x_130); + x_142 = lean_box(0); +} +if (lean_is_scalar(x_142)) { + x_143 = lean_alloc_ctor(0, 5, 0); +} else { + x_143 = x_142; +} +lean_ctor_set(x_143, 0, x_138); +lean_ctor_set(x_143, 1, x_139); +lean_ctor_set(x_143, 2, x_125); +lean_ctor_set(x_143, 3, x_140); +lean_ctor_set(x_143, 4, x_141); +if (lean_is_scalar(x_137)) { + x_144 = lean_alloc_ctor(0, 6, 0); +} else { + x_144 = x_137; +} +lean_ctor_set(x_144, 0, x_132); +lean_ctor_set(x_144, 1, x_133); +lean_ctor_set(x_144, 2, x_143); +lean_ctor_set(x_144, 3, x_134); +lean_ctor_set(x_144, 4, x_135); +lean_ctor_set(x_144, 5, x_136); +if (lean_is_scalar(x_33)) { + x_145 = lean_alloc_ctor(1, 2, 0); +} else { + x_145 = x_33; + lean_ctor_set_tag(x_145, 1); +} +lean_ctor_set(x_145, 0, x_131); +lean_ctor_set(x_145, 1, x_144); +return x_145; +} +else +{ +lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; +x_146 = lean_ctor_get(x_129, 2); +lean_inc(x_146); +x_147 = lean_ctor_get(x_128, 0); +lean_inc(x_147); +lean_dec(x_128); +x_148 = lean_ctor_get(x_129, 0); +lean_inc(x_148); +x_149 = lean_ctor_get(x_129, 1); +lean_inc(x_149); +x_150 = lean_ctor_get(x_129, 3); +lean_inc(x_150); +x_151 = lean_ctor_get(x_129, 4); +lean_inc(x_151); +x_152 = lean_ctor_get(x_129, 5); +lean_inc(x_152); +if (lean_is_exclusive(x_129)) { + lean_ctor_release(x_129, 0); + lean_ctor_release(x_129, 1); + lean_ctor_release(x_129, 2); + lean_ctor_release(x_129, 3); + lean_ctor_release(x_129, 4); + lean_ctor_release(x_129, 5); + x_153 = x_129; +} else { + lean_dec_ref(x_129); + x_153 = lean_box(0); +} +x_154 = lean_ctor_get(x_146, 0); +lean_inc(x_154); +x_155 = lean_ctor_get(x_146, 1); +lean_inc(x_155); +x_156 = lean_ctor_get(x_146, 3); +lean_inc(x_156); +x_157 = lean_ctor_get(x_146, 4); +lean_inc(x_157); +if (lean_is_exclusive(x_146)) { + lean_ctor_release(x_146, 0); + lean_ctor_release(x_146, 1); + lean_ctor_release(x_146, 2); + lean_ctor_release(x_146, 3); + lean_ctor_release(x_146, 4); + x_158 = x_146; +} else { + lean_dec_ref(x_146); + x_158 = lean_box(0); +} +if (lean_is_scalar(x_158)) { + x_159 = lean_alloc_ctor(0, 5, 0); +} else { + x_159 = x_158; +} +lean_ctor_set(x_159, 0, x_154); +lean_ctor_set(x_159, 1, x_155); +lean_ctor_set(x_159, 2, x_125); +lean_ctor_set(x_159, 3, x_156); +lean_ctor_set(x_159, 4, x_157); +if (lean_is_scalar(x_153)) { + x_160 = lean_alloc_ctor(0, 6, 0); +} else { + x_160 = x_153; +} +lean_ctor_set(x_160, 0, x_148); +lean_ctor_set(x_160, 1, x_149); +lean_ctor_set(x_160, 2, x_159); +lean_ctor_set(x_160, 3, x_150); +lean_ctor_set(x_160, 4, x_151); +lean_ctor_set(x_160, 5, x_152); +if (lean_is_scalar(x_33)) { + x_161 = lean_alloc_ctor(0, 2, 0); +} else { + x_161 = x_33; +} +lean_ctor_set(x_161, 0, x_147); +lean_ctor_set(x_161, 1, x_160); +return x_161; +} +} +} +} +else +{ +lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_228; lean_object* x_229; lean_object* x_230; lean_object* x_231; lean_object* x_232; lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_object* x_236; lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_object* x_240; +x_181 = lean_ctor_get(x_32, 2); +x_182 = lean_ctor_get(x_32, 0); +x_183 = lean_ctor_get(x_32, 1); +x_184 = lean_ctor_get(x_32, 3); +x_185 = lean_ctor_get(x_32, 4); +x_186 = lean_ctor_get(x_32, 5); +lean_inc(x_186); +lean_inc(x_185); +lean_inc(x_184); +lean_inc(x_181); +lean_inc(x_183); +lean_inc(x_182); +lean_dec(x_32); +x_187 = lean_ctor_get(x_181, 0); +lean_inc(x_187); +x_188 = lean_ctor_get(x_181, 1); +lean_inc(x_188); +x_189 = lean_ctor_get(x_181, 2); +lean_inc(x_189); +x_190 = lean_ctor_get(x_181, 3); +lean_inc(x_190); +x_191 = lean_ctor_get(x_181, 4); +lean_inc(x_191); +if (lean_is_exclusive(x_181)) { + lean_ctor_release(x_181, 0); + lean_ctor_release(x_181, 1); + lean_ctor_release(x_181, 2); + lean_ctor_release(x_181, 3); + lean_ctor_release(x_181, 4); + x_192 = x_181; +} else { + lean_dec_ref(x_181); + x_192 = lean_box(0); +} +x_228 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_192)) { x_229 = lean_alloc_ctor(0, 5, 0); } else { - x_229 = x_226; + x_229 = x_192; } -lean_ctor_set(x_229, 0, x_221); -lean_ctor_set(x_229, 1, x_222); +lean_ctor_set(x_229, 0, x_187); +lean_ctor_set(x_229, 1, x_188); lean_ctor_set(x_229, 2, x_228); -lean_ctor_set(x_229, 3, x_224); -lean_ctor_set(x_229, 4, x_225); -x_230 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_introN___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_36, x_229, x_220); -if (lean_obj_tag(x_230) == 0) -{ -lean_object* x_231; lean_object* x_232; lean_object* x_233; -x_231 = lean_ctor_get(x_230, 0); +lean_ctor_set(x_229, 3, x_190); +lean_ctor_set(x_229, 4, x_191); +x_230 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_230, 0, x_182); +lean_ctor_set(x_230, 1, x_183); +lean_ctor_set(x_230, 2, x_229); +lean_ctor_set(x_230, 3, x_184); +lean_ctor_set(x_230, 4, x_185); +lean_ctor_set(x_230, 5, x_186); +x_231 = lean_ctor_get(x_12, 0); lean_inc(x_231); -x_232 = lean_ctor_get(x_230, 1); +x_232 = lean_ctor_get(x_12, 1); lean_inc(x_232); -lean_dec(x_230); -x_233 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_233, 0, x_231); -x_185 = x_233; -x_186 = x_232; -goto block_217; -} -else -{ -lean_object* x_234; lean_object* x_235; lean_object* x_236; -x_234 = lean_ctor_get(x_230, 0); +x_233 = lean_ctor_get(x_12, 2); +lean_inc(x_233); +x_234 = lean_ctor_get(x_12, 3); lean_inc(x_234); -x_235 = lean_ctor_get(x_230, 1); +x_235 = lean_ctor_get(x_12, 4); lean_inc(x_235); -lean_dec(x_230); -x_236 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_236, 0, x_234); -x_185 = x_236; -x_186 = x_235; -goto block_217; +if (lean_is_exclusive(x_12)) { + lean_ctor_release(x_12, 0); + lean_ctor_release(x_12, 1); + lean_ctor_release(x_12, 2); + lean_ctor_release(x_12, 3); + lean_ctor_release(x_12, 4); + x_236 = x_12; +} else { + lean_dec_ref(x_12); + x_236 = lean_box(0); } -block_217: +x_237 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_237, 0, x_34); +lean_ctor_set(x_237, 1, x_21); +x_238 = lean_array_push(x_233, x_237); +if (lean_is_scalar(x_236)) { + x_239 = lean_alloc_ctor(0, 5, 0); +} else { + x_239 = x_236; +} +lean_ctor_set(x_239, 0, x_231); +lean_ctor_set(x_239, 1, x_232); +lean_ctor_set(x_239, 2, x_238); +lean_ctor_set(x_239, 3, x_234); +lean_ctor_set(x_239, 4, x_235); +x_240 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_introN___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_36, x_239, x_230); +if (lean_obj_tag(x_240) == 0) { -if (lean_obj_tag(x_185) == 0) -{ -lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; -x_187 = lean_ctor_get(x_186, 2); -lean_inc(x_187); -x_188 = lean_ctor_get(x_185, 0); -lean_inc(x_188); -lean_dec(x_185); -x_189 = lean_ctor_get(x_186, 0); -lean_inc(x_189); -x_190 = lean_ctor_get(x_186, 1); -lean_inc(x_190); -x_191 = lean_ctor_get(x_186, 3); -lean_inc(x_191); -x_192 = lean_ctor_get(x_186, 4); -lean_inc(x_192); -x_193 = lean_ctor_get(x_186, 5); -lean_inc(x_193); -if (lean_is_exclusive(x_186)) { - lean_ctor_release(x_186, 0); - lean_ctor_release(x_186, 1); - lean_ctor_release(x_186, 2); - lean_ctor_release(x_186, 3); - lean_ctor_release(x_186, 4); - lean_ctor_release(x_186, 5); - x_194 = x_186; -} else { - lean_dec_ref(x_186); - x_194 = lean_box(0); -} -x_195 = lean_ctor_get(x_187, 0); -lean_inc(x_195); -x_196 = lean_ctor_get(x_187, 1); -lean_inc(x_196); -x_197 = lean_ctor_get(x_187, 3); -lean_inc(x_197); -if (lean_is_exclusive(x_187)) { - lean_ctor_release(x_187, 0); - lean_ctor_release(x_187, 1); - lean_ctor_release(x_187, 2); - lean_ctor_release(x_187, 3); - x_198 = x_187; -} else { - lean_dec_ref(x_187); - x_198 = lean_box(0); -} -if (lean_is_scalar(x_198)) { - x_199 = lean_alloc_ctor(0, 4, 0); -} else { - x_199 = x_198; -} -lean_ctor_set(x_199, 0, x_195); -lean_ctor_set(x_199, 1, x_196); -lean_ctor_set(x_199, 2, x_182); -lean_ctor_set(x_199, 3, x_197); -if (lean_is_scalar(x_194)) { - x_200 = lean_alloc_ctor(0, 6, 0); -} else { - x_200 = x_194; -} -lean_ctor_set(x_200, 0, x_189); -lean_ctor_set(x_200, 1, x_190); -lean_ctor_set(x_200, 2, x_199); -lean_ctor_set(x_200, 3, x_191); -lean_ctor_set(x_200, 4, x_192); -lean_ctor_set(x_200, 5, x_193); -if (lean_is_scalar(x_33)) { - x_201 = lean_alloc_ctor(1, 2, 0); -} else { - x_201 = x_33; - lean_ctor_set_tag(x_201, 1); -} -lean_ctor_set(x_201, 0, x_188); -lean_ctor_set(x_201, 1, x_200); -return x_201; +lean_object* x_241; lean_object* x_242; lean_object* x_243; +x_241 = lean_ctor_get(x_240, 0); +lean_inc(x_241); +x_242 = lean_ctor_get(x_240, 1); +lean_inc(x_242); +lean_dec(x_240); +x_243 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_243, 0, x_241); +x_193 = x_243; +x_194 = x_242; +goto block_227; } else { -lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; -x_202 = lean_ctor_get(x_186, 2); -lean_inc(x_202); -x_203 = lean_ctor_get(x_185, 0); +lean_object* x_244; lean_object* x_245; lean_object* x_246; +x_244 = lean_ctor_get(x_240, 0); +lean_inc(x_244); +x_245 = lean_ctor_get(x_240, 1); +lean_inc(x_245); +lean_dec(x_240); +x_246 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_246, 0, x_244); +x_193 = x_246; +x_194 = x_245; +goto block_227; +} +block_227: +{ +if (lean_obj_tag(x_193) == 0) +{ +lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; +x_195 = lean_ctor_get(x_194, 2); +lean_inc(x_195); +x_196 = lean_ctor_get(x_193, 0); +lean_inc(x_196); +lean_dec(x_193); +x_197 = lean_ctor_get(x_194, 0); +lean_inc(x_197); +x_198 = lean_ctor_get(x_194, 1); +lean_inc(x_198); +x_199 = lean_ctor_get(x_194, 3); +lean_inc(x_199); +x_200 = lean_ctor_get(x_194, 4); +lean_inc(x_200); +x_201 = lean_ctor_get(x_194, 5); +lean_inc(x_201); +if (lean_is_exclusive(x_194)) { + lean_ctor_release(x_194, 0); + lean_ctor_release(x_194, 1); + lean_ctor_release(x_194, 2); + lean_ctor_release(x_194, 3); + lean_ctor_release(x_194, 4); + lean_ctor_release(x_194, 5); + x_202 = x_194; +} else { + lean_dec_ref(x_194); + x_202 = lean_box(0); +} +x_203 = lean_ctor_get(x_195, 0); lean_inc(x_203); -lean_dec(x_185); -x_204 = lean_ctor_get(x_186, 0); +x_204 = lean_ctor_get(x_195, 1); lean_inc(x_204); -x_205 = lean_ctor_get(x_186, 1); +x_205 = lean_ctor_get(x_195, 3); lean_inc(x_205); -x_206 = lean_ctor_get(x_186, 3); +x_206 = lean_ctor_get(x_195, 4); lean_inc(x_206); -x_207 = lean_ctor_get(x_186, 4); -lean_inc(x_207); -x_208 = lean_ctor_get(x_186, 5); -lean_inc(x_208); -if (lean_is_exclusive(x_186)) { - lean_ctor_release(x_186, 0); - lean_ctor_release(x_186, 1); - lean_ctor_release(x_186, 2); - lean_ctor_release(x_186, 3); - lean_ctor_release(x_186, 4); - lean_ctor_release(x_186, 5); - x_209 = x_186; +if (lean_is_exclusive(x_195)) { + lean_ctor_release(x_195, 0); + lean_ctor_release(x_195, 1); + lean_ctor_release(x_195, 2); + lean_ctor_release(x_195, 3); + lean_ctor_release(x_195, 4); + x_207 = x_195; } else { - lean_dec_ref(x_186); - x_209 = lean_box(0); + lean_dec_ref(x_195); + x_207 = lean_box(0); } -x_210 = lean_ctor_get(x_202, 0); -lean_inc(x_210); -x_211 = lean_ctor_get(x_202, 1); -lean_inc(x_211); -x_212 = lean_ctor_get(x_202, 3); -lean_inc(x_212); -if (lean_is_exclusive(x_202)) { - lean_ctor_release(x_202, 0); - lean_ctor_release(x_202, 1); - lean_ctor_release(x_202, 2); - lean_ctor_release(x_202, 3); - x_213 = x_202; +if (lean_is_scalar(x_207)) { + x_208 = lean_alloc_ctor(0, 5, 0); } else { - lean_dec_ref(x_202); - x_213 = lean_box(0); + x_208 = x_207; } -if (lean_is_scalar(x_213)) { - x_214 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_208, 0, x_203); +lean_ctor_set(x_208, 1, x_204); +lean_ctor_set(x_208, 2, x_189); +lean_ctor_set(x_208, 3, x_205); +lean_ctor_set(x_208, 4, x_206); +if (lean_is_scalar(x_202)) { + x_209 = lean_alloc_ctor(0, 6, 0); } else { - x_214 = x_213; + x_209 = x_202; } -lean_ctor_set(x_214, 0, x_210); -lean_ctor_set(x_214, 1, x_211); -lean_ctor_set(x_214, 2, x_182); -lean_ctor_set(x_214, 3, x_212); -if (lean_is_scalar(x_209)) { - x_215 = lean_alloc_ctor(0, 6, 0); -} else { - x_215 = x_209; -} -lean_ctor_set(x_215, 0, x_204); -lean_ctor_set(x_215, 1, x_205); -lean_ctor_set(x_215, 2, x_214); -lean_ctor_set(x_215, 3, x_206); -lean_ctor_set(x_215, 4, x_207); -lean_ctor_set(x_215, 5, x_208); +lean_ctor_set(x_209, 0, x_197); +lean_ctor_set(x_209, 1, x_198); +lean_ctor_set(x_209, 2, x_208); +lean_ctor_set(x_209, 3, x_199); +lean_ctor_set(x_209, 4, x_200); +lean_ctor_set(x_209, 5, x_201); if (lean_is_scalar(x_33)) { - x_216 = lean_alloc_ctor(0, 2, 0); + x_210 = lean_alloc_ctor(1, 2, 0); } else { - x_216 = x_33; + x_210 = x_33; + lean_ctor_set_tag(x_210, 1); } -lean_ctor_set(x_216, 0, x_203); -lean_ctor_set(x_216, 1, x_215); -return x_216; +lean_ctor_set(x_210, 0, x_196); +lean_ctor_set(x_210, 1, x_209); +return x_210; +} +else +{ +lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; lean_object* x_224; lean_object* x_225; lean_object* x_226; +x_211 = lean_ctor_get(x_194, 2); +lean_inc(x_211); +x_212 = lean_ctor_get(x_193, 0); +lean_inc(x_212); +lean_dec(x_193); +x_213 = lean_ctor_get(x_194, 0); +lean_inc(x_213); +x_214 = lean_ctor_get(x_194, 1); +lean_inc(x_214); +x_215 = lean_ctor_get(x_194, 3); +lean_inc(x_215); +x_216 = lean_ctor_get(x_194, 4); +lean_inc(x_216); +x_217 = lean_ctor_get(x_194, 5); +lean_inc(x_217); +if (lean_is_exclusive(x_194)) { + lean_ctor_release(x_194, 0); + lean_ctor_release(x_194, 1); + lean_ctor_release(x_194, 2); + lean_ctor_release(x_194, 3); + lean_ctor_release(x_194, 4); + lean_ctor_release(x_194, 5); + x_218 = x_194; +} else { + lean_dec_ref(x_194); + x_218 = lean_box(0); +} +x_219 = lean_ctor_get(x_211, 0); +lean_inc(x_219); +x_220 = lean_ctor_get(x_211, 1); +lean_inc(x_220); +x_221 = lean_ctor_get(x_211, 3); +lean_inc(x_221); +x_222 = lean_ctor_get(x_211, 4); +lean_inc(x_222); +if (lean_is_exclusive(x_211)) { + lean_ctor_release(x_211, 0); + lean_ctor_release(x_211, 1); + lean_ctor_release(x_211, 2); + lean_ctor_release(x_211, 3); + lean_ctor_release(x_211, 4); + x_223 = x_211; +} else { + lean_dec_ref(x_211); + x_223 = lean_box(0); +} +if (lean_is_scalar(x_223)) { + x_224 = lean_alloc_ctor(0, 5, 0); +} else { + x_224 = x_223; +} +lean_ctor_set(x_224, 0, x_219); +lean_ctor_set(x_224, 1, x_220); +lean_ctor_set(x_224, 2, x_189); +lean_ctor_set(x_224, 3, x_221); +lean_ctor_set(x_224, 4, x_222); +if (lean_is_scalar(x_218)) { + x_225 = lean_alloc_ctor(0, 6, 0); +} else { + x_225 = x_218; +} +lean_ctor_set(x_225, 0, x_213); +lean_ctor_set(x_225, 1, x_214); +lean_ctor_set(x_225, 2, x_224); +lean_ctor_set(x_225, 3, x_215); +lean_ctor_set(x_225, 4, x_216); +lean_ctor_set(x_225, 5, x_217); +if (lean_is_scalar(x_33)) { + x_226 = lean_alloc_ctor(0, 2, 0); +} else { + x_226 = x_33; +} +lean_ctor_set(x_226, 0, x_212); +lean_ctor_set(x_226, 1, x_225); +return x_226; } } } } default: { -lean_object* x_237; lean_object* x_238; -x_237 = lean_ctor_get(x_26, 1); -lean_inc(x_237); +lean_object* x_247; lean_object* x_248; +x_247 = lean_ctor_get(x_26, 1); +lean_inc(x_247); lean_dec(x_26); lean_inc(x_12); -x_238 = l_Lean_Meta_isClassExpensive___main(x_25, x_12, x_237); -if (lean_obj_tag(x_238) == 0) +x_248 = l_Lean_Meta_isClassExpensive___main(x_25, x_12, x_247); +if (lean_obj_tag(x_248) == 0) { -lean_object* x_239; -x_239 = lean_ctor_get(x_238, 0); -lean_inc(x_239); -if (lean_obj_tag(x_239) == 0) +lean_object* x_249; +x_249 = lean_ctor_get(x_248, 0); +lean_inc(x_249); +if (lean_obj_tag(x_249) == 0) { -lean_object* x_240; lean_object* x_241; lean_object* x_242; +lean_object* x_250; lean_object* x_251; lean_object* x_252; lean_dec(x_21); -x_240 = lean_ctor_get(x_238, 1); -lean_inc(x_240); -lean_dec(x_238); -x_241 = lean_unsigned_to_nat(1u); -x_242 = lean_nat_add(x_11, x_241); +x_250 = lean_ctor_get(x_248, 1); +lean_inc(x_250); +lean_dec(x_248); +x_251 = lean_unsigned_to_nat(1u); +x_252 = lean_nat_add(x_11, x_251); lean_dec(x_11); -x_11 = x_242; -x_13 = x_240; +x_11 = x_252; +x_13 = x_250; goto _start; } else { -lean_object* x_244; lean_object* x_245; lean_object* x_246; lean_object* x_247; lean_object* x_248; uint8_t x_249; -x_244 = lean_ctor_get(x_238, 1); -lean_inc(x_244); -if (lean_is_exclusive(x_238)) { - lean_ctor_release(x_238, 0); - lean_ctor_release(x_238, 1); - x_245 = x_238; +lean_object* x_254; lean_object* x_255; lean_object* x_256; lean_object* x_257; lean_object* x_258; uint8_t x_259; +x_254 = lean_ctor_get(x_248, 1); +lean_inc(x_254); +if (lean_is_exclusive(x_248)) { + lean_ctor_release(x_248, 0); + lean_ctor_release(x_248, 1); + x_255 = x_248; } else { - lean_dec_ref(x_238); - x_245 = lean_box(0); + lean_dec_ref(x_248); + x_255 = lean_box(0); } -x_246 = lean_ctor_get(x_239, 0); -lean_inc(x_246); -lean_dec(x_239); -x_247 = lean_unsigned_to_nat(1u); -x_248 = lean_nat_add(x_11, x_247); -lean_dec(x_11); -x_249 = !lean_is_exclusive(x_244); -if (x_249 == 0) -{ -lean_object* x_250; uint8_t x_251; -x_250 = lean_ctor_get(x_244, 2); -x_251 = !lean_is_exclusive(x_250); -if (x_251 == 0) -{ -lean_object* x_252; lean_object* x_253; lean_object* x_254; lean_object* x_304; uint8_t x_305; -x_252 = lean_ctor_get(x_250, 2); -x_304 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -lean_ctor_set(x_250, 2, x_304); -x_305 = !lean_is_exclusive(x_12); -if (x_305 == 0) -{ -lean_object* x_306; lean_object* x_307; lean_object* x_308; lean_object* x_309; -x_306 = lean_ctor_get(x_12, 2); -x_307 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_307, 0, x_246); -lean_ctor_set(x_307, 1, x_21); -x_308 = lean_array_push(x_306, x_307); -lean_ctor_set(x_12, 2, x_308); -x_309 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_introN___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_248, x_12, x_244); -if (lean_obj_tag(x_309) == 0) -{ -lean_object* x_310; lean_object* x_311; lean_object* x_312; -x_310 = lean_ctor_get(x_309, 0); -lean_inc(x_310); -x_311 = lean_ctor_get(x_309, 1); -lean_inc(x_311); -lean_dec(x_309); -x_312 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_312, 0, x_310); -x_253 = x_312; -x_254 = x_311; -goto block_303; -} -else -{ -lean_object* x_313; lean_object* x_314; lean_object* x_315; -x_313 = lean_ctor_get(x_309, 0); -lean_inc(x_313); -x_314 = lean_ctor_get(x_309, 1); -lean_inc(x_314); -lean_dec(x_309); -x_315 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_315, 0, x_313); -x_253 = x_315; -x_254 = x_314; -goto block_303; -} -} -else -{ -lean_object* x_316; lean_object* x_317; lean_object* x_318; lean_object* x_319; lean_object* x_320; lean_object* x_321; lean_object* x_322; lean_object* x_323; lean_object* x_324; -x_316 = lean_ctor_get(x_12, 0); -x_317 = lean_ctor_get(x_12, 1); -x_318 = lean_ctor_get(x_12, 2); -x_319 = lean_ctor_get(x_12, 3); -x_320 = lean_ctor_get(x_12, 4); -lean_inc(x_320); -lean_inc(x_319); -lean_inc(x_318); -lean_inc(x_317); -lean_inc(x_316); -lean_dec(x_12); -x_321 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_321, 0, x_246); -lean_ctor_set(x_321, 1, x_21); -x_322 = lean_array_push(x_318, x_321); -x_323 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_323, 0, x_316); -lean_ctor_set(x_323, 1, x_317); -lean_ctor_set(x_323, 2, x_322); -lean_ctor_set(x_323, 3, x_319); -lean_ctor_set(x_323, 4, x_320); -x_324 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_introN___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_248, x_323, x_244); -if (lean_obj_tag(x_324) == 0) -{ -lean_object* x_325; lean_object* x_326; lean_object* x_327; -x_325 = lean_ctor_get(x_324, 0); -lean_inc(x_325); -x_326 = lean_ctor_get(x_324, 1); -lean_inc(x_326); -lean_dec(x_324); -x_327 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_327, 0, x_325); -x_253 = x_327; -x_254 = x_326; -goto block_303; -} -else -{ -lean_object* x_328; lean_object* x_329; lean_object* x_330; -x_328 = lean_ctor_get(x_324, 0); -lean_inc(x_328); -x_329 = lean_ctor_get(x_324, 1); -lean_inc(x_329); -lean_dec(x_324); -x_330 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_330, 0, x_328); -x_253 = x_330; -x_254 = x_329; -goto block_303; -} -} -block_303: -{ -if (lean_obj_tag(x_253) == 0) -{ -lean_object* x_255; lean_object* x_256; uint8_t x_257; -x_255 = lean_ctor_get(x_254, 2); -lean_inc(x_255); -x_256 = lean_ctor_get(x_253, 0); +x_256 = lean_ctor_get(x_249, 0); lean_inc(x_256); -lean_dec(x_253); -x_257 = !lean_is_exclusive(x_254); -if (x_257 == 0) -{ -lean_object* x_258; uint8_t x_259; -x_258 = lean_ctor_get(x_254, 2); -lean_dec(x_258); -x_259 = !lean_is_exclusive(x_255); +lean_dec(x_249); +x_257 = lean_unsigned_to_nat(1u); +x_258 = lean_nat_add(x_11, x_257); +lean_dec(x_11); +x_259 = !lean_is_exclusive(x_254); if (x_259 == 0) { -lean_object* x_260; lean_object* x_261; -x_260 = lean_ctor_get(x_255, 2); -lean_dec(x_260); -lean_ctor_set(x_255, 2, x_252); -if (lean_is_scalar(x_245)) { - x_261 = lean_alloc_ctor(1, 2, 0); -} else { - x_261 = x_245; - lean_ctor_set_tag(x_261, 1); -} -lean_ctor_set(x_261, 0, x_256); -lean_ctor_set(x_261, 1, x_254); -return x_261; +lean_object* x_260; uint8_t x_261; +x_260 = lean_ctor_get(x_254, 2); +x_261 = !lean_is_exclusive(x_260); +if (x_261 == 0) +{ +lean_object* x_262; lean_object* x_263; lean_object* x_264; lean_object* x_318; uint8_t x_319; +x_262 = lean_ctor_get(x_260, 2); +x_318 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +lean_ctor_set(x_260, 2, x_318); +x_319 = !lean_is_exclusive(x_12); +if (x_319 == 0) +{ +lean_object* x_320; lean_object* x_321; lean_object* x_322; lean_object* x_323; +x_320 = lean_ctor_get(x_12, 2); +x_321 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_321, 0, x_256); +lean_ctor_set(x_321, 1, x_21); +x_322 = lean_array_push(x_320, x_321); +lean_ctor_set(x_12, 2, x_322); +x_323 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_introN___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_258, x_12, x_254); +if (lean_obj_tag(x_323) == 0) +{ +lean_object* x_324; lean_object* x_325; lean_object* x_326; +x_324 = lean_ctor_get(x_323, 0); +lean_inc(x_324); +x_325 = lean_ctor_get(x_323, 1); +lean_inc(x_325); +lean_dec(x_323); +x_326 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_326, 0, x_324); +x_263 = x_326; +x_264 = x_325; +goto block_317; } else { -lean_object* x_262; lean_object* x_263; lean_object* x_264; lean_object* x_265; lean_object* x_266; -x_262 = lean_ctor_get(x_255, 0); -x_263 = lean_ctor_get(x_255, 1); -x_264 = lean_ctor_get(x_255, 3); -lean_inc(x_264); -lean_inc(x_263); -lean_inc(x_262); -lean_dec(x_255); -x_265 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_265, 0, x_262); -lean_ctor_set(x_265, 1, x_263); -lean_ctor_set(x_265, 2, x_252); -lean_ctor_set(x_265, 3, x_264); -lean_ctor_set(x_254, 2, x_265); -if (lean_is_scalar(x_245)) { - x_266 = lean_alloc_ctor(1, 2, 0); -} else { - x_266 = x_245; - lean_ctor_set_tag(x_266, 1); -} -lean_ctor_set(x_266, 0, x_256); -lean_ctor_set(x_266, 1, x_254); -return x_266; +lean_object* x_327; lean_object* x_328; lean_object* x_329; +x_327 = lean_ctor_get(x_323, 0); +lean_inc(x_327); +x_328 = lean_ctor_get(x_323, 1); +lean_inc(x_328); +lean_dec(x_323); +x_329 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_329, 0, x_327); +x_263 = x_329; +x_264 = x_328; +goto block_317; } } else { -lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_object* x_270; lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_object* x_276; lean_object* x_277; lean_object* x_278; -x_267 = lean_ctor_get(x_254, 0); -x_268 = lean_ctor_get(x_254, 1); -x_269 = lean_ctor_get(x_254, 3); -x_270 = lean_ctor_get(x_254, 4); -x_271 = lean_ctor_get(x_254, 5); -lean_inc(x_271); -lean_inc(x_270); -lean_inc(x_269); -lean_inc(x_268); -lean_inc(x_267); -lean_dec(x_254); -x_272 = lean_ctor_get(x_255, 0); -lean_inc(x_272); -x_273 = lean_ctor_get(x_255, 1); -lean_inc(x_273); -x_274 = lean_ctor_get(x_255, 3); +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_330 = lean_ctor_get(x_12, 0); +x_331 = lean_ctor_get(x_12, 1); +x_332 = lean_ctor_get(x_12, 2); +x_333 = lean_ctor_get(x_12, 3); +x_334 = lean_ctor_get(x_12, 4); +lean_inc(x_334); +lean_inc(x_333); +lean_inc(x_332); +lean_inc(x_331); +lean_inc(x_330); +lean_dec(x_12); +x_335 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_335, 0, x_256); +lean_ctor_set(x_335, 1, x_21); +x_336 = lean_array_push(x_332, x_335); +x_337 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_337, 0, x_330); +lean_ctor_set(x_337, 1, x_331); +lean_ctor_set(x_337, 2, x_336); +lean_ctor_set(x_337, 3, x_333); +lean_ctor_set(x_337, 4, x_334); +x_338 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_introN___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_258, x_337, x_254); +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); +x_341 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_341, 0, x_339); +x_263 = x_341; +x_264 = x_340; +goto block_317; +} +else +{ +lean_object* x_342; lean_object* x_343; lean_object* x_344; +x_342 = lean_ctor_get(x_338, 0); +lean_inc(x_342); +x_343 = lean_ctor_get(x_338, 1); +lean_inc(x_343); +lean_dec(x_338); +x_344 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_344, 0, x_342); +x_263 = x_344; +x_264 = x_343; +goto block_317; +} +} +block_317: +{ +if (lean_obj_tag(x_263) == 0) +{ +lean_object* x_265; lean_object* x_266; uint8_t x_267; +x_265 = lean_ctor_get(x_264, 2); +lean_inc(x_265); +x_266 = lean_ctor_get(x_263, 0); +lean_inc(x_266); +lean_dec(x_263); +x_267 = !lean_is_exclusive(x_264); +if (x_267 == 0) +{ +lean_object* x_268; uint8_t x_269; +x_268 = lean_ctor_get(x_264, 2); +lean_dec(x_268); +x_269 = !lean_is_exclusive(x_265); +if (x_269 == 0) +{ +lean_object* x_270; lean_object* x_271; +x_270 = lean_ctor_get(x_265, 2); +lean_dec(x_270); +lean_ctor_set(x_265, 2, x_262); +if (lean_is_scalar(x_255)) { + x_271 = lean_alloc_ctor(1, 2, 0); +} else { + x_271 = x_255; + lean_ctor_set_tag(x_271, 1); +} +lean_ctor_set(x_271, 0, x_266); +lean_ctor_set(x_271, 1, x_264); +return x_271; +} +else +{ +lean_object* x_272; lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_object* x_276; lean_object* x_277; +x_272 = lean_ctor_get(x_265, 0); +x_273 = lean_ctor_get(x_265, 1); +x_274 = lean_ctor_get(x_265, 3); +x_275 = lean_ctor_get(x_265, 4); +lean_inc(x_275); lean_inc(x_274); -if (lean_is_exclusive(x_255)) { - lean_ctor_release(x_255, 0); - lean_ctor_release(x_255, 1); - lean_ctor_release(x_255, 2); - lean_ctor_release(x_255, 3); - x_275 = x_255; -} else { - lean_dec_ref(x_255); - x_275 = lean_box(0); -} -if (lean_is_scalar(x_275)) { - x_276 = lean_alloc_ctor(0, 4, 0); -} else { - x_276 = x_275; -} +lean_inc(x_273); +lean_inc(x_272); +lean_dec(x_265); +x_276 = lean_alloc_ctor(0, 5, 0); lean_ctor_set(x_276, 0, x_272); lean_ctor_set(x_276, 1, x_273); -lean_ctor_set(x_276, 2, x_252); +lean_ctor_set(x_276, 2, x_262); lean_ctor_set(x_276, 3, x_274); -x_277 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_277, 0, x_267); -lean_ctor_set(x_277, 1, x_268); -lean_ctor_set(x_277, 2, x_276); -lean_ctor_set(x_277, 3, x_269); -lean_ctor_set(x_277, 4, x_270); -lean_ctor_set(x_277, 5, x_271); -if (lean_is_scalar(x_245)) { - x_278 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_276, 4, x_275); +lean_ctor_set(x_264, 2, x_276); +if (lean_is_scalar(x_255)) { + x_277 = lean_alloc_ctor(1, 2, 0); } else { - x_278 = x_245; - lean_ctor_set_tag(x_278, 1); + x_277 = x_255; + lean_ctor_set_tag(x_277, 1); } -lean_ctor_set(x_278, 0, x_256); -lean_ctor_set(x_278, 1, x_277); -return x_278; +lean_ctor_set(x_277, 0, x_266); +lean_ctor_set(x_277, 1, x_264); +return x_277; } } else { -lean_object* x_279; lean_object* x_280; uint8_t x_281; -x_279 = lean_ctor_get(x_254, 2); -lean_inc(x_279); -x_280 = lean_ctor_get(x_253, 0); +lean_object* x_278; lean_object* x_279; lean_object* x_280; lean_object* x_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; lean_object* x_289; lean_object* x_290; +x_278 = lean_ctor_get(x_264, 0); +x_279 = lean_ctor_get(x_264, 1); +x_280 = lean_ctor_get(x_264, 3); +x_281 = lean_ctor_get(x_264, 4); +x_282 = lean_ctor_get(x_264, 5); +lean_inc(x_282); +lean_inc(x_281); lean_inc(x_280); -lean_dec(x_253); -x_281 = !lean_is_exclusive(x_254); -if (x_281 == 0) -{ -lean_object* x_282; uint8_t x_283; -x_282 = lean_ctor_get(x_254, 2); -lean_dec(x_282); -x_283 = !lean_is_exclusive(x_279); -if (x_283 == 0) -{ -lean_object* x_284; lean_object* x_285; -x_284 = lean_ctor_get(x_279, 2); -lean_dec(x_284); -lean_ctor_set(x_279, 2, x_252); -if (lean_is_scalar(x_245)) { - x_285 = lean_alloc_ctor(0, 2, 0); -} else { - x_285 = x_245; -} -lean_ctor_set(x_285, 0, x_280); -lean_ctor_set(x_285, 1, x_254); -return x_285; -} -else -{ -lean_object* x_286; lean_object* x_287; lean_object* x_288; lean_object* x_289; lean_object* x_290; -x_286 = lean_ctor_get(x_279, 0); -x_287 = lean_ctor_get(x_279, 1); -x_288 = lean_ctor_get(x_279, 3); -lean_inc(x_288); -lean_inc(x_287); +lean_inc(x_279); +lean_inc(x_278); +lean_dec(x_264); +x_283 = lean_ctor_get(x_265, 0); +lean_inc(x_283); +x_284 = lean_ctor_get(x_265, 1); +lean_inc(x_284); +x_285 = lean_ctor_get(x_265, 3); +lean_inc(x_285); +x_286 = lean_ctor_get(x_265, 4); lean_inc(x_286); -lean_dec(x_279); -x_289 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_289, 0, x_286); -lean_ctor_set(x_289, 1, x_287); -lean_ctor_set(x_289, 2, x_252); -lean_ctor_set(x_289, 3, x_288); -lean_ctor_set(x_254, 2, x_289); -if (lean_is_scalar(x_245)) { - x_290 = lean_alloc_ctor(0, 2, 0); +if (lean_is_exclusive(x_265)) { + lean_ctor_release(x_265, 0); + lean_ctor_release(x_265, 1); + lean_ctor_release(x_265, 2); + lean_ctor_release(x_265, 3); + lean_ctor_release(x_265, 4); + x_287 = x_265; } else { - x_290 = x_245; + lean_dec_ref(x_265); + x_287 = lean_box(0); } -lean_ctor_set(x_290, 0, x_280); -lean_ctor_set(x_290, 1, x_254); +if (lean_is_scalar(x_287)) { + x_288 = lean_alloc_ctor(0, 5, 0); +} else { + x_288 = x_287; +} +lean_ctor_set(x_288, 0, x_283); +lean_ctor_set(x_288, 1, x_284); +lean_ctor_set(x_288, 2, x_262); +lean_ctor_set(x_288, 3, x_285); +lean_ctor_set(x_288, 4, x_286); +x_289 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_289, 0, x_278); +lean_ctor_set(x_289, 1, x_279); +lean_ctor_set(x_289, 2, x_288); +lean_ctor_set(x_289, 3, x_280); +lean_ctor_set(x_289, 4, x_281); +lean_ctor_set(x_289, 5, x_282); +if (lean_is_scalar(x_255)) { + x_290 = lean_alloc_ctor(1, 2, 0); +} else { + x_290 = x_255; + lean_ctor_set_tag(x_290, 1); +} +lean_ctor_set(x_290, 0, x_266); +lean_ctor_set(x_290, 1, x_289); return x_290; } } else { -lean_object* x_291; lean_object* x_292; lean_object* x_293; lean_object* x_294; lean_object* x_295; lean_object* x_296; lean_object* x_297; lean_object* x_298; lean_object* x_299; lean_object* x_300; lean_object* x_301; lean_object* x_302; -x_291 = lean_ctor_get(x_254, 0); -x_292 = lean_ctor_get(x_254, 1); -x_293 = lean_ctor_get(x_254, 3); -x_294 = lean_ctor_get(x_254, 4); -x_295 = lean_ctor_get(x_254, 5); -lean_inc(x_295); -lean_inc(x_294); -lean_inc(x_293); -lean_inc(x_292); +lean_object* x_291; lean_object* x_292; uint8_t x_293; +x_291 = lean_ctor_get(x_264, 2); lean_inc(x_291); -lean_dec(x_254); -x_296 = lean_ctor_get(x_279, 0); -lean_inc(x_296); -x_297 = lean_ctor_get(x_279, 1); -lean_inc(x_297); -x_298 = lean_ctor_get(x_279, 3); +x_292 = lean_ctor_get(x_263, 0); +lean_inc(x_292); +lean_dec(x_263); +x_293 = !lean_is_exclusive(x_264); +if (x_293 == 0) +{ +lean_object* x_294; uint8_t x_295; +x_294 = lean_ctor_get(x_264, 2); +lean_dec(x_294); +x_295 = !lean_is_exclusive(x_291); +if (x_295 == 0) +{ +lean_object* x_296; lean_object* x_297; +x_296 = lean_ctor_get(x_291, 2); +lean_dec(x_296); +lean_ctor_set(x_291, 2, x_262); +if (lean_is_scalar(x_255)) { + x_297 = lean_alloc_ctor(0, 2, 0); +} else { + x_297 = x_255; +} +lean_ctor_set(x_297, 0, x_292); +lean_ctor_set(x_297, 1, x_264); +return x_297; +} +else +{ +lean_object* x_298; lean_object* x_299; lean_object* x_300; lean_object* x_301; lean_object* x_302; lean_object* x_303; +x_298 = lean_ctor_get(x_291, 0); +x_299 = lean_ctor_get(x_291, 1); +x_300 = lean_ctor_get(x_291, 3); +x_301 = lean_ctor_get(x_291, 4); +lean_inc(x_301); +lean_inc(x_300); +lean_inc(x_299); lean_inc(x_298); -if (lean_is_exclusive(x_279)) { - lean_ctor_release(x_279, 0); - lean_ctor_release(x_279, 1); - lean_ctor_release(x_279, 2); - lean_ctor_release(x_279, 3); - x_299 = x_279; +lean_dec(x_291); +x_302 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_302, 0, x_298); +lean_ctor_set(x_302, 1, x_299); +lean_ctor_set(x_302, 2, x_262); +lean_ctor_set(x_302, 3, x_300); +lean_ctor_set(x_302, 4, x_301); +lean_ctor_set(x_264, 2, x_302); +if (lean_is_scalar(x_255)) { + x_303 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_279); - x_299 = lean_box(0); + x_303 = x_255; } -if (lean_is_scalar(x_299)) { - x_300 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_303, 0, x_292); +lean_ctor_set(x_303, 1, x_264); +return x_303; +} +} +else +{ +lean_object* x_304; lean_object* x_305; lean_object* x_306; lean_object* x_307; lean_object* x_308; lean_object* x_309; lean_object* x_310; lean_object* x_311; lean_object* x_312; lean_object* x_313; lean_object* x_314; lean_object* x_315; lean_object* x_316; +x_304 = lean_ctor_get(x_264, 0); +x_305 = lean_ctor_get(x_264, 1); +x_306 = lean_ctor_get(x_264, 3); +x_307 = lean_ctor_get(x_264, 4); +x_308 = lean_ctor_get(x_264, 5); +lean_inc(x_308); +lean_inc(x_307); +lean_inc(x_306); +lean_inc(x_305); +lean_inc(x_304); +lean_dec(x_264); +x_309 = lean_ctor_get(x_291, 0); +lean_inc(x_309); +x_310 = lean_ctor_get(x_291, 1); +lean_inc(x_310); +x_311 = lean_ctor_get(x_291, 3); +lean_inc(x_311); +x_312 = lean_ctor_get(x_291, 4); +lean_inc(x_312); +if (lean_is_exclusive(x_291)) { + lean_ctor_release(x_291, 0); + lean_ctor_release(x_291, 1); + lean_ctor_release(x_291, 2); + lean_ctor_release(x_291, 3); + lean_ctor_release(x_291, 4); + x_313 = x_291; } else { - x_300 = x_299; + lean_dec_ref(x_291); + x_313 = lean_box(0); } -lean_ctor_set(x_300, 0, x_296); -lean_ctor_set(x_300, 1, x_297); -lean_ctor_set(x_300, 2, x_252); -lean_ctor_set(x_300, 3, x_298); -x_301 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_301, 0, x_291); -lean_ctor_set(x_301, 1, x_292); -lean_ctor_set(x_301, 2, x_300); -lean_ctor_set(x_301, 3, x_293); -lean_ctor_set(x_301, 4, x_294); -lean_ctor_set(x_301, 5, x_295); -if (lean_is_scalar(x_245)) { - x_302 = lean_alloc_ctor(0, 2, 0); +if (lean_is_scalar(x_313)) { + x_314 = lean_alloc_ctor(0, 5, 0); } else { - x_302 = x_245; + x_314 = x_313; } -lean_ctor_set(x_302, 0, x_280); -lean_ctor_set(x_302, 1, x_301); -return x_302; +lean_ctor_set(x_314, 0, x_309); +lean_ctor_set(x_314, 1, x_310); +lean_ctor_set(x_314, 2, x_262); +lean_ctor_set(x_314, 3, x_311); +lean_ctor_set(x_314, 4, x_312); +x_315 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_315, 0, x_304); +lean_ctor_set(x_315, 1, x_305); +lean_ctor_set(x_315, 2, x_314); +lean_ctor_set(x_315, 3, x_306); +lean_ctor_set(x_315, 4, x_307); +lean_ctor_set(x_315, 5, x_308); +if (lean_is_scalar(x_255)) { + x_316 = lean_alloc_ctor(0, 2, 0); +} else { + x_316 = x_255; +} +lean_ctor_set(x_316, 0, x_292); +lean_ctor_set(x_316, 1, x_315); +return x_316; } } } } else { -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_368; lean_object* x_369; lean_object* x_370; lean_object* x_371; lean_object* x_372; lean_object* x_373; lean_object* x_374; lean_object* x_375; lean_object* x_376; lean_object* x_377; lean_object* x_378; lean_object* x_379; -x_331 = lean_ctor_get(x_250, 0); -x_332 = lean_ctor_get(x_250, 1); -x_333 = lean_ctor_get(x_250, 2); -x_334 = lean_ctor_get(x_250, 3); -lean_inc(x_334); -lean_inc(x_333); -lean_inc(x_332); -lean_inc(x_331); -lean_dec(x_250); -x_368 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -x_369 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_369, 0, x_331); -lean_ctor_set(x_369, 1, x_332); -lean_ctor_set(x_369, 2, x_368); -lean_ctor_set(x_369, 3, x_334); -lean_ctor_set(x_244, 2, x_369); -x_370 = lean_ctor_get(x_12, 0); -lean_inc(x_370); -x_371 = lean_ctor_get(x_12, 1); -lean_inc(x_371); -x_372 = lean_ctor_get(x_12, 2); -lean_inc(x_372); -x_373 = lean_ctor_get(x_12, 3); -lean_inc(x_373); -x_374 = lean_ctor_get(x_12, 4); -lean_inc(x_374); +lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; lean_object* x_350; lean_object* x_351; lean_object* x_385; lean_object* x_386; lean_object* x_387; lean_object* x_388; lean_object* x_389; lean_object* x_390; lean_object* x_391; lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; +x_345 = lean_ctor_get(x_260, 0); +x_346 = lean_ctor_get(x_260, 1); +x_347 = lean_ctor_get(x_260, 2); +x_348 = lean_ctor_get(x_260, 3); +x_349 = lean_ctor_get(x_260, 4); +lean_inc(x_349); +lean_inc(x_348); +lean_inc(x_347); +lean_inc(x_346); +lean_inc(x_345); +lean_dec(x_260); +x_385 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +x_386 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_386, 0, x_345); +lean_ctor_set(x_386, 1, x_346); +lean_ctor_set(x_386, 2, x_385); +lean_ctor_set(x_386, 3, x_348); +lean_ctor_set(x_386, 4, x_349); +lean_ctor_set(x_254, 2, x_386); +x_387 = lean_ctor_get(x_12, 0); +lean_inc(x_387); +x_388 = lean_ctor_get(x_12, 1); +lean_inc(x_388); +x_389 = lean_ctor_get(x_12, 2); +lean_inc(x_389); +x_390 = lean_ctor_get(x_12, 3); +lean_inc(x_390); +x_391 = lean_ctor_get(x_12, 4); +lean_inc(x_391); if (lean_is_exclusive(x_12)) { lean_ctor_release(x_12, 0); lean_ctor_release(x_12, 1); lean_ctor_release(x_12, 2); lean_ctor_release(x_12, 3); lean_ctor_release(x_12, 4); - x_375 = x_12; + x_392 = x_12; } else { lean_dec_ref(x_12); - x_375 = lean_box(0); + x_392 = lean_box(0); } -x_376 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_376, 0, x_246); -lean_ctor_set(x_376, 1, x_21); -x_377 = lean_array_push(x_372, x_376); -if (lean_is_scalar(x_375)) { - x_378 = lean_alloc_ctor(0, 5, 0); +x_393 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_393, 0, x_256); +lean_ctor_set(x_393, 1, x_21); +x_394 = lean_array_push(x_389, x_393); +if (lean_is_scalar(x_392)) { + x_395 = lean_alloc_ctor(0, 5, 0); } else { - x_378 = x_375; + x_395 = x_392; } -lean_ctor_set(x_378, 0, x_370); -lean_ctor_set(x_378, 1, x_371); -lean_ctor_set(x_378, 2, x_377); -lean_ctor_set(x_378, 3, x_373); -lean_ctor_set(x_378, 4, x_374); -x_379 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_introN___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_248, x_378, x_244); -if (lean_obj_tag(x_379) == 0) +lean_ctor_set(x_395, 0, x_387); +lean_ctor_set(x_395, 1, x_388); +lean_ctor_set(x_395, 2, x_394); +lean_ctor_set(x_395, 3, x_390); +lean_ctor_set(x_395, 4, x_391); +x_396 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_introN___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_258, x_395, x_254); +if (lean_obj_tag(x_396) == 0) { -lean_object* x_380; lean_object* x_381; lean_object* x_382; -x_380 = lean_ctor_get(x_379, 0); -lean_inc(x_380); -x_381 = lean_ctor_get(x_379, 1); -lean_inc(x_381); -lean_dec(x_379); -x_382 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_382, 0, x_380); -x_335 = x_382; -x_336 = x_381; -goto block_367; +lean_object* x_397; lean_object* x_398; lean_object* x_399; +x_397 = lean_ctor_get(x_396, 0); +lean_inc(x_397); +x_398 = lean_ctor_get(x_396, 1); +lean_inc(x_398); +lean_dec(x_396); +x_399 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_399, 0, x_397); +x_350 = x_399; +x_351 = x_398; +goto block_384; } else { -lean_object* x_383; lean_object* x_384; lean_object* x_385; -x_383 = lean_ctor_get(x_379, 0); -lean_inc(x_383); -x_384 = lean_ctor_get(x_379, 1); -lean_inc(x_384); -lean_dec(x_379); -x_385 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_385, 0, x_383); -x_335 = x_385; -x_336 = x_384; -goto block_367; +lean_object* x_400; lean_object* x_401; lean_object* x_402; +x_400 = lean_ctor_get(x_396, 0); +lean_inc(x_400); +x_401 = lean_ctor_get(x_396, 1); +lean_inc(x_401); +lean_dec(x_396); +x_402 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_402, 0, x_400); +x_350 = x_402; +x_351 = x_401; +goto block_384; } -block_367: +block_384: { -if (lean_obj_tag(x_335) == 0) +if (lean_obj_tag(x_350) == 0) { -lean_object* x_337; lean_object* x_338; lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; lean_object* x_350; lean_object* x_351; -x_337 = lean_ctor_get(x_336, 2); -lean_inc(x_337); -x_338 = lean_ctor_get(x_335, 0); -lean_inc(x_338); -lean_dec(x_335); -x_339 = lean_ctor_get(x_336, 0); -lean_inc(x_339); -x_340 = lean_ctor_get(x_336, 1); -lean_inc(x_340); -x_341 = lean_ctor_get(x_336, 3); -lean_inc(x_341); -x_342 = lean_ctor_get(x_336, 4); -lean_inc(x_342); -x_343 = lean_ctor_get(x_336, 5); -lean_inc(x_343); -if (lean_is_exclusive(x_336)) { - lean_ctor_release(x_336, 0); - lean_ctor_release(x_336, 1); - lean_ctor_release(x_336, 2); - lean_ctor_release(x_336, 3); - lean_ctor_release(x_336, 4); - lean_ctor_release(x_336, 5); - x_344 = x_336; -} else { - lean_dec_ref(x_336); - x_344 = lean_box(0); -} -x_345 = lean_ctor_get(x_337, 0); -lean_inc(x_345); -x_346 = lean_ctor_get(x_337, 1); -lean_inc(x_346); -x_347 = lean_ctor_get(x_337, 3); -lean_inc(x_347); -if (lean_is_exclusive(x_337)) { - lean_ctor_release(x_337, 0); - lean_ctor_release(x_337, 1); - lean_ctor_release(x_337, 2); - lean_ctor_release(x_337, 3); - x_348 = x_337; -} else { - lean_dec_ref(x_337); - x_348 = lean_box(0); -} -if (lean_is_scalar(x_348)) { - x_349 = lean_alloc_ctor(0, 4, 0); -} else { - x_349 = x_348; -} -lean_ctor_set(x_349, 0, x_345); -lean_ctor_set(x_349, 1, x_346); -lean_ctor_set(x_349, 2, x_333); -lean_ctor_set(x_349, 3, x_347); -if (lean_is_scalar(x_344)) { - x_350 = lean_alloc_ctor(0, 6, 0); -} else { - x_350 = x_344; -} -lean_ctor_set(x_350, 0, x_339); -lean_ctor_set(x_350, 1, x_340); -lean_ctor_set(x_350, 2, x_349); -lean_ctor_set(x_350, 3, x_341); -lean_ctor_set(x_350, 4, x_342); -lean_ctor_set(x_350, 5, x_343); -if (lean_is_scalar(x_245)) { - x_351 = lean_alloc_ctor(1, 2, 0); -} else { - x_351 = x_245; - lean_ctor_set_tag(x_351, 1); -} -lean_ctor_set(x_351, 0, x_338); -lean_ctor_set(x_351, 1, x_350); -return x_351; -} -else -{ -lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; 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; -x_352 = lean_ctor_get(x_336, 2); +lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; 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; +x_352 = lean_ctor_get(x_351, 2); lean_inc(x_352); -x_353 = lean_ctor_get(x_335, 0); +x_353 = lean_ctor_get(x_350, 0); lean_inc(x_353); -lean_dec(x_335); -x_354 = lean_ctor_get(x_336, 0); +lean_dec(x_350); +x_354 = lean_ctor_get(x_351, 0); lean_inc(x_354); -x_355 = lean_ctor_get(x_336, 1); +x_355 = lean_ctor_get(x_351, 1); lean_inc(x_355); -x_356 = lean_ctor_get(x_336, 3); +x_356 = lean_ctor_get(x_351, 3); lean_inc(x_356); -x_357 = lean_ctor_get(x_336, 4); +x_357 = lean_ctor_get(x_351, 4); lean_inc(x_357); -x_358 = lean_ctor_get(x_336, 5); +x_358 = lean_ctor_get(x_351, 5); lean_inc(x_358); -if (lean_is_exclusive(x_336)) { - lean_ctor_release(x_336, 0); - lean_ctor_release(x_336, 1); - lean_ctor_release(x_336, 2); - lean_ctor_release(x_336, 3); - lean_ctor_release(x_336, 4); - lean_ctor_release(x_336, 5); - x_359 = x_336; +if (lean_is_exclusive(x_351)) { + lean_ctor_release(x_351, 0); + lean_ctor_release(x_351, 1); + lean_ctor_release(x_351, 2); + lean_ctor_release(x_351, 3); + lean_ctor_release(x_351, 4); + lean_ctor_release(x_351, 5); + x_359 = x_351; } else { - lean_dec_ref(x_336); + lean_dec_ref(x_351); x_359 = lean_box(0); } x_360 = lean_ctor_get(x_352, 0); @@ -4401,315 +4453,411 @@ x_361 = lean_ctor_get(x_352, 1); lean_inc(x_361); x_362 = lean_ctor_get(x_352, 3); lean_inc(x_362); +x_363 = lean_ctor_get(x_352, 4); +lean_inc(x_363); if (lean_is_exclusive(x_352)) { lean_ctor_release(x_352, 0); lean_ctor_release(x_352, 1); lean_ctor_release(x_352, 2); lean_ctor_release(x_352, 3); - x_363 = x_352; + lean_ctor_release(x_352, 4); + x_364 = x_352; } else { lean_dec_ref(x_352); - x_363 = lean_box(0); + x_364 = lean_box(0); } -if (lean_is_scalar(x_363)) { - x_364 = lean_alloc_ctor(0, 4, 0); +if (lean_is_scalar(x_364)) { + x_365 = lean_alloc_ctor(0, 5, 0); } else { - x_364 = x_363; + x_365 = x_364; } -lean_ctor_set(x_364, 0, x_360); -lean_ctor_set(x_364, 1, x_361); -lean_ctor_set(x_364, 2, x_333); -lean_ctor_set(x_364, 3, x_362); +lean_ctor_set(x_365, 0, x_360); +lean_ctor_set(x_365, 1, x_361); +lean_ctor_set(x_365, 2, x_347); +lean_ctor_set(x_365, 3, x_362); +lean_ctor_set(x_365, 4, x_363); if (lean_is_scalar(x_359)) { - x_365 = lean_alloc_ctor(0, 6, 0); + x_366 = lean_alloc_ctor(0, 6, 0); } else { - x_365 = x_359; + x_366 = x_359; } -lean_ctor_set(x_365, 0, x_354); -lean_ctor_set(x_365, 1, x_355); -lean_ctor_set(x_365, 2, x_364); -lean_ctor_set(x_365, 3, x_356); -lean_ctor_set(x_365, 4, x_357); -lean_ctor_set(x_365, 5, x_358); -if (lean_is_scalar(x_245)) { - x_366 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_366, 0, x_354); +lean_ctor_set(x_366, 1, x_355); +lean_ctor_set(x_366, 2, x_365); +lean_ctor_set(x_366, 3, x_356); +lean_ctor_set(x_366, 4, x_357); +lean_ctor_set(x_366, 5, x_358); +if (lean_is_scalar(x_255)) { + x_367 = lean_alloc_ctor(1, 2, 0); } else { - x_366 = x_245; + x_367 = x_255; + lean_ctor_set_tag(x_367, 1); } -lean_ctor_set(x_366, 0, x_353); -lean_ctor_set(x_366, 1, x_365); -return x_366; +lean_ctor_set(x_367, 0, x_353); +lean_ctor_set(x_367, 1, x_366); +return x_367; +} +else +{ +lean_object* x_368; lean_object* x_369; lean_object* x_370; lean_object* x_371; lean_object* x_372; lean_object* x_373; lean_object* x_374; lean_object* x_375; 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; +x_368 = lean_ctor_get(x_351, 2); +lean_inc(x_368); +x_369 = lean_ctor_get(x_350, 0); +lean_inc(x_369); +lean_dec(x_350); +x_370 = lean_ctor_get(x_351, 0); +lean_inc(x_370); +x_371 = lean_ctor_get(x_351, 1); +lean_inc(x_371); +x_372 = lean_ctor_get(x_351, 3); +lean_inc(x_372); +x_373 = lean_ctor_get(x_351, 4); +lean_inc(x_373); +x_374 = lean_ctor_get(x_351, 5); +lean_inc(x_374); +if (lean_is_exclusive(x_351)) { + lean_ctor_release(x_351, 0); + lean_ctor_release(x_351, 1); + lean_ctor_release(x_351, 2); + lean_ctor_release(x_351, 3); + lean_ctor_release(x_351, 4); + lean_ctor_release(x_351, 5); + x_375 = x_351; +} else { + lean_dec_ref(x_351); + x_375 = lean_box(0); +} +x_376 = lean_ctor_get(x_368, 0); +lean_inc(x_376); +x_377 = lean_ctor_get(x_368, 1); +lean_inc(x_377); +x_378 = lean_ctor_get(x_368, 3); +lean_inc(x_378); +x_379 = lean_ctor_get(x_368, 4); +lean_inc(x_379); +if (lean_is_exclusive(x_368)) { + lean_ctor_release(x_368, 0); + lean_ctor_release(x_368, 1); + lean_ctor_release(x_368, 2); + lean_ctor_release(x_368, 3); + lean_ctor_release(x_368, 4); + x_380 = x_368; +} else { + lean_dec_ref(x_368); + x_380 = lean_box(0); +} +if (lean_is_scalar(x_380)) { + x_381 = lean_alloc_ctor(0, 5, 0); +} else { + x_381 = x_380; +} +lean_ctor_set(x_381, 0, x_376); +lean_ctor_set(x_381, 1, x_377); +lean_ctor_set(x_381, 2, x_347); +lean_ctor_set(x_381, 3, x_378); +lean_ctor_set(x_381, 4, x_379); +if (lean_is_scalar(x_375)) { + x_382 = lean_alloc_ctor(0, 6, 0); +} else { + x_382 = x_375; +} +lean_ctor_set(x_382, 0, x_370); +lean_ctor_set(x_382, 1, x_371); +lean_ctor_set(x_382, 2, x_381); +lean_ctor_set(x_382, 3, x_372); +lean_ctor_set(x_382, 4, x_373); +lean_ctor_set(x_382, 5, x_374); +if (lean_is_scalar(x_255)) { + x_383 = lean_alloc_ctor(0, 2, 0); +} else { + x_383 = x_255; +} +lean_ctor_set(x_383, 0, x_369); +lean_ctor_set(x_383, 1, x_382); +return x_383; } } } } else { -lean_object* x_386; lean_object* x_387; lean_object* x_388; lean_object* x_389; lean_object* x_390; lean_object* x_391; lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_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; -x_386 = lean_ctor_get(x_244, 2); -x_387 = lean_ctor_get(x_244, 0); -x_388 = lean_ctor_get(x_244, 1); -x_389 = lean_ctor_get(x_244, 3); -x_390 = lean_ctor_get(x_244, 4); -x_391 = lean_ctor_get(x_244, 5); -lean_inc(x_391); -lean_inc(x_390); -lean_inc(x_389); -lean_inc(x_386); -lean_inc(x_388); -lean_inc(x_387); -lean_dec(x_244); -x_392 = lean_ctor_get(x_386, 0); -lean_inc(x_392); -x_393 = lean_ctor_get(x_386, 1); -lean_inc(x_393); -x_394 = lean_ctor_get(x_386, 2); -lean_inc(x_394); -x_395 = lean_ctor_get(x_386, 3); -lean_inc(x_395); -if (lean_is_exclusive(x_386)) { - lean_ctor_release(x_386, 0); - lean_ctor_release(x_386, 1); - lean_ctor_release(x_386, 2); - lean_ctor_release(x_386, 3); - x_396 = x_386; +lean_object* x_403; lean_object* x_404; lean_object* x_405; lean_object* x_406; lean_object* x_407; lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_object* x_412; lean_object* x_413; lean_object* x_414; lean_object* x_415; lean_object* x_416; lean_object* x_450; lean_object* x_451; lean_object* x_452; lean_object* x_453; lean_object* x_454; lean_object* x_455; lean_object* x_456; lean_object* x_457; lean_object* x_458; lean_object* x_459; lean_object* x_460; lean_object* x_461; lean_object* x_462; +x_403 = lean_ctor_get(x_254, 2); +x_404 = lean_ctor_get(x_254, 0); +x_405 = lean_ctor_get(x_254, 1); +x_406 = lean_ctor_get(x_254, 3); +x_407 = lean_ctor_get(x_254, 4); +x_408 = lean_ctor_get(x_254, 5); +lean_inc(x_408); +lean_inc(x_407); +lean_inc(x_406); +lean_inc(x_403); +lean_inc(x_405); +lean_inc(x_404); +lean_dec(x_254); +x_409 = lean_ctor_get(x_403, 0); +lean_inc(x_409); +x_410 = lean_ctor_get(x_403, 1); +lean_inc(x_410); +x_411 = lean_ctor_get(x_403, 2); +lean_inc(x_411); +x_412 = lean_ctor_get(x_403, 3); +lean_inc(x_412); +x_413 = lean_ctor_get(x_403, 4); +lean_inc(x_413); +if (lean_is_exclusive(x_403)) { + lean_ctor_release(x_403, 0); + lean_ctor_release(x_403, 1); + lean_ctor_release(x_403, 2); + lean_ctor_release(x_403, 3); + lean_ctor_release(x_403, 4); + x_414 = x_403; } else { - lean_dec_ref(x_386); - x_396 = lean_box(0); + lean_dec_ref(x_403); + x_414 = lean_box(0); } -x_430 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; -if (lean_is_scalar(x_396)) { - x_431 = lean_alloc_ctor(0, 4, 0); +x_450 = l_Lean_Meta_resettingSynthInstanceCache___rarg___closed__1; +if (lean_is_scalar(x_414)) { + x_451 = lean_alloc_ctor(0, 5, 0); } else { - x_431 = x_396; + x_451 = x_414; } -lean_ctor_set(x_431, 0, x_392); -lean_ctor_set(x_431, 1, x_393); -lean_ctor_set(x_431, 2, x_430); -lean_ctor_set(x_431, 3, x_395); -x_432 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_432, 0, x_387); -lean_ctor_set(x_432, 1, x_388); -lean_ctor_set(x_432, 2, x_431); -lean_ctor_set(x_432, 3, x_389); -lean_ctor_set(x_432, 4, x_390); -lean_ctor_set(x_432, 5, x_391); -x_433 = lean_ctor_get(x_12, 0); -lean_inc(x_433); -x_434 = lean_ctor_get(x_12, 1); -lean_inc(x_434); -x_435 = lean_ctor_get(x_12, 2); -lean_inc(x_435); -x_436 = lean_ctor_get(x_12, 3); -lean_inc(x_436); -x_437 = lean_ctor_get(x_12, 4); -lean_inc(x_437); +lean_ctor_set(x_451, 0, x_409); +lean_ctor_set(x_451, 1, x_410); +lean_ctor_set(x_451, 2, x_450); +lean_ctor_set(x_451, 3, x_412); +lean_ctor_set(x_451, 4, x_413); +x_452 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_452, 0, x_404); +lean_ctor_set(x_452, 1, x_405); +lean_ctor_set(x_452, 2, x_451); +lean_ctor_set(x_452, 3, x_406); +lean_ctor_set(x_452, 4, x_407); +lean_ctor_set(x_452, 5, x_408); +x_453 = lean_ctor_get(x_12, 0); +lean_inc(x_453); +x_454 = lean_ctor_get(x_12, 1); +lean_inc(x_454); +x_455 = lean_ctor_get(x_12, 2); +lean_inc(x_455); +x_456 = lean_ctor_get(x_12, 3); +lean_inc(x_456); +x_457 = lean_ctor_get(x_12, 4); +lean_inc(x_457); if (lean_is_exclusive(x_12)) { lean_ctor_release(x_12, 0); lean_ctor_release(x_12, 1); lean_ctor_release(x_12, 2); lean_ctor_release(x_12, 3); lean_ctor_release(x_12, 4); - x_438 = x_12; + x_458 = x_12; } else { lean_dec_ref(x_12); - x_438 = lean_box(0); + x_458 = lean_box(0); } -x_439 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_439, 0, x_246); -lean_ctor_set(x_439, 1, x_21); -x_440 = lean_array_push(x_435, x_439); -if (lean_is_scalar(x_438)) { - x_441 = lean_alloc_ctor(0, 5, 0); +x_459 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_459, 0, x_256); +lean_ctor_set(x_459, 1, x_21); +x_460 = lean_array_push(x_455, x_459); +if (lean_is_scalar(x_458)) { + x_461 = lean_alloc_ctor(0, 5, 0); } else { - x_441 = x_438; + x_461 = x_458; } -lean_ctor_set(x_441, 0, x_433); -lean_ctor_set(x_441, 1, x_434); -lean_ctor_set(x_441, 2, x_440); -lean_ctor_set(x_441, 3, x_436); -lean_ctor_set(x_441, 4, x_437); -x_442 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_introN___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_248, x_441, x_432); -if (lean_obj_tag(x_442) == 0) +lean_ctor_set(x_461, 0, x_453); +lean_ctor_set(x_461, 1, x_454); +lean_ctor_set(x_461, 2, x_460); +lean_ctor_set(x_461, 3, x_456); +lean_ctor_set(x_461, 4, x_457); +x_462 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_introN___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_258, x_461, x_452); +if (lean_obj_tag(x_462) == 0) { -lean_object* x_443; lean_object* x_444; lean_object* x_445; -x_443 = lean_ctor_get(x_442, 0); -lean_inc(x_443); -x_444 = lean_ctor_get(x_442, 1); -lean_inc(x_444); -lean_dec(x_442); -x_445 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_445, 0, x_443); -x_397 = x_445; -x_398 = x_444; -goto block_429; +lean_object* x_463; lean_object* x_464; lean_object* x_465; +x_463 = lean_ctor_get(x_462, 0); +lean_inc(x_463); +x_464 = lean_ctor_get(x_462, 1); +lean_inc(x_464); +lean_dec(x_462); +x_465 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_465, 0, x_463); +x_415 = x_465; +x_416 = x_464; +goto block_449; } else { -lean_object* x_446; lean_object* x_447; lean_object* x_448; -x_446 = lean_ctor_get(x_442, 0); -lean_inc(x_446); -x_447 = lean_ctor_get(x_442, 1); -lean_inc(x_447); -lean_dec(x_442); -x_448 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_448, 0, x_446); -x_397 = x_448; -x_398 = x_447; -goto block_429; +lean_object* x_466; lean_object* x_467; lean_object* x_468; +x_466 = lean_ctor_get(x_462, 0); +lean_inc(x_466); +x_467 = lean_ctor_get(x_462, 1); +lean_inc(x_467); +lean_dec(x_462); +x_468 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_468, 0, x_466); +x_415 = x_468; +x_416 = x_467; +goto block_449; } -block_429: +block_449: { -if (lean_obj_tag(x_397) == 0) +if (lean_obj_tag(x_415) == 0) { -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; lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_object* x_412; lean_object* x_413; -x_399 = lean_ctor_get(x_398, 2); -lean_inc(x_399); -x_400 = lean_ctor_get(x_397, 0); -lean_inc(x_400); -lean_dec(x_397); -x_401 = lean_ctor_get(x_398, 0); -lean_inc(x_401); -x_402 = lean_ctor_get(x_398, 1); -lean_inc(x_402); -x_403 = lean_ctor_get(x_398, 3); -lean_inc(x_403); -x_404 = lean_ctor_get(x_398, 4); -lean_inc(x_404); -x_405 = lean_ctor_get(x_398, 5); -lean_inc(x_405); -if (lean_is_exclusive(x_398)) { - lean_ctor_release(x_398, 0); - lean_ctor_release(x_398, 1); - lean_ctor_release(x_398, 2); - lean_ctor_release(x_398, 3); - lean_ctor_release(x_398, 4); - lean_ctor_release(x_398, 5); - x_406 = x_398; -} else { - lean_dec_ref(x_398); - x_406 = lean_box(0); -} -x_407 = lean_ctor_get(x_399, 0); -lean_inc(x_407); -x_408 = lean_ctor_get(x_399, 1); -lean_inc(x_408); -x_409 = lean_ctor_get(x_399, 3); -lean_inc(x_409); -if (lean_is_exclusive(x_399)) { - lean_ctor_release(x_399, 0); - lean_ctor_release(x_399, 1); - lean_ctor_release(x_399, 2); - lean_ctor_release(x_399, 3); - x_410 = x_399; -} else { - lean_dec_ref(x_399); - x_410 = lean_box(0); -} -if (lean_is_scalar(x_410)) { - x_411 = lean_alloc_ctor(0, 4, 0); -} else { - x_411 = x_410; -} -lean_ctor_set(x_411, 0, x_407); -lean_ctor_set(x_411, 1, x_408); -lean_ctor_set(x_411, 2, x_394); -lean_ctor_set(x_411, 3, x_409); -if (lean_is_scalar(x_406)) { - x_412 = lean_alloc_ctor(0, 6, 0); -} else { - x_412 = x_406; -} -lean_ctor_set(x_412, 0, x_401); -lean_ctor_set(x_412, 1, x_402); -lean_ctor_set(x_412, 2, x_411); -lean_ctor_set(x_412, 3, x_403); -lean_ctor_set(x_412, 4, x_404); -lean_ctor_set(x_412, 5, x_405); -if (lean_is_scalar(x_245)) { - x_413 = lean_alloc_ctor(1, 2, 0); -} else { - x_413 = x_245; - lean_ctor_set_tag(x_413, 1); -} -lean_ctor_set(x_413, 0, x_400); -lean_ctor_set(x_413, 1, x_412); -return x_413; -} -else -{ -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; lean_object* x_426; lean_object* x_427; lean_object* x_428; -x_414 = lean_ctor_get(x_398, 2); -lean_inc(x_414); -x_415 = lean_ctor_get(x_397, 0); -lean_inc(x_415); -lean_dec(x_397); -x_416 = lean_ctor_get(x_398, 0); -lean_inc(x_416); -x_417 = lean_ctor_get(x_398, 1); +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; lean_object* x_426; lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; lean_object* x_432; +x_417 = lean_ctor_get(x_416, 2); lean_inc(x_417); -x_418 = lean_ctor_get(x_398, 3); +x_418 = lean_ctor_get(x_415, 0); lean_inc(x_418); -x_419 = lean_ctor_get(x_398, 4); +lean_dec(x_415); +x_419 = lean_ctor_get(x_416, 0); lean_inc(x_419); -x_420 = lean_ctor_get(x_398, 5); +x_420 = lean_ctor_get(x_416, 1); lean_inc(x_420); -if (lean_is_exclusive(x_398)) { - lean_ctor_release(x_398, 0); - lean_ctor_release(x_398, 1); - lean_ctor_release(x_398, 2); - lean_ctor_release(x_398, 3); - lean_ctor_release(x_398, 4); - lean_ctor_release(x_398, 5); - x_421 = x_398; -} else { - lean_dec_ref(x_398); - x_421 = lean_box(0); -} -x_422 = lean_ctor_get(x_414, 0); +x_421 = lean_ctor_get(x_416, 3); +lean_inc(x_421); +x_422 = lean_ctor_get(x_416, 4); lean_inc(x_422); -x_423 = lean_ctor_get(x_414, 1); +x_423 = lean_ctor_get(x_416, 5); lean_inc(x_423); -x_424 = lean_ctor_get(x_414, 3); -lean_inc(x_424); -if (lean_is_exclusive(x_414)) { - lean_ctor_release(x_414, 0); - lean_ctor_release(x_414, 1); - lean_ctor_release(x_414, 2); - lean_ctor_release(x_414, 3); - x_425 = x_414; +if (lean_is_exclusive(x_416)) { + lean_ctor_release(x_416, 0); + lean_ctor_release(x_416, 1); + lean_ctor_release(x_416, 2); + lean_ctor_release(x_416, 3); + lean_ctor_release(x_416, 4); + lean_ctor_release(x_416, 5); + x_424 = x_416; } else { - lean_dec_ref(x_414); - x_425 = lean_box(0); + lean_dec_ref(x_416); + x_424 = lean_box(0); } -if (lean_is_scalar(x_425)) { - x_426 = lean_alloc_ctor(0, 4, 0); +x_425 = lean_ctor_get(x_417, 0); +lean_inc(x_425); +x_426 = lean_ctor_get(x_417, 1); +lean_inc(x_426); +x_427 = lean_ctor_get(x_417, 3); +lean_inc(x_427); +x_428 = lean_ctor_get(x_417, 4); +lean_inc(x_428); +if (lean_is_exclusive(x_417)) { + lean_ctor_release(x_417, 0); + lean_ctor_release(x_417, 1); + lean_ctor_release(x_417, 2); + lean_ctor_release(x_417, 3); + lean_ctor_release(x_417, 4); + x_429 = x_417; } else { - x_426 = x_425; + lean_dec_ref(x_417); + x_429 = lean_box(0); } -lean_ctor_set(x_426, 0, x_422); -lean_ctor_set(x_426, 1, x_423); -lean_ctor_set(x_426, 2, x_394); -lean_ctor_set(x_426, 3, x_424); -if (lean_is_scalar(x_421)) { - x_427 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_429)) { + x_430 = lean_alloc_ctor(0, 5, 0); } else { - x_427 = x_421; + x_430 = x_429; } -lean_ctor_set(x_427, 0, x_416); -lean_ctor_set(x_427, 1, x_417); -lean_ctor_set(x_427, 2, x_426); -lean_ctor_set(x_427, 3, x_418); -lean_ctor_set(x_427, 4, x_419); -lean_ctor_set(x_427, 5, x_420); -if (lean_is_scalar(x_245)) { - x_428 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_430, 0, x_425); +lean_ctor_set(x_430, 1, x_426); +lean_ctor_set(x_430, 2, x_411); +lean_ctor_set(x_430, 3, x_427); +lean_ctor_set(x_430, 4, x_428); +if (lean_is_scalar(x_424)) { + x_431 = lean_alloc_ctor(0, 6, 0); } else { - x_428 = x_245; + x_431 = x_424; } -lean_ctor_set(x_428, 0, x_415); -lean_ctor_set(x_428, 1, x_427); -return x_428; +lean_ctor_set(x_431, 0, x_419); +lean_ctor_set(x_431, 1, x_420); +lean_ctor_set(x_431, 2, x_430); +lean_ctor_set(x_431, 3, x_421); +lean_ctor_set(x_431, 4, x_422); +lean_ctor_set(x_431, 5, x_423); +if (lean_is_scalar(x_255)) { + x_432 = lean_alloc_ctor(1, 2, 0); +} else { + x_432 = x_255; + lean_ctor_set_tag(x_432, 1); +} +lean_ctor_set(x_432, 0, x_418); +lean_ctor_set(x_432, 1, x_431); +return x_432; +} +else +{ +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; lean_object* x_445; lean_object* x_446; lean_object* x_447; lean_object* x_448; +x_433 = lean_ctor_get(x_416, 2); +lean_inc(x_433); +x_434 = lean_ctor_get(x_415, 0); +lean_inc(x_434); +lean_dec(x_415); +x_435 = lean_ctor_get(x_416, 0); +lean_inc(x_435); +x_436 = lean_ctor_get(x_416, 1); +lean_inc(x_436); +x_437 = lean_ctor_get(x_416, 3); +lean_inc(x_437); +x_438 = lean_ctor_get(x_416, 4); +lean_inc(x_438); +x_439 = lean_ctor_get(x_416, 5); +lean_inc(x_439); +if (lean_is_exclusive(x_416)) { + lean_ctor_release(x_416, 0); + lean_ctor_release(x_416, 1); + lean_ctor_release(x_416, 2); + lean_ctor_release(x_416, 3); + lean_ctor_release(x_416, 4); + lean_ctor_release(x_416, 5); + x_440 = x_416; +} else { + lean_dec_ref(x_416); + x_440 = lean_box(0); +} +x_441 = lean_ctor_get(x_433, 0); +lean_inc(x_441); +x_442 = lean_ctor_get(x_433, 1); +lean_inc(x_442); +x_443 = lean_ctor_get(x_433, 3); +lean_inc(x_443); +x_444 = lean_ctor_get(x_433, 4); +lean_inc(x_444); +if (lean_is_exclusive(x_433)) { + lean_ctor_release(x_433, 0); + lean_ctor_release(x_433, 1); + lean_ctor_release(x_433, 2); + lean_ctor_release(x_433, 3); + lean_ctor_release(x_433, 4); + x_445 = x_433; +} else { + lean_dec_ref(x_433); + x_445 = lean_box(0); +} +if (lean_is_scalar(x_445)) { + x_446 = lean_alloc_ctor(0, 5, 0); +} else { + x_446 = x_445; +} +lean_ctor_set(x_446, 0, x_441); +lean_ctor_set(x_446, 1, x_442); +lean_ctor_set(x_446, 2, x_411); +lean_ctor_set(x_446, 3, x_443); +lean_ctor_set(x_446, 4, x_444); +if (lean_is_scalar(x_440)) { + x_447 = lean_alloc_ctor(0, 6, 0); +} else { + x_447 = x_440; +} +lean_ctor_set(x_447, 0, x_435); +lean_ctor_set(x_447, 1, x_436); +lean_ctor_set(x_447, 2, x_446); +lean_ctor_set(x_447, 3, x_437); +lean_ctor_set(x_447, 4, x_438); +lean_ctor_set(x_447, 5, x_439); +if (lean_is_scalar(x_255)) { + x_448 = lean_alloc_ctor(0, 2, 0); +} else { + x_448 = x_255; +} +lean_ctor_set(x_448, 0, x_434); +lean_ctor_set(x_448, 1, x_447); +return x_448; } } } @@ -4717,7 +4865,7 @@ return x_428; } else { -uint8_t x_449; +uint8_t x_469; lean_dec(x_21); lean_dec(x_12); lean_dec(x_11); @@ -4727,23 +4875,23 @@ lean_dec(x_6); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_449 = !lean_is_exclusive(x_238); -if (x_449 == 0) +x_469 = !lean_is_exclusive(x_248); +if (x_469 == 0) { -return x_238; +return x_248; } else { -lean_object* x_450; lean_object* x_451; lean_object* x_452; -x_450 = lean_ctor_get(x_238, 0); -x_451 = lean_ctor_get(x_238, 1); -lean_inc(x_451); -lean_inc(x_450); -lean_dec(x_238); -x_452 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_452, 0, x_450); -lean_ctor_set(x_452, 1, x_451); -return x_452; +lean_object* x_470; lean_object* x_471; lean_object* x_472; +x_470 = lean_ctor_get(x_248, 0); +x_471 = lean_ctor_get(x_248, 1); +lean_inc(x_471); +lean_inc(x_470); +lean_dec(x_248); +x_472 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_472, 0, x_470); +lean_ctor_set(x_472, 1, x_471); +return x_472; } } } @@ -4751,7 +4899,7 @@ return x_452; } else { -uint8_t x_453; +uint8_t x_473; lean_dec(x_25); lean_dec(x_21); lean_dec(x_12); @@ -4762,29 +4910,29 @@ lean_dec(x_6); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_453 = !lean_is_exclusive(x_26); -if (x_453 == 0) +x_473 = !lean_is_exclusive(x_26); +if (x_473 == 0) { return x_26; } else { -lean_object* x_454; lean_object* x_455; lean_object* x_456; -x_454 = lean_ctor_get(x_26, 0); -x_455 = lean_ctor_get(x_26, 1); -lean_inc(x_455); -lean_inc(x_454); +lean_object* x_474; lean_object* x_475; lean_object* x_476; +x_474 = lean_ctor_get(x_26, 0); +x_475 = lean_ctor_get(x_26, 1); +lean_inc(x_475); +lean_inc(x_474); lean_dec(x_26); -x_456 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_456, 0, x_454); -lean_ctor_set(x_456, 1, x_455); -return x_456; +x_476 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_476, 0, x_474); +lean_ctor_set(x_476, 1, x_475); +return x_476; } } } else { -uint8_t x_457; +uint8_t x_477; lean_dec(x_21); lean_dec(x_12); lean_dec(x_11); @@ -4794,23 +4942,23 @@ lean_dec(x_6); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_457 = !lean_is_exclusive(x_22); -if (x_457 == 0) +x_477 = !lean_is_exclusive(x_22); +if (x_477 == 0) { return x_22; } else { -lean_object* x_458; lean_object* x_459; lean_object* x_460; -x_458 = lean_ctor_get(x_22, 0); -x_459 = lean_ctor_get(x_22, 1); -lean_inc(x_459); -lean_inc(x_458); +lean_object* x_478; lean_object* x_479; lean_object* x_480; +x_478 = lean_ctor_get(x_22, 0); +x_479 = lean_ctor_get(x_22, 1); +lean_inc(x_479); +lean_inc(x_478); lean_dec(x_22); -x_460 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_460, 0, x_458); -lean_ctor_set(x_460, 1, x_459); -return x_460; +x_480 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_480, 0, x_478); +lean_ctor_set(x_480, 1, x_479); +return x_480; } } } diff --git a/stage0/stdlib/Lean/Meta/Tactic/Subst.c b/stage0/stdlib/Lean/Meta/Tactic/Subst.c index 7444f73c45..5830e37ce4 100644 --- a/stage0/stdlib/Lean/Meta/Tactic/Subst.c +++ b/stage0/stdlib/Lean/Meta/Tactic/Subst.c @@ -14,6 +14,7 @@ extern "C" { #endif lean_object* l_Array_findSomeMAux___main___at_Lean_Meta_subst___spec__4(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +extern lean_object* l_Lean_Name_toString___closed__1; lean_object* l_Lean_Meta_substCore___lambda__3___closed__2; lean_object* l_Lean_Meta_substCore___lambda__3___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Expr_eq_x3f___closed__2; @@ -24,6 +25,8 @@ lean_object* l_Lean_Meta_subst___lambda__1___boxed(lean_object*, lean_object*, l lean_object* l_unreachable_x21___rarg(lean_object*); lean_object* l_Lean_Meta_substCore___lambda__3___closed__17; lean_object* l_Array_findSomeMAux___main___at_Lean_Meta_subst___spec__6___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +extern lean_object* l_List_repr___rarg___closed__1; +lean_object* l_Lean_Meta_substCore___lambda__3___closed__27; lean_object* l_Lean_Meta_substCore___lambda__3___closed__4; uint8_t lean_name_eq(lean_object*, lean_object*); lean_object* l_Lean_Meta_withLocalContext___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); @@ -40,16 +43,23 @@ lean_object* l_Lean_Expr_appFn_x21(lean_object*); lean_object* lean_array_push(lean_object*, lean_object*); lean_object* l_Lean_Meta_substCore___lambda__3___closed__6; lean_object* lean_array_get_size(lean_object*); +lean_object* lean_string_append(lean_object*, lean_object*); +lean_object* l_Lean_Meta_substCore___lambda__3___closed__23; lean_object* l_Lean_Meta_substCore___lambda__3___closed__13; extern lean_object* l_Lean_Name_inhabited; +extern lean_object* l_String_splitAux___main___closed__1; lean_object* l_Lean_Meta_substCore___lambda__2___closed__1; +extern lean_object* l_List_repr___rarg___closed__3; lean_object* l_Lean_Expr_appArg_x21(lean_object*); +lean_object* l_Lean_Meta_substCore___lambda__3___closed__21; lean_object* l_Lean_LocalContext_findDeclM_x3f___at_Lean_Meta_subst___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_nat_add(lean_object*, lean_object*); +lean_object* l_Lean_Meta_substCore___lambda__3___closed__31; lean_object* l_Lean_Meta_mkEqRefl(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_LocalContext_findDeclM_x3f___at_Lean_Meta_subst___spec__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Array_forMAux___main___at_Lean_Meta_clear___spec__5___closed__8; lean_object* l_Lean_Meta_substCore___lambda__3___closed__11; +extern lean_object* l_Array_HasRepr___rarg___closed__1; lean_object* lean_array_fget(lean_object*, lean_object*); lean_object* l_Lean_Meta_substCore(lean_object*, lean_object*, uint8_t, uint8_t, lean_object*, lean_object*); lean_object* l_Lean_Meta_substCore___lambda__3___closed__12; @@ -63,18 +73,23 @@ lean_object* l_Nat_foldMAux___main___at_Lean_Meta_substCore___spec__2___boxed(le lean_object* lean_array_get(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Expr_fvarId_x21(lean_object*); lean_object* l_Lean_Meta_clear(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Lean_Meta_Tactic_Subst_1__regTraceClasses___closed__1; lean_object* l_Lean_Meta_substCore___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_substCore___lambda__3___closed__9; lean_object* l_Std_RBNode_insert___at_Lean_NameMap_insert___spec__1___rarg(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_subst___lambda__1___closed__6; lean_object* l_Lean_Meta_substCore___lambda__3___closed__19; lean_object* lean_name_mk_string(lean_object*, lean_object*); +extern lean_object* l_List_repr___rarg___closed__2; lean_object* l_Lean_Meta_revert(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*); +extern lean_object* l_List_reprAux___main___rarg___closed__1; lean_object* l_Lean_Meta_mkEqNDRec(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_substCore___lambda__3___closed__10; +lean_object* l_Lean_Meta_substCore___lambda__3___closed__32; +lean_object* l_Lean_Meta_substCore___lambda__3___closed__20; lean_object* l_Lean_Meta_subst___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_substCore___lambda__3___closed__24; lean_object* l_Array_findSomeMAux___main___at_Lean_Meta_subst___spec__6(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_List_toStringAux___main___at_Lean_Meta_substCore___spec__5___boxed(lean_object*, lean_object*); lean_object* l_Lean_Meta_whnf(lean_object*, lean_object*, lean_object*); lean_object* l_Std_PersistentArray_findSomeMAux___main___at_Lean_Meta_subst___spec__3(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_mkFVar(lean_object*); @@ -99,26 +114,38 @@ extern lean_object* l_Lean_Meta_FVarSubst_empty; lean_object* l_Lean_Meta_substCore___lambda__3(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_mkFreshExprMVar(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*); lean_object* l_Array_findSomeMAux___main___at_Lean_Meta_subst___spec__4___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_substCore___lambda__3___closed__26; +lean_object* l___private_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_isLevelDefEqAux___main___spec__2(lean_object*, lean_object*, lean_object*); lean_object* l_Nat_foldMAux___main___at_Lean_Meta_substCore___spec__3___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_substCore___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_subst___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_subst___lambda__1___closed__5; +lean_object* l_List_toString___at_Lean_Meta_substCore___spec__4(lean_object*); lean_object* l_Lean_Meta_introNCore___at_Lean_Meta_introN___spec__1(uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_substCore___lambda__3___closed__22; uint8_t l_Lean_Expr_isFVar(lean_object*); extern lean_object* l_Lean_mkAppStx___closed__9; lean_object* l_Lean_Meta_substCore___lambda__3___closed__5; lean_object* l_Lean_Meta_mkLambda(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_getMVarDecl(lean_object*, lean_object*, lean_object*); +lean_object* l_Array_toList___rarg(lean_object*); lean_object* l_Lean_Meta_substCore___lambda__3___closed__14; lean_object* l_Array_findSomeMAux___main___at_Lean_Meta_subst___spec__5(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_substCore___lambda__3___closed__25; extern lean_object* l___private_Lean_Meta_Tactic_Util_1__regTraceClasses___closed__2; +lean_object* l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__1(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Meta_Tactic_Subst_1__regTraceClasses(lean_object*); lean_object* l_Std_PersistentArray_findSomeM_x3f___at_Lean_Meta_subst___spec__2(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_mkOptionalNode___closed__2; +lean_object* l_Lean_Meta_substCore___lambda__3___closed__29; extern lean_object* l_Lean_Meta_isClassQuick___main___closed__1; lean_object* l_Std_PersistentArray_findSomeMAux___main___at_Lean_Meta_subst___spec__3___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_List_toStringAux___main___at_Lean_Meta_substCore___spec__5(uint8_t, lean_object*); +lean_object* l_Lean_Name_toStringWithSep___main(lean_object*, lean_object*); +lean_object* l_Lean_Meta_substCore___lambda__3___closed__28; lean_object* l_Lean_Meta_mkEq(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_subst___lambda__1___closed__1; +lean_object* l_Lean_Meta_substCore___lambda__3___closed__30; lean_object* l_Lean_indentExpr(lean_object*); lean_object* l_Lean_Meta_getMVarTag___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_substCore___lambda__3___closed__3; @@ -134,30 +161,33 @@ x_8 = lean_unsigned_to_nat(0u); x_9 = lean_nat_dec_eq(x_4, x_8); if (x_9 == 0) { -lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; +lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; x_10 = lean_unsigned_to_nat(1u); x_11 = lean_nat_sub(x_4, x_10); lean_dec(x_4); x_12 = lean_nat_sub(x_3, x_11); x_13 = lean_nat_sub(x_12, x_10); lean_dec(x_12); -x_14 = l_Lean_Name_inhabited; -x_15 = lean_array_get(x_14, x_1, x_13); -x_16 = lean_array_get(x_14, x_2, x_13); +x_14 = lean_unsigned_to_nat(2u); +x_15 = lean_nat_add(x_13, x_14); +x_16 = l_Lean_Name_inhabited; +x_17 = lean_array_get(x_16, x_1, x_15); +lean_dec(x_15); +x_18 = lean_array_get(x_16, x_2, x_13); lean_dec(x_13); -x_17 = l_Std_RBNode_insert___at_Lean_NameMap_insert___spec__1___rarg(x_5, x_15, x_16); +x_19 = l_Std_RBNode_insert___at_Lean_NameMap_insert___spec__1___rarg(x_5, x_17, x_18); x_4 = x_11; -x_5 = x_17; +x_5 = x_19; goto _start; } else { -lean_object* x_19; +lean_object* x_21; lean_dec(x_4); -x_19 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_19, 0, x_5); -lean_ctor_set(x_19, 1, x_7); -return x_19; +x_21 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_21, 0, x_5); +lean_ctor_set(x_21, 1, x_7); +return x_21; } } } @@ -169,30 +199,33 @@ x_8 = lean_unsigned_to_nat(0u); x_9 = lean_nat_dec_eq(x_4, x_8); if (x_9 == 0) { -lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; +lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; x_10 = lean_unsigned_to_nat(1u); x_11 = lean_nat_sub(x_4, x_10); lean_dec(x_4); x_12 = lean_nat_sub(x_3, x_11); x_13 = lean_nat_sub(x_12, x_10); lean_dec(x_12); -x_14 = l_Lean_Name_inhabited; -x_15 = lean_array_get(x_14, x_1, x_13); -x_16 = lean_array_get(x_14, x_2, x_13); +x_14 = lean_unsigned_to_nat(2u); +x_15 = lean_nat_add(x_13, x_14); +x_16 = l_Lean_Name_inhabited; +x_17 = lean_array_get(x_16, x_1, x_15); +lean_dec(x_15); +x_18 = lean_array_get(x_16, x_2, x_13); lean_dec(x_13); -x_17 = l_Std_RBNode_insert___at_Lean_NameMap_insert___spec__1___rarg(x_5, x_15, x_16); +x_19 = l_Std_RBNode_insert___at_Lean_NameMap_insert___spec__1___rarg(x_5, x_17, x_18); x_4 = x_11; -x_5 = x_17; +x_5 = x_19; goto _start; } else { -lean_object* x_19; +lean_object* x_21; lean_dec(x_4); -x_19 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_19, 0, x_5); -lean_ctor_set(x_19, 1, x_7); -return x_19; +x_21 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_21, 0, x_5); +lean_ctor_set(x_21, 1, x_7); +return x_21; } } } @@ -204,33 +237,116 @@ x_8 = lean_unsigned_to_nat(0u); x_9 = lean_nat_dec_eq(x_4, x_8); if (x_9 == 0) { -lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; +lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; x_10 = lean_unsigned_to_nat(1u); x_11 = lean_nat_sub(x_4, x_10); lean_dec(x_4); x_12 = lean_nat_sub(x_3, x_11); x_13 = lean_nat_sub(x_12, x_10); lean_dec(x_12); -x_14 = l_Lean_Name_inhabited; -x_15 = lean_array_get(x_14, x_1, x_13); -x_16 = lean_array_get(x_14, x_2, x_13); +x_14 = lean_unsigned_to_nat(2u); +x_15 = lean_nat_add(x_13, x_14); +x_16 = l_Lean_Name_inhabited; +x_17 = lean_array_get(x_16, x_1, x_15); +lean_dec(x_15); +x_18 = lean_array_get(x_16, x_2, x_13); lean_dec(x_13); -x_17 = l_Std_RBNode_insert___at_Lean_NameMap_insert___spec__1___rarg(x_5, x_15, x_16); +x_19 = l_Std_RBNode_insert___at_Lean_NameMap_insert___spec__1___rarg(x_5, x_17, x_18); x_4 = x_11; -x_5 = x_17; +x_5 = x_19; goto _start; } else { -lean_object* x_19; +lean_object* x_21; lean_dec(x_4); -x_19 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_19, 0, x_5); -lean_ctor_set(x_19, 1, x_7); +x_21 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_21, 0, x_5); +lean_ctor_set(x_21, 1, x_7); +return x_21; +} +} +} +lean_object* l_List_toStringAux___main___at_Lean_Meta_substCore___spec__5(uint8_t x_1, lean_object* x_2) { +_start: +{ +if (x_1 == 0) +{ +if (lean_obj_tag(x_2) == 0) +{ +lean_object* x_3; +x_3 = l_String_splitAux___main___closed__1; +return x_3; +} +else +{ +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_4 = lean_ctor_get(x_2, 0); +lean_inc(x_4); +x_5 = lean_ctor_get(x_2, 1); +lean_inc(x_5); +lean_dec(x_2); +x_6 = l_Lean_Name_toString___closed__1; +x_7 = l_Lean_Name_toStringWithSep___main(x_6, x_4); +x_8 = l_List_reprAux___main___rarg___closed__1; +x_9 = lean_string_append(x_8, x_7); +lean_dec(x_7); +x_10 = l_List_toStringAux___main___at_Lean_Meta_substCore___spec__5(x_1, x_5); +x_11 = lean_string_append(x_9, x_10); +lean_dec(x_10); +return x_11; +} +} +else +{ +if (lean_obj_tag(x_2) == 0) +{ +lean_object* x_12; +x_12 = l_String_splitAux___main___closed__1; +return x_12; +} +else +{ +lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; uint8_t x_17; lean_object* x_18; lean_object* x_19; +x_13 = lean_ctor_get(x_2, 0); +lean_inc(x_13); +x_14 = lean_ctor_get(x_2, 1); +lean_inc(x_14); +lean_dec(x_2); +x_15 = l_Lean_Name_toString___closed__1; +x_16 = l_Lean_Name_toStringWithSep___main(x_15, x_13); +x_17 = 0; +x_18 = l_List_toStringAux___main___at_Lean_Meta_substCore___spec__5(x_17, x_14); +x_19 = lean_string_append(x_16, x_18); +lean_dec(x_18); return x_19; } } } +} +lean_object* l_List_toString___at_Lean_Meta_substCore___spec__4(lean_object* x_1) { +_start: +{ +if (lean_obj_tag(x_1) == 0) +{ +lean_object* x_2; +x_2 = l_List_repr___rarg___closed__1; +return x_2; +} +else +{ +uint8_t x_3; lean_object* x_4; lean_object* x_5; lean_object* x_6; lean_object* x_7; lean_object* x_8; +x_3 = 1; +x_4 = l_List_toStringAux___main___at_Lean_Meta_substCore___spec__5(x_3, x_1); +x_5 = l_List_repr___rarg___closed__2; +x_6 = lean_string_append(x_5, x_4); +lean_dec(x_4); +x_7 = l_List_repr___rarg___closed__3; +x_8 = lean_string_append(x_6, x_7); +return x_8; +} +} +} lean_object* l_Lean_Meta_substCore___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) { _start: { @@ -1721,19 +1837,19 @@ return x_3; lean_object* _init_l_Lean_Meta_substCore___lambda__3___closed__17() { _start: { -lean_object* x_1; -x_1 = lean_mk_string("' occurs at"); -return x_1; +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = l___private_Lean_Meta_Tactic_Util_1__regTraceClasses___closed__2; +x_2 = l_Lean_Meta_substCore___lambda__3___closed__1; +x_3 = lean_name_mk_string(x_1, x_2); +return x_3; } } lean_object* _init_l_Lean_Meta_substCore___lambda__3___closed__18() { _start: { -lean_object* x_1; lean_object* x_2; -x_1 = l_Lean_Meta_substCore___lambda__3___closed__17; -x_2 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_2, 0, x_1); -return x_2; +lean_object* x_1; +x_1 = lean_mk_string("reverted variables "); +return x_1; } } lean_object* _init_l_Lean_Meta_substCore___lambda__3___closed__19() { @@ -1741,6 +1857,128 @@ _start: { lean_object* x_1; lean_object* x_2; x_1 = l_Lean_Meta_substCore___lambda__3___closed__18; +x_2 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l_Lean_Meta_substCore___lambda__3___closed__20() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l_Lean_Meta_substCore___lambda__3___closed__19; +x_2 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l_Lean_Meta_substCore___lambda__3___closed__21() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("' occurs at"); +return x_1; +} +} +lean_object* _init_l_Lean_Meta_substCore___lambda__3___closed__22() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l_Lean_Meta_substCore___lambda__3___closed__21; +x_2 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l_Lean_Meta_substCore___lambda__3___closed__23() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l_Lean_Meta_substCore___lambda__3___closed__22; +x_2 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l_Lean_Meta_substCore___lambda__3___closed__24() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("substituting "); +return x_1; +} +} +lean_object* _init_l_Lean_Meta_substCore___lambda__3___closed__25() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l_Lean_Meta_substCore___lambda__3___closed__24; +x_2 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l_Lean_Meta_substCore___lambda__3___closed__26() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l_Lean_Meta_substCore___lambda__3___closed__25; +x_2 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l_Lean_Meta_substCore___lambda__3___closed__27() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string(" (id: "); +return x_1; +} +} +lean_object* _init_l_Lean_Meta_substCore___lambda__3___closed__28() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l_Lean_Meta_substCore___lambda__3___closed__27; +x_2 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l_Lean_Meta_substCore___lambda__3___closed__29() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l_Lean_Meta_substCore___lambda__3___closed__28; +x_2 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l_Lean_Meta_substCore___lambda__3___closed__30() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string(") with "); +return x_1; +} +} +lean_object* _init_l_Lean_Meta_substCore___lambda__3___closed__31() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l_Lean_Meta_substCore___lambda__3___closed__30; +x_2 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* _init_l_Lean_Meta_substCore___lambda__3___closed__32() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l_Lean_Meta_substCore___lambda__3___closed__31; x_2 = lean_alloc_ctor(0, 1, 0); lean_ctor_set(x_2, 0, x_1); return x_2; @@ -1795,49 +2033,49 @@ lean_dec(x_19); x_21 = l_Lean_Expr_appArg_x21(x_13); if (x_3 == 0) { -uint8_t x_117; -x_117 = 0; -x_22 = x_117; -goto block_116; +uint8_t x_171; +x_171 = 0; +x_22 = x_171; +goto block_170; } else { -uint8_t x_118; -x_118 = 1; -x_22 = x_118; -goto block_116; +uint8_t x_172; +x_172 = 1; +x_22 = x_172; +goto block_170; } -block_116: +block_170: { lean_object* x_23; if (x_22 == 0) { lean_inc(x_20); x_23 = x_20; -goto block_115; +goto block_169; } else { lean_inc(x_21); x_23 = x_21; -goto block_115; +goto block_169; } -block_115: +block_169: { lean_object* x_24; if (x_22 == 0) { lean_dec(x_20); x_24 = x_21; -goto block_114; +goto block_168; } else { lean_dec(x_21); x_24 = x_20; -goto block_114; +goto block_168; } -block_114: +block_168: { lean_object* x_25; lean_inc(x_5); @@ -1852,275 +2090,447 @@ lean_inc(x_27); lean_dec(x_25); if (lean_obj_tag(x_26) == 1) { -lean_object* x_38; lean_object* x_39; lean_object* x_40; uint8_t x_41; lean_object* x_42; +lean_object* x_38; lean_object* x_39; lean_object* x_142; uint8_t x_143; lean_dec(x_13); x_38 = lean_ctor_get(x_26, 0); lean_inc(x_38); -x_39 = lean_ctor_get(x_27, 1); -lean_inc(x_39); +x_142 = lean_ctor_get(x_27, 4); +lean_inc(x_142); +x_143 = lean_ctor_get_uint8(x_142, sizeof(void*)*1); +lean_dec(x_142); +if (x_143 == 0) +{ +x_39 = x_27; +goto block_141; +} +else +{ +lean_object* x_144; lean_object* x_145; lean_object* x_146; uint8_t x_147; +x_144 = l_Lean_Meta_substCore___lambda__3___closed__17; +x_145 = l___private_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_144, x_5, x_27); +x_146 = lean_ctor_get(x_145, 0); +lean_inc(x_146); +x_147 = lean_unbox(x_146); +lean_dec(x_146); +if (x_147 == 0) +{ +lean_object* x_148; +x_148 = lean_ctor_get(x_145, 1); +lean_inc(x_148); +lean_dec(x_145); +x_39 = x_148; +goto block_141; +} +else +{ +lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; +x_149 = lean_ctor_get(x_145, 1); +lean_inc(x_149); +lean_dec(x_145); +lean_inc(x_26); +x_150 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_150, 0, x_26); +x_151 = l_Lean_Meta_substCore___lambda__3___closed__26; +x_152 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_152, 0, x_151); +lean_ctor_set(x_152, 1, x_150); +x_153 = l_Lean_Meta_substCore___lambda__3___closed__29; +x_154 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_154, 0, x_152); +lean_ctor_set(x_154, 1, x_153); +lean_inc(x_38); +x_155 = lean_alloc_ctor(4, 1, 0); +lean_ctor_set(x_155, 0, x_38); +x_156 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_156, 0, x_154); +lean_ctor_set(x_156, 1, x_155); +x_157 = l_Lean_Meta_substCore___lambda__3___closed__32; +x_158 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_158, 0, x_156); +lean_ctor_set(x_158, 1, x_157); lean_inc(x_24); -x_40 = l_Lean_MetavarContext_exprDependsOn(x_39, x_24, x_38); -x_41 = lean_unbox(x_40); -lean_dec(x_40); -if (x_41 == 0) +x_159 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_159, 0, x_24); +x_160 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_160, 0, x_158); +lean_ctor_set(x_160, 1, x_159); +x_161 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_144, x_160, x_5, x_149); +x_162 = lean_ctor_get(x_161, 1); +lean_inc(x_162); +lean_dec(x_161); +x_39 = x_162; +goto block_141; +} +} +block_141: +{ +lean_object* x_40; lean_object* x_41; uint8_t x_42; lean_object* x_43; +x_40 = lean_ctor_get(x_39, 1); +lean_inc(x_40); +lean_inc(x_24); +x_41 = l_Lean_MetavarContext_exprDependsOn(x_40, x_24, x_38); +x_42 = lean_unbox(x_41); +lean_dec(x_41); +if (x_42 == 0) { lean_dec(x_26); lean_dec(x_24); -x_42 = x_27; -goto block_95; +x_43 = x_39; +goto block_127; } else { -lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; uint8_t x_105; +lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; uint8_t x_137; lean_dec(x_38); lean_dec(x_4); lean_dec(x_2); -x_96 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_96, 0, x_26); -x_97 = l_Array_forMAux___main___at_Lean_Meta_clear___spec__5___closed__8; -x_98 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_98, 0, x_97); -lean_ctor_set(x_98, 1, x_96); -x_99 = l_Lean_Meta_substCore___lambda__3___closed__19; -x_100 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_100, 0, x_98); -lean_ctor_set(x_100, 1, x_99); -x_101 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_101, 0, x_24); -x_102 = l_Lean_indentExpr(x_101); -x_103 = lean_alloc_ctor(9, 2, 0); -lean_ctor_set(x_103, 0, x_100); -lean_ctor_set(x_103, 1, x_102); -x_104 = l_Lean_Meta_throwTacticEx___rarg(x_7, x_1, x_103, x_5, x_27); +x_128 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_128, 0, x_26); +x_129 = l_Array_forMAux___main___at_Lean_Meta_clear___spec__5___closed__8; +x_130 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_130, 0, x_129); +lean_ctor_set(x_130, 1, x_128); +x_131 = l_Lean_Meta_substCore___lambda__3___closed__23; +x_132 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_132, 0, x_130); +lean_ctor_set(x_132, 1, x_131); +x_133 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_133, 0, x_24); +x_134 = l_Lean_indentExpr(x_133); +x_135 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_135, 0, x_132); +lean_ctor_set(x_135, 1, x_134); +x_136 = l_Lean_Meta_throwTacticEx___rarg(x_7, x_1, x_135, x_5, x_39); lean_dec(x_5); -x_105 = !lean_is_exclusive(x_104); -if (x_105 == 0) +x_137 = !lean_is_exclusive(x_136); +if (x_137 == 0) { -return x_104; +return x_136; } else { -lean_object* x_106; lean_object* x_107; lean_object* x_108; -x_106 = lean_ctor_get(x_104, 0); -x_107 = lean_ctor_get(x_104, 1); -lean_inc(x_107); -lean_inc(x_106); -lean_dec(x_104); -x_108 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_108, 0, x_106); -lean_ctor_set(x_108, 1, x_107); -return x_108; +lean_object* x_138; lean_object* x_139; lean_object* x_140; +x_138 = lean_ctor_get(x_136, 0); +x_139 = lean_ctor_get(x_136, 1); +lean_inc(x_139); +lean_inc(x_138); +lean_dec(x_136); +x_140 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_140, 0, x_138); +lean_ctor_set(x_140, 1, x_139); +return x_140; } } -block_95: +block_127: { -lean_object* x_43; +lean_object* x_44; lean_inc(x_5); lean_inc(x_38); -x_43 = l_Lean_Meta_getLocalDecl(x_38, x_5, x_42); -if (lean_obj_tag(x_43) == 0) +x_44 = l_Lean_Meta_getLocalDecl(x_38, x_5, x_43); +if (lean_obj_tag(x_44) == 0) { -lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; uint8_t x_48; lean_object* x_49; -x_44 = lean_ctor_get(x_43, 1); -lean_inc(x_44); -lean_dec(x_43); -x_45 = l_Lean_mkAppStx___closed__9; -x_46 = lean_array_push(x_45, x_38); -x_47 = lean_array_push(x_46, x_2); -x_48 = 1; -x_49 = l_Lean_Meta_revert(x_1, x_47, x_48, x_5, x_44); -if (lean_obj_tag(x_49) == 0) +lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; uint8_t x_49; lean_object* x_50; +x_45 = lean_ctor_get(x_44, 1); +lean_inc(x_45); +lean_dec(x_44); +x_46 = l_Lean_mkAppStx___closed__9; +x_47 = lean_array_push(x_46, x_38); +x_48 = lean_array_push(x_47, x_2); +x_49 = 1; +x_50 = l_Lean_Meta_revert(x_1, x_48, x_49, x_5, x_45); +if (lean_obj_tag(x_50) == 0) { -lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; uint8_t x_55; lean_object* x_56; lean_object* x_57; -x_50 = lean_ctor_get(x_49, 0); -lean_inc(x_50); -x_51 = lean_ctor_get(x_49, 1); +lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; uint8_t x_56; lean_object* x_57; lean_object* x_58; +x_51 = lean_ctor_get(x_50, 0); lean_inc(x_51); -lean_dec(x_49); -x_52 = lean_ctor_get(x_50, 0); +x_52 = lean_ctor_get(x_50, 1); lean_inc(x_52); -x_53 = lean_ctor_get(x_50, 1); -lean_inc(x_53); lean_dec(x_50); -x_54 = lean_box(0); -x_55 = 0; -x_56 = lean_unsigned_to_nat(2u); -x_57 = l_Lean_Meta_introNCore___at_Lean_Meta_introN___spec__1(x_55, x_53, x_56, x_54, x_5, x_51); -if (lean_obj_tag(x_57) == 0) +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_55 = lean_box(0); +x_56 = 0; +x_57 = lean_unsigned_to_nat(2u); +x_58 = l_Lean_Meta_introNCore___at_Lean_Meta_introN___spec__1(x_56, x_54, x_57, x_55, x_5, x_52); +if (lean_obj_tag(x_58) == 0) { -lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; -x_58 = lean_ctor_get(x_57, 0); -lean_inc(x_58); -x_59 = lean_ctor_get(x_57, 1); +lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; uint8_t x_74; lean_object* x_75; lean_object* x_108; uint8_t x_109; +x_59 = lean_ctor_get(x_58, 0); lean_inc(x_59); -lean_dec(x_57); -x_60 = lean_ctor_get(x_58, 0); +x_60 = lean_ctor_get(x_58, 1); lean_inc(x_60); -x_61 = lean_ctor_get(x_58, 1); -lean_inc(x_61); lean_dec(x_58); -x_62 = l_Lean_Name_inhabited; -x_63 = lean_unsigned_to_nat(0u); -x_64 = lean_array_get(x_62, x_60, x_63); -lean_inc(x_64); -x_65 = l_Lean_mkFVar(x_64); -x_66 = lean_unsigned_to_nat(1u); -x_67 = lean_array_get(x_62, x_60, x_66); -lean_dec(x_60); -lean_inc(x_67); -x_68 = l_Lean_mkFVar(x_67); +x_61 = lean_ctor_get(x_59, 0); lean_inc(x_61); -x_69 = lean_alloc_closure((void*)(l_Lean_Meta_getMVarDecl___boxed), 3, 1); -lean_closure_set(x_69, 0, x_61); -x_70 = lean_box(x_22); -lean_inc(x_61); -x_71 = lean_alloc_closure((void*)(l_Lean_Meta_substCore___lambda__2___boxed), 14, 11); -lean_closure_set(x_71, 0, x_67); -lean_closure_set(x_71, 1, x_65); -lean_closure_set(x_71, 2, x_4); -lean_closure_set(x_71, 3, x_61); -lean_closure_set(x_71, 4, x_64); -lean_closure_set(x_71, 5, x_52); -lean_closure_set(x_71, 6, x_54); -lean_closure_set(x_71, 7, x_70); -lean_closure_set(x_71, 8, x_68); -lean_closure_set(x_71, 9, x_45); -lean_closure_set(x_71, 10, x_14); -x_72 = lean_alloc_closure((void*)(l_ReaderT_bind___at_Lean_Meta_isClassExpensive___main___spec__4___rarg), 4, 2); -lean_closure_set(x_72, 0, x_69); -lean_closure_set(x_72, 1, x_71); -x_73 = l_Lean_Meta_getMVarDecl(x_61, x_5, x_59); -if (lean_obj_tag(x_73) == 0) +x_62 = lean_ctor_get(x_59, 1); +lean_inc(x_62); +lean_dec(x_59); +x_63 = l_Lean_Name_inhabited; +x_64 = lean_unsigned_to_nat(0u); +x_65 = lean_array_get(x_63, x_61, x_64); +lean_inc(x_65); +x_66 = l_Lean_mkFVar(x_65); +x_67 = lean_unsigned_to_nat(1u); +x_68 = lean_array_get(x_63, x_61, x_67); +lean_dec(x_61); +lean_inc(x_68); +x_69 = l_Lean_mkFVar(x_68); +lean_inc(x_62); +x_70 = lean_alloc_closure((void*)(l_Lean_Meta_getMVarDecl___boxed), 3, 1); +lean_closure_set(x_70, 0, x_62); +x_71 = lean_box(x_22); +lean_inc(x_53); +lean_inc(x_62); +x_72 = lean_alloc_closure((void*)(l_Lean_Meta_substCore___lambda__2___boxed), 14, 11); +lean_closure_set(x_72, 0, x_68); +lean_closure_set(x_72, 1, x_66); +lean_closure_set(x_72, 2, x_4); +lean_closure_set(x_72, 3, x_62); +lean_closure_set(x_72, 4, x_65); +lean_closure_set(x_72, 5, x_53); +lean_closure_set(x_72, 6, x_55); +lean_closure_set(x_72, 7, x_71); +lean_closure_set(x_72, 8, x_69); +lean_closure_set(x_72, 9, x_46); +lean_closure_set(x_72, 10, x_14); +x_73 = lean_alloc_closure((void*)(l_ReaderT_bind___at_Lean_Meta_isClassExpensive___main___spec__4___rarg), 4, 2); +lean_closure_set(x_73, 0, x_70); +lean_closure_set(x_73, 1, x_72); +x_108 = lean_ctor_get(x_60, 4); +lean_inc(x_108); +x_109 = lean_ctor_get_uint8(x_108, sizeof(void*)*1); +lean_dec(x_108); +if (x_109 == 0) { -lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; -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_ctor_get(x_74, 1); -lean_inc(x_76); -x_77 = lean_ctor_get(x_74, 4); +x_74 = x_56; +x_75 = x_60; +goto block_107; +} +else +{ +lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; uint8_t x_114; +x_110 = l_Lean_Meta_substCore___lambda__3___closed__17; +x_111 = l___private_Lean_Util_Trace_5__checkTraceOptionM___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_110, x_5, x_60); +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_unbox(x_112); +lean_dec(x_112); +x_74 = x_114; +x_75 = x_113; +goto block_107; +} +block_107: +{ +if (x_74 == 0) +{ +lean_object* x_76; +lean_dec(x_53); +x_76 = l_Lean_Meta_getMVarDecl(x_62, x_5, x_75); +if (lean_obj_tag(x_76) == 0) +{ +lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; +x_77 = lean_ctor_get(x_76, 0); lean_inc(x_77); -lean_dec(x_74); -x_78 = l_Lean_Meta_withLocalContext___rarg(x_76, x_77, x_72, x_5, x_75); -lean_dec(x_5); -return x_78; -} -else -{ -uint8_t x_79; -lean_dec(x_72); -lean_dec(x_5); -x_79 = !lean_is_exclusive(x_73); -if (x_79 == 0) -{ -return x_73; -} -else -{ -lean_object* x_80; lean_object* x_81; lean_object* x_82; -x_80 = lean_ctor_get(x_73, 0); -x_81 = lean_ctor_get(x_73, 1); -lean_inc(x_81); +x_78 = lean_ctor_get(x_76, 1); +lean_inc(x_78); +lean_dec(x_76); +x_79 = lean_ctor_get(x_77, 1); +lean_inc(x_79); +x_80 = lean_ctor_get(x_77, 4); lean_inc(x_80); +lean_dec(x_77); +x_81 = l_Lean_Meta_withLocalContext___rarg(x_79, x_80, x_73, x_5, x_78); +lean_dec(x_5); +return x_81; +} +else +{ +uint8_t x_82; lean_dec(x_73); -x_82 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_82, 0, x_80); -lean_ctor_set(x_82, 1, x_81); -return x_82; -} -} -} -else -{ -uint8_t x_83; -lean_dec(x_52); lean_dec(x_5); -lean_dec(x_4); -x_83 = !lean_is_exclusive(x_57); -if (x_83 == 0) +x_82 = !lean_is_exclusive(x_76); +if (x_82 == 0) { -return x_57; +return x_76; } else { -lean_object* x_84; lean_object* x_85; lean_object* x_86; -x_84 = lean_ctor_get(x_57, 0); -x_85 = lean_ctor_get(x_57, 1); -lean_inc(x_85); +lean_object* x_83; lean_object* x_84; lean_object* x_85; +x_83 = lean_ctor_get(x_76, 0); +x_84 = lean_ctor_get(x_76, 1); lean_inc(x_84); -lean_dec(x_57); -x_86 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_86, 0, x_84); -lean_ctor_set(x_86, 1, x_85); -return x_86; +lean_inc(x_83); +lean_dec(x_76); +x_85 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_85, 0, x_83); +lean_ctor_set(x_85, 1, x_84); +return x_85; } } } else { -uint8_t x_87; +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; +x_86 = l_Array_toList___rarg(x_53); +lean_dec(x_53); +x_87 = l_List_toString___at_Lean_Meta_substCore___spec__4(x_86); +x_88 = l_Array_HasRepr___rarg___closed__1; +x_89 = lean_string_append(x_88, x_87); +lean_dec(x_87); +x_90 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_90, 0, x_89); +x_91 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_91, 0, x_90); +x_92 = l_Lean_Meta_substCore___lambda__3___closed__20; +x_93 = lean_alloc_ctor(9, 2, 0); +lean_ctor_set(x_93, 0, x_92); +lean_ctor_set(x_93, 1, x_91); +x_94 = l_Lean_Meta_substCore___lambda__3___closed__17; +x_95 = l_Lean_MonadTracerAdapter_addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_94, x_93, x_5, x_75); +x_96 = lean_ctor_get(x_95, 1); +lean_inc(x_96); +lean_dec(x_95); +x_97 = l_Lean_Meta_getMVarDecl(x_62, x_5, x_96); +if (lean_obj_tag(x_97) == 0) +{ +lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; +x_98 = lean_ctor_get(x_97, 0); +lean_inc(x_98); +x_99 = lean_ctor_get(x_97, 1); +lean_inc(x_99); +lean_dec(x_97); +x_100 = lean_ctor_get(x_98, 1); +lean_inc(x_100); +x_101 = lean_ctor_get(x_98, 4); +lean_inc(x_101); +lean_dec(x_98); +x_102 = l_Lean_Meta_withLocalContext___rarg(x_100, x_101, x_73, x_5, x_99); +lean_dec(x_5); +return x_102; +} +else +{ +uint8_t x_103; +lean_dec(x_73); +lean_dec(x_5); +x_103 = !lean_is_exclusive(x_97); +if (x_103 == 0) +{ +return x_97; +} +else +{ +lean_object* x_104; lean_object* x_105; lean_object* x_106; +x_104 = lean_ctor_get(x_97, 0); +x_105 = lean_ctor_get(x_97, 1); +lean_inc(x_105); +lean_inc(x_104); +lean_dec(x_97); +x_106 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_106, 0, x_104); +lean_ctor_set(x_106, 1, x_105); +return x_106; +} +} +} +} +} +else +{ +uint8_t x_115; +lean_dec(x_53); lean_dec(x_5); lean_dec(x_4); -x_87 = !lean_is_exclusive(x_49); -if (x_87 == 0) +x_115 = !lean_is_exclusive(x_58); +if (x_115 == 0) { -return x_49; +return x_58; } else { -lean_object* x_88; lean_object* x_89; lean_object* x_90; -x_88 = lean_ctor_get(x_49, 0); -x_89 = lean_ctor_get(x_49, 1); -lean_inc(x_89); -lean_inc(x_88); -lean_dec(x_49); -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_116; lean_object* x_117; lean_object* x_118; +x_116 = lean_ctor_get(x_58, 0); +x_117 = lean_ctor_get(x_58, 1); +lean_inc(x_117); +lean_inc(x_116); +lean_dec(x_58); +x_118 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_118, 0, x_116); +lean_ctor_set(x_118, 1, x_117); +return x_118; } } } else { -uint8_t x_91; +uint8_t x_119; +lean_dec(x_5); +lean_dec(x_4); +x_119 = !lean_is_exclusive(x_50); +if (x_119 == 0) +{ +return x_50; +} +else +{ +lean_object* x_120; lean_object* x_121; lean_object* x_122; +x_120 = lean_ctor_get(x_50, 0); +x_121 = lean_ctor_get(x_50, 1); +lean_inc(x_121); +lean_inc(x_120); +lean_dec(x_50); +x_122 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_122, 0, x_120); +lean_ctor_set(x_122, 1, x_121); +return x_122; +} +} +} +else +{ +uint8_t x_123; lean_dec(x_38); lean_dec(x_5); lean_dec(x_4); lean_dec(x_2); lean_dec(x_1); -x_91 = !lean_is_exclusive(x_43); -if (x_91 == 0) +x_123 = !lean_is_exclusive(x_44); +if (x_123 == 0) { -return x_43; +return x_44; } else { -lean_object* x_92; lean_object* x_93; lean_object* x_94; -x_92 = lean_ctor_get(x_43, 0); -x_93 = lean_ctor_get(x_43, 1); -lean_inc(x_93); -lean_inc(x_92); -lean_dec(x_43); -x_94 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_94, 0, x_92); -lean_ctor_set(x_94, 1, x_93); -return x_94; +lean_object* x_124; lean_object* x_125; lean_object* x_126; +x_124 = lean_ctor_get(x_44, 0); +x_125 = lean_ctor_get(x_44, 1); +lean_inc(x_125); +lean_inc(x_124); +lean_dec(x_44); +x_126 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_126, 0, x_124); +lean_ctor_set(x_126, 1, x_125); +return x_126; +} } } } } else { -lean_object* x_109; +lean_object* x_163; lean_dec(x_26); lean_dec(x_24); lean_dec(x_4); lean_dec(x_2); -x_109 = lean_box(0); -x_28 = x_109; +x_163 = lean_box(0); +x_28 = x_163; goto block_37; } block_37: @@ -2156,30 +2566,30 @@ return x_36; } else { -uint8_t x_110; +uint8_t x_164; lean_dec(x_24); lean_dec(x_13); lean_dec(x_5); lean_dec(x_4); lean_dec(x_2); lean_dec(x_1); -x_110 = !lean_is_exclusive(x_25); -if (x_110 == 0) +x_164 = !lean_is_exclusive(x_25); +if (x_164 == 0) { return x_25; } else { -lean_object* x_111; lean_object* x_112; lean_object* x_113; -x_111 = lean_ctor_get(x_25, 0); -x_112 = lean_ctor_get(x_25, 1); -lean_inc(x_112); -lean_inc(x_111); +lean_object* x_165; lean_object* x_166; lean_object* x_167; +x_165 = lean_ctor_get(x_25, 0); +x_166 = lean_ctor_get(x_25, 1); +lean_inc(x_166); +lean_inc(x_165); lean_dec(x_25); -x_113 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_113, 0, x_111); -lean_ctor_set(x_113, 1, x_112); -return x_113; +x_167 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_167, 0, x_165); +lean_ctor_set(x_167, 1, x_166); +return x_167; } } } @@ -2189,55 +2599,55 @@ return x_113; } else { -uint8_t x_119; +uint8_t x_173; lean_dec(x_5); lean_dec(x_4); lean_dec(x_2); lean_dec(x_1); -x_119 = !lean_is_exclusive(x_10); -if (x_119 == 0) +x_173 = !lean_is_exclusive(x_10); +if (x_173 == 0) { return x_10; } else { -lean_object* x_120; lean_object* x_121; lean_object* x_122; -x_120 = lean_ctor_get(x_10, 0); -x_121 = lean_ctor_get(x_10, 1); -lean_inc(x_121); -lean_inc(x_120); +lean_object* x_174; lean_object* x_175; lean_object* x_176; +x_174 = lean_ctor_get(x_10, 0); +x_175 = lean_ctor_get(x_10, 1); +lean_inc(x_175); +lean_inc(x_174); lean_dec(x_10); -x_122 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_122, 0, x_120); -lean_ctor_set(x_122, 1, x_121); -return x_122; +x_176 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_176, 0, x_174); +lean_ctor_set(x_176, 1, x_175); +return x_176; } } } else { -uint8_t x_123; +uint8_t x_177; lean_dec(x_5); lean_dec(x_4); lean_dec(x_2); lean_dec(x_1); -x_123 = !lean_is_exclusive(x_8); -if (x_123 == 0) +x_177 = !lean_is_exclusive(x_8); +if (x_177 == 0) { return x_8; } else { -lean_object* x_124; lean_object* x_125; lean_object* x_126; -x_124 = lean_ctor_get(x_8, 0); -x_125 = lean_ctor_get(x_8, 1); -lean_inc(x_125); -lean_inc(x_124); +lean_object* x_178; lean_object* x_179; lean_object* x_180; +x_178 = lean_ctor_get(x_8, 0); +x_179 = lean_ctor_get(x_8, 1); +lean_inc(x_179); +lean_inc(x_178); lean_dec(x_8); -x_126 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_126, 0, x_124); -lean_ctor_set(x_126, 1, x_125); -return x_126; +x_180 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_180, 0, x_178); +lean_ctor_set(x_180, 1, x_179); +return x_180; } } } @@ -2336,6 +2746,16 @@ lean_dec(x_1); return x_8; } } +lean_object* l_List_toStringAux___main___at_Lean_Meta_substCore___spec__5___boxed(lean_object* x_1, lean_object* x_2) { +_start: +{ +uint8_t x_3; lean_object* x_4; +x_3 = lean_unbox(x_1); +lean_dec(x_1); +x_4 = l_List_toStringAux___main___at_Lean_Meta_substCore___spec__5(x_3, x_2); +return x_4; +} +} lean_object* l_Lean_Meta_substCore___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) { _start: { @@ -3419,21 +3839,11 @@ lean_dec(x_3); return x_5; } } -lean_object* _init_l___private_Lean_Meta_Tactic_Subst_1__regTraceClasses___closed__1() { -_start: -{ -lean_object* x_1; lean_object* x_2; lean_object* x_3; -x_1 = l___private_Lean_Meta_Tactic_Util_1__regTraceClasses___closed__2; -x_2 = l_Lean_Meta_substCore___lambda__3___closed__1; -x_3 = lean_name_mk_string(x_1, x_2); -return x_3; -} -} lean_object* l___private_Lean_Meta_Tactic_Subst_1__regTraceClasses(lean_object* x_1) { _start: { lean_object* x_2; lean_object* x_3; -x_2 = l___private_Lean_Meta_Tactic_Subst_1__regTraceClasses___closed__1; +x_2 = l_Lean_Meta_substCore___lambda__3___closed__17; x_3 = l_Lean_registerTraceClass(x_2, x_1); return x_3; } @@ -3517,6 +3927,32 @@ l_Lean_Meta_substCore___lambda__3___closed__18 = _init_l_Lean_Meta_substCore___l lean_mark_persistent(l_Lean_Meta_substCore___lambda__3___closed__18); l_Lean_Meta_substCore___lambda__3___closed__19 = _init_l_Lean_Meta_substCore___lambda__3___closed__19(); lean_mark_persistent(l_Lean_Meta_substCore___lambda__3___closed__19); +l_Lean_Meta_substCore___lambda__3___closed__20 = _init_l_Lean_Meta_substCore___lambda__3___closed__20(); +lean_mark_persistent(l_Lean_Meta_substCore___lambda__3___closed__20); +l_Lean_Meta_substCore___lambda__3___closed__21 = _init_l_Lean_Meta_substCore___lambda__3___closed__21(); +lean_mark_persistent(l_Lean_Meta_substCore___lambda__3___closed__21); +l_Lean_Meta_substCore___lambda__3___closed__22 = _init_l_Lean_Meta_substCore___lambda__3___closed__22(); +lean_mark_persistent(l_Lean_Meta_substCore___lambda__3___closed__22); +l_Lean_Meta_substCore___lambda__3___closed__23 = _init_l_Lean_Meta_substCore___lambda__3___closed__23(); +lean_mark_persistent(l_Lean_Meta_substCore___lambda__3___closed__23); +l_Lean_Meta_substCore___lambda__3___closed__24 = _init_l_Lean_Meta_substCore___lambda__3___closed__24(); +lean_mark_persistent(l_Lean_Meta_substCore___lambda__3___closed__24); +l_Lean_Meta_substCore___lambda__3___closed__25 = _init_l_Lean_Meta_substCore___lambda__3___closed__25(); +lean_mark_persistent(l_Lean_Meta_substCore___lambda__3___closed__25); +l_Lean_Meta_substCore___lambda__3___closed__26 = _init_l_Lean_Meta_substCore___lambda__3___closed__26(); +lean_mark_persistent(l_Lean_Meta_substCore___lambda__3___closed__26); +l_Lean_Meta_substCore___lambda__3___closed__27 = _init_l_Lean_Meta_substCore___lambda__3___closed__27(); +lean_mark_persistent(l_Lean_Meta_substCore___lambda__3___closed__27); +l_Lean_Meta_substCore___lambda__3___closed__28 = _init_l_Lean_Meta_substCore___lambda__3___closed__28(); +lean_mark_persistent(l_Lean_Meta_substCore___lambda__3___closed__28); +l_Lean_Meta_substCore___lambda__3___closed__29 = _init_l_Lean_Meta_substCore___lambda__3___closed__29(); +lean_mark_persistent(l_Lean_Meta_substCore___lambda__3___closed__29); +l_Lean_Meta_substCore___lambda__3___closed__30 = _init_l_Lean_Meta_substCore___lambda__3___closed__30(); +lean_mark_persistent(l_Lean_Meta_substCore___lambda__3___closed__30); +l_Lean_Meta_substCore___lambda__3___closed__31 = _init_l_Lean_Meta_substCore___lambda__3___closed__31(); +lean_mark_persistent(l_Lean_Meta_substCore___lambda__3___closed__31); +l_Lean_Meta_substCore___lambda__3___closed__32 = _init_l_Lean_Meta_substCore___lambda__3___closed__32(); +lean_mark_persistent(l_Lean_Meta_substCore___lambda__3___closed__32); l_Lean_Meta_subst___lambda__1___closed__1 = _init_l_Lean_Meta_subst___lambda__1___closed__1(); lean_mark_persistent(l_Lean_Meta_subst___lambda__1___closed__1); l_Lean_Meta_subst___lambda__1___closed__2 = _init_l_Lean_Meta_subst___lambda__1___closed__2(); @@ -3529,8 +3965,6 @@ l_Lean_Meta_subst___lambda__1___closed__5 = _init_l_Lean_Meta_subst___lambda__1_ lean_mark_persistent(l_Lean_Meta_subst___lambda__1___closed__5); l_Lean_Meta_subst___lambda__1___closed__6 = _init_l_Lean_Meta_subst___lambda__1___closed__6(); lean_mark_persistent(l_Lean_Meta_subst___lambda__1___closed__6); -l___private_Lean_Meta_Tactic_Subst_1__regTraceClasses___closed__1 = _init_l___private_Lean_Meta_Tactic_Subst_1__regTraceClasses___closed__1(); -lean_mark_persistent(l___private_Lean_Meta_Tactic_Subst_1__regTraceClasses___closed__1); res = l___private_Lean_Meta_Tactic_Subst_1__regTraceClasses(lean_io_mk_world()); if (lean_io_result_is_error(res)) return res; lean_dec_ref(res); diff --git a/stage0/stdlib/Lean/Meta/WHNF.c b/stage0/stdlib/Lean/Meta/WHNF.c index 49f26536b2..159b996f8a 100644 --- a/stage0/stdlib/Lean/Meta/WHNF.c +++ b/stage0/stdlib/Lean/Meta/WHNF.c @@ -108,6 +108,7 @@ lean_object* l_Lean_Meta_setWHNFRef(lean_object*); lean_object* l___private_Lean_Util_WHNF_7__deltaDefinition___at_Lean_Meta_unfoldDefinition_x3f___spec__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Meta_WHNF_1__useWHNFCache___boxed(lean_object*, lean_object*, lean_object*); lean_object* lean_nat_sub(lean_object*, lean_object*); +lean_object* l_Lean_Meta_throwOther___rarg(lean_object*, lean_object*, lean_object*); extern lean_object* l_Std_PersistentHashMap_insertAux___main___rarg___closed__3; lean_object* l_Array_shrink___main___rarg(lean_object*, lean_object*); lean_object* l_Lean_Meta_getConstNoEx___boxed(lean_object*, lean_object*, lean_object*); @@ -235,6 +236,7 @@ lean_object* l_Lean_Meta_whnfCore(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_reduceNat_x3f___closed__1; lean_object* l_Lean_WHNF_reduceQuotRec___at_Lean_Meta_unfoldDefinition_x3f___spec__7___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_mkNatLit(lean_object*); +extern lean_object* l_Lean_Meta_isClassQuick___main___closed__1; lean_object* l_Lean_Meta_reduceBinNatOp___closed__2; lean_object* l___private_Lean_Meta_WHNF_4__whnfHeadPredAux___main___closed__1; lean_object* l_Lean_Meta_reduceNativeConst___rarg(lean_object*, lean_object*, lean_object*, lean_object*); @@ -11072,7 +11074,7 @@ lean_inc(x_5); x_6 = l_Lean_Environment_evalConstCheck___rarg(x_5, x_1, x_2); if (lean_obj_tag(x_6) == 0) { -lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; +lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; x_7 = lean_ctor_get(x_6, 0); lean_inc(x_7); lean_dec(x_6); @@ -11080,23 +11082,19 @@ x_8 = lean_alloc_ctor(2, 1, 0); lean_ctor_set(x_8, 0, x_7); x_9 = lean_alloc_ctor(0, 1, 0); lean_ctor_set(x_9, 0, x_8); -x_10 = lean_alloc_ctor(22, 1, 0); -lean_ctor_set(x_10, 0, x_9); -x_11 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_11, 0, x_10); -lean_ctor_set(x_11, 1, x_4); -return x_11; +x_10 = l_Lean_Meta_throwOther___rarg(x_9, x_3, x_4); +return x_10; } else { -lean_object* x_12; lean_object* x_13; -x_12 = lean_ctor_get(x_6, 0); -lean_inc(x_12); +lean_object* x_11; lean_object* x_12; +x_11 = lean_ctor_get(x_6, 0); +lean_inc(x_11); lean_dec(x_6); -x_13 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_13, 0, x_12); -lean_ctor_set(x_13, 1, x_4); -return x_13; +x_12 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_12, 0, x_11); +lean_ctor_set(x_12, 1, x_4); +return x_12; } } } @@ -16395,26 +16393,41 @@ uint8_t x_4; x_4 = l_Lean_Expr_hasFVar(x_1); if (x_4 == 0) { -lean_object* x_5; uint8_t x_6; uint8_t x_7; uint8_t x_8; lean_object* x_9; lean_object* x_10; +lean_object* x_5; uint8_t x_6; uint8_t x_7; uint8_t x_8; x_5 = lean_ctor_get(x_2, 0); x_6 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 6); -x_7 = 1; +x_7 = 2; x_8 = l_Lean_Meta_TransparencyMode_beq(x_6, x_7); -x_9 = lean_box(x_8); -x_10 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_10, 0, x_9); -lean_ctor_set(x_10, 1, x_3); -return x_10; +if (x_8 == 0) +{ +uint8_t x_9; lean_object* x_10; lean_object* x_11; +x_9 = 1; +x_10 = lean_box(x_9); +x_11 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_11, 0, x_10); +lean_ctor_set(x_11, 1, x_3); +return x_11; } else { -uint8_t x_11; lean_object* x_12; lean_object* x_13; -x_11 = 0; -x_12 = lean_box(x_11); -x_13 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_13, 0, x_12); -lean_ctor_set(x_13, 1, x_3); -return x_13; +uint8_t x_12; lean_object* x_13; lean_object* x_14; +x_12 = 0; +x_13 = lean_box(x_12); +x_14 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_14, 0, x_13); +lean_ctor_set(x_14, 1, x_3); +return x_14; +} +} +else +{ +uint8_t x_15; lean_object* x_16; lean_object* x_17; +x_15 = 0; +x_16 = lean_box(x_15); +x_17 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_17, 0, x_16); +lean_ctor_set(x_17, 1, x_3); +return x_17; } } } @@ -16566,6 +16579,7 @@ _start: if (x_1 == 0) { lean_object* x_5; lean_object* x_6; +lean_dec(x_3); x_5 = lean_box(0); x_6 = lean_alloc_ctor(0, 2, 0); lean_ctor_set(x_6, 0, x_5); @@ -16574,17 +16588,51 @@ return x_6; } else { -lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; -x_7 = lean_ctor_get(x_4, 2); +lean_object* x_7; uint8_t x_8; +x_7 = lean_ctor_get(x_3, 0); lean_inc(x_7); -x_8 = lean_ctor_get(x_7, 3); -lean_inc(x_8); +x_8 = lean_ctor_get_uint8(x_7, sizeof(void*)*1 + 6); lean_dec(x_7); -x_9 = l_Std_PersistentHashMap_find_x3f___at___private_Lean_Meta_WHNF_2__cached_x3f___spec__1(x_8, x_2); -x_10 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_10, 0, x_9); -lean_ctor_set(x_10, 1, x_4); -return x_10; +switch (x_8) { +case 0: +{ +lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; +lean_dec(x_3); +x_9 = lean_ctor_get(x_4, 2); +lean_inc(x_9); +x_10 = lean_ctor_get(x_9, 4); +lean_inc(x_10); +lean_dec(x_9); +x_11 = l_Std_PersistentHashMap_find_x3f___at___private_Lean_Meta_WHNF_2__cached_x3f___spec__1(x_10, x_2); +x_12 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_12, 0, x_11); +lean_ctor_set(x_12, 1, x_4); +return x_12; +} +case 1: +{ +lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; +lean_dec(x_3); +x_13 = lean_ctor_get(x_4, 2); +lean_inc(x_13); +x_14 = lean_ctor_get(x_13, 3); +lean_inc(x_14); +lean_dec(x_13); +x_15 = l_Std_PersistentHashMap_find_x3f___at___private_Lean_Meta_WHNF_2__cached_x3f___spec__1(x_14, x_2); +x_16 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_16, 0, x_15); +lean_ctor_set(x_16, 1, x_4); +return x_16; +} +default: +{ +lean_object* x_17; lean_object* x_18; lean_object* x_19; +x_17 = l_Lean_Meta_isClassQuick___main___closed__1; +x_18 = l_unreachable_x21___rarg(x_17); +x_19 = lean_apply_2(x_18, x_3, x_4); +return x_19; +} +} } } } @@ -16626,7 +16674,6 @@ uint8_t x_5; lean_object* x_6; x_5 = lean_unbox(x_1); lean_dec(x_1); x_6 = l___private_Lean_Meta_WHNF_2__cached_x3f(x_5, x_2, x_3, x_4); -lean_dec(x_3); lean_dec(x_2); return x_6; } @@ -17116,6 +17163,7 @@ _start: if (x_1 == 0) { lean_object* x_6; +lean_dec(x_4); lean_dec(x_2); x_6 = lean_alloc_ctor(0, 2, 0); lean_ctor_set(x_6, 0, x_3); @@ -17124,107 +17172,293 @@ return x_6; } else { -uint8_t x_7; -x_7 = !lean_is_exclusive(x_5); -if (x_7 == 0) +lean_object* x_7; uint8_t x_8; +x_7 = lean_ctor_get(x_4, 0); +lean_inc(x_7); +x_8 = lean_ctor_get_uint8(x_7, sizeof(void*)*1 + 6); +lean_dec(x_7); +switch (x_8) { +case 0: { -lean_object* x_8; uint8_t x_9; -x_8 = lean_ctor_get(x_5, 2); -x_9 = !lean_is_exclusive(x_8); +uint8_t x_9; +lean_dec(x_4); +x_9 = !lean_is_exclusive(x_5); if (x_9 == 0) { -lean_object* x_10; lean_object* x_11; lean_object* x_12; -x_10 = lean_ctor_get(x_8, 3); +lean_object* x_10; uint8_t x_11; +x_10 = lean_ctor_get(x_5, 2); +x_11 = !lean_is_exclusive(x_10); +if (x_11 == 0) +{ +lean_object* x_12; lean_object* x_13; lean_object* x_14; +x_12 = lean_ctor_get(x_10, 4); lean_inc(x_3); -x_11 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_WHNF_3__cache___spec__1(x_10, x_2, x_3); -lean_ctor_set(x_8, 3, x_11); -x_12 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_12, 0, x_3); -lean_ctor_set(x_12, 1, x_5); -return x_12; +x_13 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_WHNF_3__cache___spec__1(x_12, x_2, x_3); +lean_ctor_set(x_10, 4, x_13); +x_14 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_14, 0, x_3); +lean_ctor_set(x_14, 1, x_5); +return x_14; } else { -lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; -x_13 = lean_ctor_get(x_8, 0); -x_14 = lean_ctor_get(x_8, 1); -x_15 = lean_ctor_get(x_8, 2); -x_16 = lean_ctor_get(x_8, 3); +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_ctor_get(x_10, 0); +x_16 = lean_ctor_get(x_10, 1); +x_17 = lean_ctor_get(x_10, 2); +x_18 = lean_ctor_get(x_10, 3); +x_19 = lean_ctor_get(x_10, 4); +lean_inc(x_19); +lean_inc(x_18); +lean_inc(x_17); lean_inc(x_16); lean_inc(x_15); -lean_inc(x_14); -lean_inc(x_13); -lean_dec(x_8); +lean_dec(x_10); lean_inc(x_3); -x_17 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_WHNF_3__cache___spec__1(x_16, x_2, x_3); -x_18 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_18, 0, x_13); -lean_ctor_set(x_18, 1, x_14); -lean_ctor_set(x_18, 2, x_15); -lean_ctor_set(x_18, 3, x_17); -lean_ctor_set(x_5, 2, x_18); -x_19 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_19, 0, x_3); -lean_ctor_set(x_19, 1, x_5); -return x_19; +x_20 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_WHNF_3__cache___spec__1(x_19, x_2, x_3); +x_21 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_21, 0, x_15); +lean_ctor_set(x_21, 1, x_16); +lean_ctor_set(x_21, 2, x_17); +lean_ctor_set(x_21, 3, x_18); +lean_ctor_set(x_21, 4, x_20); +lean_ctor_set(x_5, 2, x_21); +x_22 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_22, 0, x_3); +lean_ctor_set(x_22, 1, x_5); +return x_22; } } else { -lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; -x_20 = lean_ctor_get(x_5, 2); -x_21 = lean_ctor_get(x_5, 0); -x_22 = lean_ctor_get(x_5, 1); -x_23 = lean_ctor_get(x_5, 3); -x_24 = lean_ctor_get(x_5, 4); -x_25 = lean_ctor_get(x_5, 5); +lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; +x_23 = lean_ctor_get(x_5, 2); +x_24 = lean_ctor_get(x_5, 0); +x_25 = lean_ctor_get(x_5, 1); +x_26 = lean_ctor_get(x_5, 3); +x_27 = lean_ctor_get(x_5, 4); +x_28 = lean_ctor_get(x_5, 5); +lean_inc(x_28); +lean_inc(x_27); +lean_inc(x_26); +lean_inc(x_23); lean_inc(x_25); lean_inc(x_24); -lean_inc(x_23); -lean_inc(x_20); -lean_inc(x_22); -lean_inc(x_21); lean_dec(x_5); -x_26 = lean_ctor_get(x_20, 0); -lean_inc(x_26); -x_27 = lean_ctor_get(x_20, 1); -lean_inc(x_27); -x_28 = lean_ctor_get(x_20, 2); -lean_inc(x_28); -x_29 = lean_ctor_get(x_20, 3); +x_29 = lean_ctor_get(x_23, 0); lean_inc(x_29); -if (lean_is_exclusive(x_20)) { - lean_ctor_release(x_20, 0); - lean_ctor_release(x_20, 1); - lean_ctor_release(x_20, 2); - lean_ctor_release(x_20, 3); - x_30 = x_20; +x_30 = lean_ctor_get(x_23, 1); +lean_inc(x_30); +x_31 = lean_ctor_get(x_23, 2); +lean_inc(x_31); +x_32 = lean_ctor_get(x_23, 3); +lean_inc(x_32); +x_33 = lean_ctor_get(x_23, 4); +lean_inc(x_33); +if (lean_is_exclusive(x_23)) { + lean_ctor_release(x_23, 0); + lean_ctor_release(x_23, 1); + lean_ctor_release(x_23, 2); + lean_ctor_release(x_23, 3); + lean_ctor_release(x_23, 4); + x_34 = x_23; } else { - lean_dec_ref(x_20); - x_30 = lean_box(0); + lean_dec_ref(x_23); + x_34 = lean_box(0); } lean_inc(x_3); -x_31 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_WHNF_3__cache___spec__1(x_29, x_2, x_3); -if (lean_is_scalar(x_30)) { - x_32 = lean_alloc_ctor(0, 4, 0); +x_35 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_WHNF_3__cache___spec__1(x_33, x_2, x_3); +if (lean_is_scalar(x_34)) { + x_36 = lean_alloc_ctor(0, 5, 0); } else { - x_32 = x_30; + x_36 = x_34; +} +lean_ctor_set(x_36, 0, x_29); +lean_ctor_set(x_36, 1, x_30); +lean_ctor_set(x_36, 2, x_31); +lean_ctor_set(x_36, 3, x_32); +lean_ctor_set(x_36, 4, x_35); +x_37 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_37, 0, x_24); +lean_ctor_set(x_37, 1, x_25); +lean_ctor_set(x_37, 2, x_36); +lean_ctor_set(x_37, 3, x_26); +lean_ctor_set(x_37, 4, x_27); +lean_ctor_set(x_37, 5, x_28); +x_38 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_38, 0, x_3); +lean_ctor_set(x_38, 1, x_37); +return x_38; +} +} +case 1: +{ +uint8_t x_39; +lean_dec(x_4); +x_39 = !lean_is_exclusive(x_5); +if (x_39 == 0) +{ +lean_object* x_40; uint8_t x_41; +x_40 = lean_ctor_get(x_5, 2); +x_41 = !lean_is_exclusive(x_40); +if (x_41 == 0) +{ +lean_object* x_42; lean_object* x_43; lean_object* x_44; +x_42 = lean_ctor_get(x_40, 3); +lean_inc(x_3); +x_43 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_WHNF_3__cache___spec__1(x_42, x_2, x_3); +lean_ctor_set(x_40, 3, x_43); +x_44 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_44, 0, x_3); +lean_ctor_set(x_44, 1, x_5); +return x_44; +} +else +{ +lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; +x_45 = lean_ctor_get(x_40, 0); +x_46 = lean_ctor_get(x_40, 1); +x_47 = lean_ctor_get(x_40, 2); +x_48 = lean_ctor_get(x_40, 3); +x_49 = lean_ctor_get(x_40, 4); +lean_inc(x_49); +lean_inc(x_48); +lean_inc(x_47); +lean_inc(x_46); +lean_inc(x_45); +lean_dec(x_40); +lean_inc(x_3); +x_50 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_WHNF_3__cache___spec__1(x_48, x_2, x_3); +x_51 = lean_alloc_ctor(0, 5, 0); +lean_ctor_set(x_51, 0, x_45); +lean_ctor_set(x_51, 1, x_46); +lean_ctor_set(x_51, 2, x_47); +lean_ctor_set(x_51, 3, x_50); +lean_ctor_set(x_51, 4, x_49); +lean_ctor_set(x_5, 2, x_51); +x_52 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_52, 0, x_3); +lean_ctor_set(x_52, 1, x_5); +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; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; +x_53 = lean_ctor_get(x_5, 2); +x_54 = lean_ctor_get(x_5, 0); +x_55 = lean_ctor_get(x_5, 1); +x_56 = lean_ctor_get(x_5, 3); +x_57 = lean_ctor_get(x_5, 4); +x_58 = lean_ctor_get(x_5, 5); +lean_inc(x_58); +lean_inc(x_57); +lean_inc(x_56); +lean_inc(x_53); +lean_inc(x_55); +lean_inc(x_54); +lean_dec(x_5); +x_59 = lean_ctor_get(x_53, 0); +lean_inc(x_59); +x_60 = lean_ctor_get(x_53, 1); +lean_inc(x_60); +x_61 = lean_ctor_get(x_53, 2); +lean_inc(x_61); +x_62 = lean_ctor_get(x_53, 3); +lean_inc(x_62); +x_63 = lean_ctor_get(x_53, 4); +lean_inc(x_63); +if (lean_is_exclusive(x_53)) { + lean_ctor_release(x_53, 0); + lean_ctor_release(x_53, 1); + lean_ctor_release(x_53, 2); + lean_ctor_release(x_53, 3); + lean_ctor_release(x_53, 4); + x_64 = x_53; +} else { + lean_dec_ref(x_53); + x_64 = lean_box(0); +} +lean_inc(x_3); +x_65 = l_Std_PersistentHashMap_insert___at___private_Lean_Meta_WHNF_3__cache___spec__1(x_62, x_2, x_3); +if (lean_is_scalar(x_64)) { + x_66 = lean_alloc_ctor(0, 5, 0); +} else { + x_66 = x_64; +} +lean_ctor_set(x_66, 0, x_59); +lean_ctor_set(x_66, 1, x_60); +lean_ctor_set(x_66, 2, x_61); +lean_ctor_set(x_66, 3, x_65); +lean_ctor_set(x_66, 4, x_63); +x_67 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_67, 0, x_54); +lean_ctor_set(x_67, 1, x_55); +lean_ctor_set(x_67, 2, x_66); +lean_ctor_set(x_67, 3, x_56); +lean_ctor_set(x_67, 4, x_57); +lean_ctor_set(x_67, 5, x_58); +x_68 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_68, 0, x_3); +lean_ctor_set(x_68, 1, x_67); +return x_68; +} +} +default: +{ +lean_object* x_69; lean_object* x_70; lean_object* x_71; +lean_dec(x_2); +x_69 = l_Lean_Meta_isClassQuick___main___closed__1; +x_70 = l_unreachable_x21___rarg(x_69); +x_71 = lean_apply_2(x_70, x_4, x_5); +if (lean_obj_tag(x_71) == 0) +{ +uint8_t x_72; +x_72 = !lean_is_exclusive(x_71); +if (x_72 == 0) +{ +lean_object* x_73; +x_73 = lean_ctor_get(x_71, 0); +lean_dec(x_73); +lean_ctor_set(x_71, 0, x_3); +return x_71; +} +else +{ +lean_object* x_74; lean_object* x_75; +x_74 = lean_ctor_get(x_71, 1); +lean_inc(x_74); +lean_dec(x_71); +x_75 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_75, 0, x_3); +lean_ctor_set(x_75, 1, x_74); +return x_75; +} +} +else +{ +uint8_t x_76; +lean_dec(x_3); +x_76 = !lean_is_exclusive(x_71); +if (x_76 == 0) +{ +return x_71; +} +else +{ +lean_object* x_77; lean_object* x_78; lean_object* x_79; +x_77 = lean_ctor_get(x_71, 0); +x_78 = lean_ctor_get(x_71, 1); +lean_inc(x_78); +lean_inc(x_77); +lean_dec(x_71); +x_79 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_79, 0, x_77); +lean_ctor_set(x_79, 1, x_78); +return x_79; +} +} } -lean_ctor_set(x_32, 0, x_26); -lean_ctor_set(x_32, 1, x_27); -lean_ctor_set(x_32, 2, x_28); -lean_ctor_set(x_32, 3, x_31); -x_33 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_33, 0, x_21); -lean_ctor_set(x_33, 1, x_22); -lean_ctor_set(x_33, 2, x_32); -lean_ctor_set(x_33, 3, x_23); -lean_ctor_set(x_33, 4, x_24); -lean_ctor_set(x_33, 5, x_25); -x_34 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_34, 0, x_3); -lean_ctor_set(x_34, 1, x_33); -return x_34; } } } @@ -17261,7 +17495,6 @@ uint8_t x_6; lean_object* x_7; x_6 = lean_unbox(x_1); lean_dec(x_1); x_7 = l___private_Lean_Meta_WHNF_3__cache(x_6, x_2, x_3, x_4, x_5); -lean_dec(x_4); return x_7; } } @@ -17412,30 +17645,43 @@ goto _start; } case 4: { -uint8_t x_31; lean_object* x_32; uint8_t x_81; -x_81 = l_Lean_Expr_hasFVar(x_1); -if (x_81 == 0) +uint8_t x_31; lean_object* x_32; uint8_t x_95; +x_95 = l_Lean_Expr_hasFVar(x_1); +if (x_95 == 0) { -lean_object* x_82; uint8_t x_83; uint8_t x_84; uint8_t x_85; -x_82 = lean_ctor_get(x_2, 0); -lean_inc(x_82); -x_83 = lean_ctor_get_uint8(x_82, sizeof(void*)*1 + 6); -lean_dec(x_82); -x_84 = 1; -x_85 = l_Lean_Meta_TransparencyMode_beq(x_83, x_84); -x_31 = x_85; +lean_object* x_96; uint8_t x_97; uint8_t x_98; uint8_t x_99; +x_96 = lean_ctor_get(x_2, 0); +lean_inc(x_96); +x_97 = lean_ctor_get_uint8(x_96, sizeof(void*)*1 + 6); +lean_dec(x_96); +x_98 = 2; +x_99 = l_Lean_Meta_TransparencyMode_beq(x_97, x_98); +if (x_99 == 0) +{ +uint8_t x_100; +x_100 = 1; +x_31 = x_100; x_32 = x_3; -goto block_80; +goto block_94; } else { -uint8_t x_86; -x_86 = 0; -x_31 = x_86; +uint8_t x_101; +x_101 = 0; +x_31 = x_101; x_32 = x_3; -goto block_80; +goto block_94; } -block_80: +} +else +{ +uint8_t x_102; +x_102 = 0; +x_31 = x_102; +x_32 = x_3; +goto block_94; +} +block_94: { lean_object* x_33; lean_object* x_34; if (x_31 == 0) @@ -17448,17 +17694,84 @@ goto block_75; } else { -lean_object* x_77; lean_object* x_78; lean_object* x_79; -x_77 = lean_ctor_get(x_32, 2); +lean_object* x_77; uint8_t x_78; +x_77 = lean_ctor_get(x_2, 0); lean_inc(x_77); -x_78 = lean_ctor_get(x_77, 3); -lean_inc(x_78); +x_78 = lean_ctor_get_uint8(x_77, sizeof(void*)*1 + 6); lean_dec(x_77); -x_79 = l_Std_PersistentHashMap_find_x3f___at___private_Lean_Meta_WHNF_2__cached_x3f___spec__1(x_78, x_1); -x_33 = x_79; +switch (x_78) { +case 0: +{ +lean_object* x_79; lean_object* x_80; lean_object* x_81; +x_79 = lean_ctor_get(x_32, 2); +lean_inc(x_79); +x_80 = lean_ctor_get(x_79, 4); +lean_inc(x_80); +lean_dec(x_79); +x_81 = l_Std_PersistentHashMap_find_x3f___at___private_Lean_Meta_WHNF_2__cached_x3f___spec__1(x_80, x_1); +x_33 = x_81; x_34 = x_32; goto block_75; } +case 1: +{ +lean_object* x_82; lean_object* x_83; lean_object* x_84; +x_82 = lean_ctor_get(x_32, 2); +lean_inc(x_82); +x_83 = lean_ctor_get(x_82, 3); +lean_inc(x_83); +lean_dec(x_82); +x_84 = l_Std_PersistentHashMap_find_x3f___at___private_Lean_Meta_WHNF_2__cached_x3f___spec__1(x_83, x_1); +x_33 = x_84; +x_34 = x_32; +goto block_75; +} +default: +{ +lean_object* x_85; lean_object* x_86; lean_object* x_87; +x_85 = l_Lean_Meta_isClassQuick___main___closed__1; +x_86 = l_unreachable_x21___rarg(x_85); +lean_inc(x_2); +x_87 = lean_apply_2(x_86, x_2, x_32); +if (lean_obj_tag(x_87) == 0) +{ +lean_object* x_88; lean_object* x_89; +x_88 = lean_ctor_get(x_87, 0); +lean_inc(x_88); +x_89 = lean_ctor_get(x_87, 1); +lean_inc(x_89); +lean_dec(x_87); +x_33 = x_88; +x_34 = x_89; +goto block_75; +} +else +{ +uint8_t x_90; +lean_dec(x_2); +lean_dec(x_1); +x_90 = !lean_is_exclusive(x_87); +if (x_90 == 0) +{ +return x_87; +} +else +{ +lean_object* x_91; lean_object* x_92; lean_object* x_93; +x_91 = lean_ctor_get(x_87, 0); +x_92 = lean_ctor_get(x_87, 1); +lean_inc(x_92); +lean_inc(x_91); +lean_dec(x_87); +x_93 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_93, 0, x_91); +lean_ctor_set(x_93, 1, x_92); +return x_93; +} +} +} +} +} block_75: { if (lean_obj_tag(x_33) == 0) @@ -17517,7 +17830,6 @@ x_46 = lean_ctor_get(x_44, 1); lean_inc(x_46); lean_dec(x_44); x_47 = l___private_Lean_Meta_WHNF_3__cache(x_31, x_1, x_36, x_2, x_46); -lean_dec(x_2); return x_47; } else @@ -17573,7 +17885,6 @@ x_56 = lean_ctor_get(x_42, 0); lean_inc(x_56); lean_dec(x_42); x_57 = l___private_Lean_Meta_WHNF_3__cache(x_31, x_1, x_56, x_2, x_55); -lean_dec(x_2); return x_57; } } @@ -17614,7 +17925,6 @@ x_63 = lean_ctor_get(x_39, 0); lean_inc(x_63); lean_dec(x_39); x_64 = l___private_Lean_Meta_WHNF_3__cache(x_31, x_1, x_63, x_2, x_62); -lean_dec(x_2); return x_64; } } @@ -17687,855 +17997,1086 @@ return x_74; } case 5: { -uint8_t x_87; lean_object* x_88; uint8_t x_137; -x_137 = l_Lean_Expr_hasFVar(x_1); -if (x_137 == 0) +uint8_t x_103; lean_object* x_104; uint8_t x_167; +x_167 = l_Lean_Expr_hasFVar(x_1); +if (x_167 == 0) { -lean_object* x_138; uint8_t x_139; uint8_t x_140; uint8_t x_141; -x_138 = lean_ctor_get(x_2, 0); -lean_inc(x_138); -x_139 = lean_ctor_get_uint8(x_138, sizeof(void*)*1 + 6); -lean_dec(x_138); -x_140 = 1; -x_141 = l_Lean_Meta_TransparencyMode_beq(x_139, x_140); -x_87 = x_141; -x_88 = x_3; -goto block_136; +lean_object* x_168; uint8_t x_169; uint8_t x_170; uint8_t x_171; +x_168 = lean_ctor_get(x_2, 0); +lean_inc(x_168); +x_169 = lean_ctor_get_uint8(x_168, sizeof(void*)*1 + 6); +lean_dec(x_168); +x_170 = 2; +x_171 = l_Lean_Meta_TransparencyMode_beq(x_169, x_170); +if (x_171 == 0) +{ +uint8_t x_172; +x_172 = 1; +x_103 = x_172; +x_104 = x_3; +goto block_166; } else { -uint8_t x_142; -x_142 = 0; -x_87 = x_142; -x_88 = x_3; -goto block_136; +uint8_t x_173; +x_173 = 0; +x_103 = x_173; +x_104 = x_3; +goto block_166; } -block_136: -{ -lean_object* x_89; lean_object* x_90; -if (x_87 == 0) -{ -lean_object* x_132; -x_132 = lean_box(0); -x_89 = x_132; -x_90 = x_88; -goto block_131; } else { -lean_object* x_133; lean_object* x_134; lean_object* x_135; -x_133 = lean_ctor_get(x_88, 2); -lean_inc(x_133); -x_134 = lean_ctor_get(x_133, 3); -lean_inc(x_134); -lean_dec(x_133); -x_135 = l_Std_PersistentHashMap_find_x3f___at___private_Lean_Meta_WHNF_2__cached_x3f___spec__1(x_134, x_1); -x_89 = x_135; -x_90 = x_88; -goto block_131; +uint8_t x_174; +x_174 = 0; +x_103 = x_174; +x_104 = x_3; +goto block_166; } -block_131: +block_166: { -if (lean_obj_tag(x_89) == 0) +lean_object* x_105; lean_object* x_106; +if (x_103 == 0) { -lean_object* x_91; +lean_object* x_148; +x_148 = lean_box(0); +x_105 = x_148; +x_106 = x_104; +goto block_147; +} +else +{ +lean_object* x_149; uint8_t x_150; +x_149 = lean_ctor_get(x_2, 0); +lean_inc(x_149); +x_150 = lean_ctor_get_uint8(x_149, sizeof(void*)*1 + 6); +lean_dec(x_149); +switch (x_150) { +case 0: +{ +lean_object* x_151; lean_object* x_152; lean_object* x_153; +x_151 = lean_ctor_get(x_104, 2); +lean_inc(x_151); +x_152 = lean_ctor_get(x_151, 4); +lean_inc(x_152); +lean_dec(x_151); +x_153 = l_Std_PersistentHashMap_find_x3f___at___private_Lean_Meta_WHNF_2__cached_x3f___spec__1(x_152, x_1); +x_105 = x_153; +x_106 = x_104; +goto block_147; +} +case 1: +{ +lean_object* x_154; lean_object* x_155; lean_object* x_156; +x_154 = lean_ctor_get(x_104, 2); +lean_inc(x_154); +x_155 = lean_ctor_get(x_154, 3); +lean_inc(x_155); +lean_dec(x_154); +x_156 = l_Std_PersistentHashMap_find_x3f___at___private_Lean_Meta_WHNF_2__cached_x3f___spec__1(x_155, x_1); +x_105 = x_156; +x_106 = x_104; +goto block_147; +} +default: +{ +lean_object* x_157; lean_object* x_158; lean_object* x_159; +x_157 = l_Lean_Meta_isClassQuick___main___closed__1; +x_158 = l_unreachable_x21___rarg(x_157); +lean_inc(x_2); +x_159 = lean_apply_2(x_158, x_2, x_104); +if (lean_obj_tag(x_159) == 0) +{ +lean_object* x_160; lean_object* x_161; +x_160 = lean_ctor_get(x_159, 0); +lean_inc(x_160); +x_161 = lean_ctor_get(x_159, 1); +lean_inc(x_161); +lean_dec(x_159); +x_105 = x_160; +x_106 = x_161; +goto block_147; +} +else +{ +uint8_t x_162; +lean_dec(x_2); +lean_dec(x_1); +x_162 = !lean_is_exclusive(x_159); +if (x_162 == 0) +{ +return x_159; +} +else +{ +lean_object* x_163; lean_object* x_164; lean_object* x_165; +x_163 = lean_ctor_get(x_159, 0); +x_164 = lean_ctor_get(x_159, 1); +lean_inc(x_164); +lean_inc(x_163); +lean_dec(x_159); +x_165 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_165, 0, x_163); +lean_ctor_set(x_165, 1, x_164); +return x_165; +} +} +} +} +} +block_147: +{ +if (lean_obj_tag(x_105) == 0) +{ +lean_object* x_107; lean_inc(x_2); lean_inc(x_1); -x_91 = l_Lean_WHNF_whnfCore___main___at_Lean_Meta_whnfCore___spec__1(x_1, x_2, x_90); -if (lean_obj_tag(x_91) == 0) +x_107 = l_Lean_WHNF_whnfCore___main___at_Lean_Meta_whnfCore___spec__1(x_1, x_2, x_106); +if (lean_obj_tag(x_107) == 0) { -lean_object* x_92; lean_object* x_93; lean_object* x_94; -x_92 = lean_ctor_get(x_91, 0); -lean_inc(x_92); -x_93 = lean_ctor_get(x_91, 1); -lean_inc(x_93); -lean_dec(x_91); +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_2); -lean_inc(x_92); -x_94 = l_Lean_Meta_reduceNat_x3f(x_92, x_2, x_93); -if (lean_obj_tag(x_94) == 0) +lean_inc(x_108); +x_110 = l_Lean_Meta_reduceNat_x3f(x_108, x_2, x_109); +if (lean_obj_tag(x_110) == 0) { -lean_object* x_95; -x_95 = lean_ctor_get(x_94, 0); -lean_inc(x_95); -if (lean_obj_tag(x_95) == 0) +lean_object* x_111; +x_111 = lean_ctor_get(x_110, 0); +lean_inc(x_111); +if (lean_obj_tag(x_111) == 0) { -lean_object* x_96; lean_object* x_97; -x_96 = lean_ctor_get(x_94, 1); -lean_inc(x_96); -lean_dec(x_94); -lean_inc(x_92); -x_97 = l_Lean_Meta_reduceNative_x3f(x_92, x_2, x_96); -if (lean_obj_tag(x_97) == 0) +lean_object* x_112; lean_object* x_113; +x_112 = lean_ctor_get(x_110, 1); +lean_inc(x_112); +lean_dec(x_110); +lean_inc(x_108); +x_113 = l_Lean_Meta_reduceNative_x3f(x_108, x_2, x_112); +if (lean_obj_tag(x_113) == 0) { -lean_object* x_98; -x_98 = lean_ctor_get(x_97, 0); -lean_inc(x_98); -if (lean_obj_tag(x_98) == 0) +lean_object* x_114; +x_114 = lean_ctor_get(x_113, 0); +lean_inc(x_114); +if (lean_obj_tag(x_114) == 0) { -lean_object* x_99; lean_object* x_100; -x_99 = lean_ctor_get(x_97, 1); -lean_inc(x_99); -lean_dec(x_97); +lean_object* x_115; lean_object* x_116; +x_115 = lean_ctor_get(x_113, 1); +lean_inc(x_115); +lean_dec(x_113); lean_inc(x_2); -lean_inc(x_92); -x_100 = l_Lean_WHNF_unfoldDefinitionAux___at_Lean_Meta_unfoldDefinition_x3f___spec__1(x_92, x_2, x_99); -if (lean_obj_tag(x_100) == 0) +lean_inc(x_108); +x_116 = l_Lean_WHNF_unfoldDefinitionAux___at_Lean_Meta_unfoldDefinition_x3f___spec__1(x_108, x_2, x_115); +if (lean_obj_tag(x_116) == 0) { -lean_object* x_101; -x_101 = lean_ctor_get(x_100, 0); -lean_inc(x_101); -if (lean_obj_tag(x_101) == 0) +lean_object* x_117; +x_117 = lean_ctor_get(x_116, 0); +lean_inc(x_117); +if (lean_obj_tag(x_117) == 0) { -lean_object* x_102; lean_object* x_103; -x_102 = lean_ctor_get(x_100, 1); -lean_inc(x_102); -lean_dec(x_100); -x_103 = l___private_Lean_Meta_WHNF_3__cache(x_87, x_1, x_92, x_2, x_102); -lean_dec(x_2); -return x_103; +lean_object* x_118; lean_object* x_119; +x_118 = lean_ctor_get(x_116, 1); +lean_inc(x_118); +lean_dec(x_116); +x_119 = l___private_Lean_Meta_WHNF_3__cache(x_103, x_1, x_108, x_2, x_118); +return x_119; } else { -lean_object* x_104; lean_object* x_105; -lean_dec(x_92); +lean_object* x_120; lean_object* x_121; +lean_dec(x_108); lean_dec(x_1); -x_104 = lean_ctor_get(x_100, 1); -lean_inc(x_104); -lean_dec(x_100); -x_105 = lean_ctor_get(x_101, 0); -lean_inc(x_105); -lean_dec(x_101); -x_1 = x_105; -x_3 = x_104; +x_120 = lean_ctor_get(x_116, 1); +lean_inc(x_120); +lean_dec(x_116); +x_121 = lean_ctor_get(x_117, 0); +lean_inc(x_121); +lean_dec(x_117); +x_1 = x_121; +x_3 = x_120; goto _start; } } else { -uint8_t x_107; -lean_dec(x_92); +uint8_t x_123; +lean_dec(x_108); lean_dec(x_2); lean_dec(x_1); -x_107 = !lean_is_exclusive(x_100); -if (x_107 == 0) +x_123 = !lean_is_exclusive(x_116); +if (x_123 == 0) { -return x_100; +return x_116; } else { -lean_object* x_108; lean_object* x_109; lean_object* x_110; -x_108 = lean_ctor_get(x_100, 0); -x_109 = lean_ctor_get(x_100, 1); -lean_inc(x_109); -lean_inc(x_108); -lean_dec(x_100); -x_110 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_110, 0, x_108); -lean_ctor_set(x_110, 1, x_109); -return x_110; +lean_object* x_124; lean_object* x_125; lean_object* x_126; +x_124 = lean_ctor_get(x_116, 0); +x_125 = lean_ctor_get(x_116, 1); +lean_inc(x_125); +lean_inc(x_124); +lean_dec(x_116); +x_126 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_126, 0, x_124); +lean_ctor_set(x_126, 1, x_125); +return x_126; } } } else { -lean_object* x_111; lean_object* x_112; lean_object* x_113; -lean_dec(x_92); -x_111 = lean_ctor_get(x_97, 1); -lean_inc(x_111); -lean_dec(x_97); -x_112 = lean_ctor_get(x_98, 0); -lean_inc(x_112); -lean_dec(x_98); -x_113 = l___private_Lean_Meta_WHNF_3__cache(x_87, x_1, x_112, x_2, x_111); +lean_object* x_127; lean_object* x_128; lean_object* x_129; +lean_dec(x_108); +x_127 = lean_ctor_get(x_113, 1); +lean_inc(x_127); +lean_dec(x_113); +x_128 = lean_ctor_get(x_114, 0); +lean_inc(x_128); +lean_dec(x_114); +x_129 = l___private_Lean_Meta_WHNF_3__cache(x_103, x_1, x_128, x_2, x_127); +return x_129; +} +} +else +{ +uint8_t x_130; +lean_dec(x_108); lean_dec(x_2); +lean_dec(x_1); +x_130 = !lean_is_exclusive(x_113); +if (x_130 == 0) +{ return x_113; } +else +{ +lean_object* x_131; lean_object* x_132; lean_object* x_133; +x_131 = lean_ctor_get(x_113, 0); +x_132 = lean_ctor_get(x_113, 1); +lean_inc(x_132); +lean_inc(x_131); +lean_dec(x_113); +x_133 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_133, 0, x_131); +lean_ctor_set(x_133, 1, x_132); +return x_133; +} +} } else { -uint8_t x_114; -lean_dec(x_92); +lean_object* x_134; lean_object* x_135; lean_object* x_136; +lean_dec(x_108); +x_134 = lean_ctor_get(x_110, 1); +lean_inc(x_134); +lean_dec(x_110); +x_135 = lean_ctor_get(x_111, 0); +lean_inc(x_135); +lean_dec(x_111); +x_136 = l___private_Lean_Meta_WHNF_3__cache(x_103, x_1, x_135, x_2, x_134); +return x_136; +} +} +else +{ +uint8_t x_137; +lean_dec(x_108); lean_dec(x_2); lean_dec(x_1); -x_114 = !lean_is_exclusive(x_97); -if (x_114 == 0) +x_137 = !lean_is_exclusive(x_110); +if (x_137 == 0) { -return x_97; +return x_110; } else { -lean_object* x_115; lean_object* x_116; lean_object* x_117; -x_115 = lean_ctor_get(x_97, 0); -x_116 = lean_ctor_get(x_97, 1); -lean_inc(x_116); -lean_inc(x_115); -lean_dec(x_97); -x_117 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_117, 0, x_115); -lean_ctor_set(x_117, 1, x_116); -return x_117; +lean_object* x_138; lean_object* x_139; lean_object* x_140; +x_138 = lean_ctor_get(x_110, 0); +x_139 = lean_ctor_get(x_110, 1); +lean_inc(x_139); +lean_inc(x_138); +lean_dec(x_110); +x_140 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_140, 0, x_138); +lean_ctor_set(x_140, 1, x_139); +return x_140; } } } else { -lean_object* x_118; lean_object* x_119; lean_object* x_120; -lean_dec(x_92); -x_118 = lean_ctor_get(x_94, 1); -lean_inc(x_118); -lean_dec(x_94); -x_119 = lean_ctor_get(x_95, 0); -lean_inc(x_119); -lean_dec(x_95); -x_120 = l___private_Lean_Meta_WHNF_3__cache(x_87, x_1, x_119, x_2, x_118); -lean_dec(x_2); -return x_120; -} -} -else -{ -uint8_t x_121; -lean_dec(x_92); +uint8_t x_141; lean_dec(x_2); lean_dec(x_1); -x_121 = !lean_is_exclusive(x_94); -if (x_121 == 0) +x_141 = !lean_is_exclusive(x_107); +if (x_141 == 0) { -return x_94; +return x_107; } else { -lean_object* x_122; lean_object* x_123; lean_object* x_124; -x_122 = lean_ctor_get(x_94, 0); -x_123 = lean_ctor_get(x_94, 1); -lean_inc(x_123); -lean_inc(x_122); -lean_dec(x_94); -x_124 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_124, 0, x_122); -lean_ctor_set(x_124, 1, x_123); -return x_124; +lean_object* x_142; lean_object* x_143; lean_object* x_144; +x_142 = lean_ctor_get(x_107, 0); +x_143 = lean_ctor_get(x_107, 1); +lean_inc(x_143); +lean_inc(x_142); +lean_dec(x_107); +x_144 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_144, 0, x_142); +lean_ctor_set(x_144, 1, x_143); +return x_144; } } } else { -uint8_t x_125; +lean_object* x_145; lean_object* x_146; lean_dec(x_2); lean_dec(x_1); -x_125 = !lean_is_exclusive(x_91); -if (x_125 == 0) -{ -return x_91; -} -else -{ -lean_object* x_126; lean_object* x_127; lean_object* x_128; -x_126 = lean_ctor_get(x_91, 0); -x_127 = lean_ctor_get(x_91, 1); -lean_inc(x_127); -lean_inc(x_126); -lean_dec(x_91); -x_128 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_128, 0, x_126); -lean_ctor_set(x_128, 1, x_127); -return x_128; -} -} -} -else -{ -lean_object* x_129; lean_object* x_130; -lean_dec(x_2); -lean_dec(x_1); -x_129 = lean_ctor_get(x_89, 0); -lean_inc(x_129); -lean_dec(x_89); -x_130 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_130, 0, x_129); -lean_ctor_set(x_130, 1, x_90); -return x_130; +x_145 = lean_ctor_get(x_105, 0); +lean_inc(x_145); +lean_dec(x_105); +x_146 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_146, 0, x_145); +lean_ctor_set(x_146, 1, x_106); +return x_146; } } } } case 8: { -uint8_t x_143; lean_object* x_144; uint8_t x_193; -x_193 = l_Lean_Expr_hasFVar(x_1); -if (x_193 == 0) +uint8_t x_175; lean_object* x_176; uint8_t x_239; +x_239 = l_Lean_Expr_hasFVar(x_1); +if (x_239 == 0) { -lean_object* x_194; uint8_t x_195; uint8_t x_196; uint8_t x_197; -x_194 = lean_ctor_get(x_2, 0); -lean_inc(x_194); -x_195 = lean_ctor_get_uint8(x_194, sizeof(void*)*1 + 6); -lean_dec(x_194); -x_196 = 1; -x_197 = l_Lean_Meta_TransparencyMode_beq(x_195, x_196); -x_143 = x_197; -x_144 = x_3; -goto block_192; +lean_object* x_240; uint8_t x_241; uint8_t x_242; uint8_t x_243; +x_240 = lean_ctor_get(x_2, 0); +lean_inc(x_240); +x_241 = lean_ctor_get_uint8(x_240, sizeof(void*)*1 + 6); +lean_dec(x_240); +x_242 = 2; +x_243 = l_Lean_Meta_TransparencyMode_beq(x_241, x_242); +if (x_243 == 0) +{ +uint8_t x_244; +x_244 = 1; +x_175 = x_244; +x_176 = x_3; +goto block_238; } else { -uint8_t x_198; -x_198 = 0; -x_143 = x_198; -x_144 = x_3; -goto block_192; +uint8_t x_245; +x_245 = 0; +x_175 = x_245; +x_176 = x_3; +goto block_238; } -block_192: -{ -lean_object* x_145; lean_object* x_146; -if (x_143 == 0) -{ -lean_object* x_188; -x_188 = lean_box(0); -x_145 = x_188; -x_146 = x_144; -goto block_187; } else { -lean_object* x_189; lean_object* x_190; lean_object* x_191; -x_189 = lean_ctor_get(x_144, 2); -lean_inc(x_189); -x_190 = lean_ctor_get(x_189, 3); -lean_inc(x_190); -lean_dec(x_189); -x_191 = l_Std_PersistentHashMap_find_x3f___at___private_Lean_Meta_WHNF_2__cached_x3f___spec__1(x_190, x_1); -x_145 = x_191; -x_146 = x_144; -goto block_187; +uint8_t x_246; +x_246 = 0; +x_175 = x_246; +x_176 = x_3; +goto block_238; } -block_187: +block_238: { -if (lean_obj_tag(x_145) == 0) +lean_object* x_177; lean_object* x_178; +if (x_175 == 0) { -lean_object* x_147; +lean_object* x_220; +x_220 = lean_box(0); +x_177 = x_220; +x_178 = x_176; +goto block_219; +} +else +{ +lean_object* x_221; uint8_t x_222; +x_221 = lean_ctor_get(x_2, 0); +lean_inc(x_221); +x_222 = lean_ctor_get_uint8(x_221, sizeof(void*)*1 + 6); +lean_dec(x_221); +switch (x_222) { +case 0: +{ +lean_object* x_223; lean_object* x_224; lean_object* x_225; +x_223 = lean_ctor_get(x_176, 2); +lean_inc(x_223); +x_224 = lean_ctor_get(x_223, 4); +lean_inc(x_224); +lean_dec(x_223); +x_225 = l_Std_PersistentHashMap_find_x3f___at___private_Lean_Meta_WHNF_2__cached_x3f___spec__1(x_224, x_1); +x_177 = x_225; +x_178 = x_176; +goto block_219; +} +case 1: +{ +lean_object* x_226; lean_object* x_227; lean_object* x_228; +x_226 = lean_ctor_get(x_176, 2); +lean_inc(x_226); +x_227 = lean_ctor_get(x_226, 3); +lean_inc(x_227); +lean_dec(x_226); +x_228 = l_Std_PersistentHashMap_find_x3f___at___private_Lean_Meta_WHNF_2__cached_x3f___spec__1(x_227, x_1); +x_177 = x_228; +x_178 = x_176; +goto block_219; +} +default: +{ +lean_object* x_229; lean_object* x_230; lean_object* x_231; +x_229 = l_Lean_Meta_isClassQuick___main___closed__1; +x_230 = l_unreachable_x21___rarg(x_229); +lean_inc(x_2); +x_231 = lean_apply_2(x_230, x_2, x_176); +if (lean_obj_tag(x_231) == 0) +{ +lean_object* x_232; lean_object* x_233; +x_232 = lean_ctor_get(x_231, 0); +lean_inc(x_232); +x_233 = lean_ctor_get(x_231, 1); +lean_inc(x_233); +lean_dec(x_231); +x_177 = x_232; +x_178 = x_233; +goto block_219; +} +else +{ +uint8_t x_234; +lean_dec(x_2); +lean_dec(x_1); +x_234 = !lean_is_exclusive(x_231); +if (x_234 == 0) +{ +return x_231; +} +else +{ +lean_object* x_235; lean_object* x_236; lean_object* x_237; +x_235 = lean_ctor_get(x_231, 0); +x_236 = lean_ctor_get(x_231, 1); +lean_inc(x_236); +lean_inc(x_235); +lean_dec(x_231); +x_237 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_237, 0, x_235); +lean_ctor_set(x_237, 1, x_236); +return x_237; +} +} +} +} +} +block_219: +{ +if (lean_obj_tag(x_177) == 0) +{ +lean_object* x_179; lean_inc(x_2); lean_inc(x_1); -x_147 = l_Lean_WHNF_whnfCore___main___at_Lean_Meta_whnfCore___spec__1(x_1, x_2, x_146); -if (lean_obj_tag(x_147) == 0) +x_179 = l_Lean_WHNF_whnfCore___main___at_Lean_Meta_whnfCore___spec__1(x_1, x_2, x_178); +if (lean_obj_tag(x_179) == 0) { -lean_object* x_148; lean_object* x_149; lean_object* x_150; -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); +lean_object* x_180; lean_object* x_181; lean_object* x_182; +x_180 = lean_ctor_get(x_179, 0); +lean_inc(x_180); +x_181 = lean_ctor_get(x_179, 1); +lean_inc(x_181); +lean_dec(x_179); lean_inc(x_2); -lean_inc(x_148); -x_150 = l_Lean_Meta_reduceNat_x3f(x_148, x_2, x_149); -if (lean_obj_tag(x_150) == 0) +lean_inc(x_180); +x_182 = l_Lean_Meta_reduceNat_x3f(x_180, x_2, x_181); +if (lean_obj_tag(x_182) == 0) { -lean_object* x_151; -x_151 = lean_ctor_get(x_150, 0); -lean_inc(x_151); -if (lean_obj_tag(x_151) == 0) +lean_object* x_183; +x_183 = lean_ctor_get(x_182, 0); +lean_inc(x_183); +if (lean_obj_tag(x_183) == 0) { -lean_object* x_152; lean_object* x_153; -x_152 = lean_ctor_get(x_150, 1); -lean_inc(x_152); -lean_dec(x_150); -lean_inc(x_148); -x_153 = l_Lean_Meta_reduceNative_x3f(x_148, x_2, x_152); -if (lean_obj_tag(x_153) == 0) +lean_object* x_184; lean_object* x_185; +x_184 = lean_ctor_get(x_182, 1); +lean_inc(x_184); +lean_dec(x_182); +lean_inc(x_180); +x_185 = l_Lean_Meta_reduceNative_x3f(x_180, x_2, x_184); +if (lean_obj_tag(x_185) == 0) { -lean_object* x_154; -x_154 = lean_ctor_get(x_153, 0); -lean_inc(x_154); -if (lean_obj_tag(x_154) == 0) +lean_object* x_186; +x_186 = lean_ctor_get(x_185, 0); +lean_inc(x_186); +if (lean_obj_tag(x_186) == 0) { -lean_object* x_155; lean_object* x_156; -x_155 = lean_ctor_get(x_153, 1); -lean_inc(x_155); -lean_dec(x_153); +lean_object* x_187; lean_object* x_188; +x_187 = lean_ctor_get(x_185, 1); +lean_inc(x_187); +lean_dec(x_185); lean_inc(x_2); -lean_inc(x_148); -x_156 = l_Lean_WHNF_unfoldDefinitionAux___at_Lean_Meta_unfoldDefinition_x3f___spec__1(x_148, x_2, x_155); -if (lean_obj_tag(x_156) == 0) +lean_inc(x_180); +x_188 = l_Lean_WHNF_unfoldDefinitionAux___at_Lean_Meta_unfoldDefinition_x3f___spec__1(x_180, x_2, x_187); +if (lean_obj_tag(x_188) == 0) { -lean_object* x_157; -x_157 = lean_ctor_get(x_156, 0); -lean_inc(x_157); -if (lean_obj_tag(x_157) == 0) +lean_object* x_189; +x_189 = lean_ctor_get(x_188, 0); +lean_inc(x_189); +if (lean_obj_tag(x_189) == 0) { -lean_object* x_158; lean_object* x_159; -x_158 = lean_ctor_get(x_156, 1); -lean_inc(x_158); -lean_dec(x_156); -x_159 = l___private_Lean_Meta_WHNF_3__cache(x_143, x_1, x_148, x_2, x_158); -lean_dec(x_2); -return x_159; +lean_object* x_190; lean_object* x_191; +x_190 = lean_ctor_get(x_188, 1); +lean_inc(x_190); +lean_dec(x_188); +x_191 = l___private_Lean_Meta_WHNF_3__cache(x_175, x_1, x_180, x_2, x_190); +return x_191; } else { -lean_object* x_160; lean_object* x_161; -lean_dec(x_148); +lean_object* x_192; lean_object* x_193; +lean_dec(x_180); lean_dec(x_1); -x_160 = lean_ctor_get(x_156, 1); -lean_inc(x_160); -lean_dec(x_156); -x_161 = lean_ctor_get(x_157, 0); -lean_inc(x_161); -lean_dec(x_157); -x_1 = x_161; -x_3 = x_160; +x_192 = lean_ctor_get(x_188, 1); +lean_inc(x_192); +lean_dec(x_188); +x_193 = lean_ctor_get(x_189, 0); +lean_inc(x_193); +lean_dec(x_189); +x_1 = x_193; +x_3 = x_192; goto _start; } } else { -uint8_t x_163; -lean_dec(x_148); +uint8_t x_195; +lean_dec(x_180); lean_dec(x_2); lean_dec(x_1); -x_163 = !lean_is_exclusive(x_156); -if (x_163 == 0) +x_195 = !lean_is_exclusive(x_188); +if (x_195 == 0) { -return x_156; +return x_188; } else { -lean_object* x_164; lean_object* x_165; lean_object* x_166; -x_164 = lean_ctor_get(x_156, 0); -x_165 = lean_ctor_get(x_156, 1); -lean_inc(x_165); -lean_inc(x_164); -lean_dec(x_156); -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; +lean_object* x_196; lean_object* x_197; lean_object* x_198; +x_196 = lean_ctor_get(x_188, 0); +x_197 = lean_ctor_get(x_188, 1); +lean_inc(x_197); +lean_inc(x_196); +lean_dec(x_188); +x_198 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_198, 0, x_196); +lean_ctor_set(x_198, 1, x_197); +return x_198; } } } else { -lean_object* x_167; lean_object* x_168; lean_object* x_169; -lean_dec(x_148); -x_167 = lean_ctor_get(x_153, 1); -lean_inc(x_167); -lean_dec(x_153); -x_168 = lean_ctor_get(x_154, 0); -lean_inc(x_168); -lean_dec(x_154); -x_169 = l___private_Lean_Meta_WHNF_3__cache(x_143, x_1, x_168, x_2, x_167); -lean_dec(x_2); -return x_169; +lean_object* x_199; lean_object* x_200; lean_object* x_201; +lean_dec(x_180); +x_199 = lean_ctor_get(x_185, 1); +lean_inc(x_199); +lean_dec(x_185); +x_200 = lean_ctor_get(x_186, 0); +lean_inc(x_200); +lean_dec(x_186); +x_201 = l___private_Lean_Meta_WHNF_3__cache(x_175, x_1, x_200, x_2, x_199); +return x_201; } } else { -uint8_t x_170; -lean_dec(x_148); +uint8_t x_202; +lean_dec(x_180); lean_dec(x_2); lean_dec(x_1); -x_170 = !lean_is_exclusive(x_153); -if (x_170 == 0) +x_202 = !lean_is_exclusive(x_185); +if (x_202 == 0) { -return x_153; +return x_185; } else { -lean_object* x_171; lean_object* x_172; lean_object* x_173; -x_171 = lean_ctor_get(x_153, 0); -x_172 = lean_ctor_get(x_153, 1); -lean_inc(x_172); -lean_inc(x_171); -lean_dec(x_153); -x_173 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_173, 0, x_171); -lean_ctor_set(x_173, 1, x_172); -return x_173; +lean_object* x_203; lean_object* x_204; lean_object* x_205; +x_203 = lean_ctor_get(x_185, 0); +x_204 = lean_ctor_get(x_185, 1); +lean_inc(x_204); +lean_inc(x_203); +lean_dec(x_185); +x_205 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_205, 0, x_203); +lean_ctor_set(x_205, 1, x_204); +return x_205; } } } else { -lean_object* x_174; lean_object* x_175; lean_object* x_176; -lean_dec(x_148); -x_174 = lean_ctor_get(x_150, 1); -lean_inc(x_174); -lean_dec(x_150); -x_175 = lean_ctor_get(x_151, 0); -lean_inc(x_175); -lean_dec(x_151); -x_176 = l___private_Lean_Meta_WHNF_3__cache(x_143, x_1, x_175, x_2, x_174); -lean_dec(x_2); -return x_176; +lean_object* x_206; lean_object* x_207; lean_object* x_208; +lean_dec(x_180); +x_206 = lean_ctor_get(x_182, 1); +lean_inc(x_206); +lean_dec(x_182); +x_207 = lean_ctor_get(x_183, 0); +lean_inc(x_207); +lean_dec(x_183); +x_208 = l___private_Lean_Meta_WHNF_3__cache(x_175, x_1, x_207, x_2, x_206); +return x_208; } } else { -uint8_t x_177; -lean_dec(x_148); +uint8_t x_209; +lean_dec(x_180); lean_dec(x_2); lean_dec(x_1); -x_177 = !lean_is_exclusive(x_150); -if (x_177 == 0) +x_209 = !lean_is_exclusive(x_182); +if (x_209 == 0) { -return x_150; +return x_182; } else { -lean_object* x_178; lean_object* x_179; lean_object* x_180; -x_178 = lean_ctor_get(x_150, 0); -x_179 = lean_ctor_get(x_150, 1); -lean_inc(x_179); -lean_inc(x_178); -lean_dec(x_150); -x_180 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_180, 0, x_178); -lean_ctor_set(x_180, 1, x_179); -return x_180; +lean_object* x_210; lean_object* x_211; lean_object* x_212; +x_210 = lean_ctor_get(x_182, 0); +x_211 = lean_ctor_get(x_182, 1); +lean_inc(x_211); +lean_inc(x_210); +lean_dec(x_182); +x_212 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_212, 0, x_210); +lean_ctor_set(x_212, 1, x_211); +return x_212; } } } else { -uint8_t x_181; +uint8_t x_213; lean_dec(x_2); lean_dec(x_1); -x_181 = !lean_is_exclusive(x_147); -if (x_181 == 0) +x_213 = !lean_is_exclusive(x_179); +if (x_213 == 0) { -return x_147; +return x_179; } else { -lean_object* x_182; lean_object* x_183; lean_object* x_184; -x_182 = lean_ctor_get(x_147, 0); -x_183 = lean_ctor_get(x_147, 1); -lean_inc(x_183); -lean_inc(x_182); -lean_dec(x_147); -x_184 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_184, 0, x_182); -lean_ctor_set(x_184, 1, x_183); -return x_184; +lean_object* x_214; lean_object* x_215; lean_object* x_216; +x_214 = lean_ctor_get(x_179, 0); +x_215 = lean_ctor_get(x_179, 1); +lean_inc(x_215); +lean_inc(x_214); +lean_dec(x_179); +x_216 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_216, 0, x_214); +lean_ctor_set(x_216, 1, x_215); +return x_216; } } } else { -lean_object* x_185; lean_object* x_186; +lean_object* x_217; lean_object* x_218; lean_dec(x_2); lean_dec(x_1); -x_185 = lean_ctor_get(x_145, 0); -lean_inc(x_185); -lean_dec(x_145); -x_186 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_186, 0, x_185); -lean_ctor_set(x_186, 1, x_146); -return x_186; +x_217 = lean_ctor_get(x_177, 0); +lean_inc(x_217); +lean_dec(x_177); +x_218 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_218, 0, x_217); +lean_ctor_set(x_218, 1, x_178); +return x_218; } } } } case 10: { -lean_object* x_199; -x_199 = lean_ctor_get(x_1, 1); -lean_inc(x_199); +lean_object* x_247; +x_247 = lean_ctor_get(x_1, 1); +lean_inc(x_247); lean_dec(x_1); -x_1 = x_199; +x_1 = x_247; goto _start; } case 11: { -uint8_t x_201; lean_object* x_202; uint8_t x_251; -x_251 = l_Lean_Expr_hasFVar(x_1); -if (x_251 == 0) +uint8_t x_249; lean_object* x_250; uint8_t x_313; +x_313 = l_Lean_Expr_hasFVar(x_1); +if (x_313 == 0) { -lean_object* x_252; uint8_t x_253; uint8_t x_254; uint8_t x_255; -x_252 = lean_ctor_get(x_2, 0); -lean_inc(x_252); -x_253 = lean_ctor_get_uint8(x_252, sizeof(void*)*1 + 6); -lean_dec(x_252); -x_254 = 1; -x_255 = l_Lean_Meta_TransparencyMode_beq(x_253, x_254); -x_201 = x_255; -x_202 = x_3; -goto block_250; +lean_object* x_314; uint8_t x_315; uint8_t x_316; uint8_t x_317; +x_314 = lean_ctor_get(x_2, 0); +lean_inc(x_314); +x_315 = lean_ctor_get_uint8(x_314, sizeof(void*)*1 + 6); +lean_dec(x_314); +x_316 = 2; +x_317 = l_Lean_Meta_TransparencyMode_beq(x_315, x_316); +if (x_317 == 0) +{ +uint8_t x_318; +x_318 = 1; +x_249 = x_318; +x_250 = x_3; +goto block_312; } else { -uint8_t x_256; -x_256 = 0; -x_201 = x_256; -x_202 = x_3; -goto block_250; +uint8_t x_319; +x_319 = 0; +x_249 = x_319; +x_250 = x_3; +goto block_312; } -block_250: -{ -lean_object* x_203; lean_object* x_204; -if (x_201 == 0) -{ -lean_object* x_246; -x_246 = lean_box(0); -x_203 = x_246; -x_204 = x_202; -goto block_245; } else { -lean_object* x_247; lean_object* x_248; lean_object* x_249; -x_247 = lean_ctor_get(x_202, 2); -lean_inc(x_247); -x_248 = lean_ctor_get(x_247, 3); -lean_inc(x_248); -lean_dec(x_247); -x_249 = l_Std_PersistentHashMap_find_x3f___at___private_Lean_Meta_WHNF_2__cached_x3f___spec__1(x_248, x_1); -x_203 = x_249; -x_204 = x_202; -goto block_245; +uint8_t x_320; +x_320 = 0; +x_249 = x_320; +x_250 = x_3; +goto block_312; } -block_245: +block_312: { -if (lean_obj_tag(x_203) == 0) +lean_object* x_251; lean_object* x_252; +if (x_249 == 0) { -lean_object* x_205; +lean_object* x_294; +x_294 = lean_box(0); +x_251 = x_294; +x_252 = x_250; +goto block_293; +} +else +{ +lean_object* x_295; uint8_t x_296; +x_295 = lean_ctor_get(x_2, 0); +lean_inc(x_295); +x_296 = lean_ctor_get_uint8(x_295, sizeof(void*)*1 + 6); +lean_dec(x_295); +switch (x_296) { +case 0: +{ +lean_object* x_297; lean_object* x_298; lean_object* x_299; +x_297 = lean_ctor_get(x_250, 2); +lean_inc(x_297); +x_298 = lean_ctor_get(x_297, 4); +lean_inc(x_298); +lean_dec(x_297); +x_299 = l_Std_PersistentHashMap_find_x3f___at___private_Lean_Meta_WHNF_2__cached_x3f___spec__1(x_298, x_1); +x_251 = x_299; +x_252 = x_250; +goto block_293; +} +case 1: +{ +lean_object* x_300; lean_object* x_301; lean_object* x_302; +x_300 = lean_ctor_get(x_250, 2); +lean_inc(x_300); +x_301 = lean_ctor_get(x_300, 3); +lean_inc(x_301); +lean_dec(x_300); +x_302 = l_Std_PersistentHashMap_find_x3f___at___private_Lean_Meta_WHNF_2__cached_x3f___spec__1(x_301, x_1); +x_251 = x_302; +x_252 = x_250; +goto block_293; +} +default: +{ +lean_object* x_303; lean_object* x_304; lean_object* x_305; +x_303 = l_Lean_Meta_isClassQuick___main___closed__1; +x_304 = l_unreachable_x21___rarg(x_303); +lean_inc(x_2); +x_305 = lean_apply_2(x_304, x_2, x_250); +if (lean_obj_tag(x_305) == 0) +{ +lean_object* x_306; lean_object* x_307; +x_306 = lean_ctor_get(x_305, 0); +lean_inc(x_306); +x_307 = lean_ctor_get(x_305, 1); +lean_inc(x_307); +lean_dec(x_305); +x_251 = x_306; +x_252 = x_307; +goto block_293; +} +else +{ +uint8_t x_308; +lean_dec(x_2); +lean_dec(x_1); +x_308 = !lean_is_exclusive(x_305); +if (x_308 == 0) +{ +return x_305; +} +else +{ +lean_object* x_309; lean_object* x_310; lean_object* x_311; +x_309 = lean_ctor_get(x_305, 0); +x_310 = lean_ctor_get(x_305, 1); +lean_inc(x_310); +lean_inc(x_309); +lean_dec(x_305); +x_311 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_311, 0, x_309); +lean_ctor_set(x_311, 1, x_310); +return x_311; +} +} +} +} +} +block_293: +{ +if (lean_obj_tag(x_251) == 0) +{ +lean_object* x_253; lean_inc(x_2); lean_inc(x_1); -x_205 = l_Lean_WHNF_whnfCore___main___at_Lean_Meta_whnfCore___spec__1(x_1, x_2, x_204); -if (lean_obj_tag(x_205) == 0) +x_253 = l_Lean_WHNF_whnfCore___main___at_Lean_Meta_whnfCore___spec__1(x_1, x_2, x_252); +if (lean_obj_tag(x_253) == 0) { -lean_object* x_206; lean_object* x_207; lean_object* x_208; -x_206 = lean_ctor_get(x_205, 0); -lean_inc(x_206); -x_207 = lean_ctor_get(x_205, 1); -lean_inc(x_207); -lean_dec(x_205); +lean_object* x_254; lean_object* x_255; lean_object* x_256; +x_254 = lean_ctor_get(x_253, 0); +lean_inc(x_254); +x_255 = lean_ctor_get(x_253, 1); +lean_inc(x_255); +lean_dec(x_253); lean_inc(x_2); -lean_inc(x_206); -x_208 = l_Lean_Meta_reduceNat_x3f(x_206, x_2, x_207); -if (lean_obj_tag(x_208) == 0) +lean_inc(x_254); +x_256 = l_Lean_Meta_reduceNat_x3f(x_254, x_2, x_255); +if (lean_obj_tag(x_256) == 0) { -lean_object* x_209; -x_209 = lean_ctor_get(x_208, 0); -lean_inc(x_209); -if (lean_obj_tag(x_209) == 0) +lean_object* x_257; +x_257 = lean_ctor_get(x_256, 0); +lean_inc(x_257); +if (lean_obj_tag(x_257) == 0) { -lean_object* x_210; lean_object* x_211; -x_210 = lean_ctor_get(x_208, 1); -lean_inc(x_210); -lean_dec(x_208); -lean_inc(x_206); -x_211 = l_Lean_Meta_reduceNative_x3f(x_206, x_2, x_210); -if (lean_obj_tag(x_211) == 0) +lean_object* x_258; lean_object* x_259; +x_258 = lean_ctor_get(x_256, 1); +lean_inc(x_258); +lean_dec(x_256); +lean_inc(x_254); +x_259 = l_Lean_Meta_reduceNative_x3f(x_254, x_2, x_258); +if (lean_obj_tag(x_259) == 0) { -lean_object* x_212; -x_212 = lean_ctor_get(x_211, 0); -lean_inc(x_212); -if (lean_obj_tag(x_212) == 0) +lean_object* x_260; +x_260 = lean_ctor_get(x_259, 0); +lean_inc(x_260); +if (lean_obj_tag(x_260) == 0) { -lean_object* x_213; lean_object* x_214; -x_213 = lean_ctor_get(x_211, 1); -lean_inc(x_213); -lean_dec(x_211); +lean_object* x_261; lean_object* x_262; +x_261 = lean_ctor_get(x_259, 1); +lean_inc(x_261); +lean_dec(x_259); lean_inc(x_2); -lean_inc(x_206); -x_214 = l_Lean_WHNF_unfoldDefinitionAux___at_Lean_Meta_unfoldDefinition_x3f___spec__1(x_206, x_2, x_213); -if (lean_obj_tag(x_214) == 0) +lean_inc(x_254); +x_262 = l_Lean_WHNF_unfoldDefinitionAux___at_Lean_Meta_unfoldDefinition_x3f___spec__1(x_254, x_2, x_261); +if (lean_obj_tag(x_262) == 0) { -lean_object* x_215; -x_215 = lean_ctor_get(x_214, 0); -lean_inc(x_215); -if (lean_obj_tag(x_215) == 0) +lean_object* x_263; +x_263 = lean_ctor_get(x_262, 0); +lean_inc(x_263); +if (lean_obj_tag(x_263) == 0) { -lean_object* x_216; lean_object* x_217; -x_216 = lean_ctor_get(x_214, 1); -lean_inc(x_216); -lean_dec(x_214); -x_217 = l___private_Lean_Meta_WHNF_3__cache(x_201, x_1, x_206, x_2, x_216); -lean_dec(x_2); -return x_217; +lean_object* x_264; lean_object* x_265; +x_264 = lean_ctor_get(x_262, 1); +lean_inc(x_264); +lean_dec(x_262); +x_265 = l___private_Lean_Meta_WHNF_3__cache(x_249, x_1, x_254, x_2, x_264); +return x_265; } else { -lean_object* x_218; lean_object* x_219; -lean_dec(x_206); +lean_object* x_266; lean_object* x_267; +lean_dec(x_254); lean_dec(x_1); -x_218 = lean_ctor_get(x_214, 1); -lean_inc(x_218); -lean_dec(x_214); -x_219 = lean_ctor_get(x_215, 0); -lean_inc(x_219); -lean_dec(x_215); -x_1 = x_219; -x_3 = x_218; +x_266 = lean_ctor_get(x_262, 1); +lean_inc(x_266); +lean_dec(x_262); +x_267 = lean_ctor_get(x_263, 0); +lean_inc(x_267); +lean_dec(x_263); +x_1 = x_267; +x_3 = x_266; goto _start; } } else { -uint8_t x_221; -lean_dec(x_206); +uint8_t x_269; +lean_dec(x_254); lean_dec(x_2); lean_dec(x_1); -x_221 = !lean_is_exclusive(x_214); -if (x_221 == 0) +x_269 = !lean_is_exclusive(x_262); +if (x_269 == 0) { -return x_214; +return x_262; } else { -lean_object* x_222; lean_object* x_223; lean_object* x_224; -x_222 = lean_ctor_get(x_214, 0); -x_223 = lean_ctor_get(x_214, 1); -lean_inc(x_223); -lean_inc(x_222); -lean_dec(x_214); -x_224 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_224, 0, x_222); -lean_ctor_set(x_224, 1, x_223); -return x_224; +lean_object* x_270; lean_object* x_271; lean_object* x_272; +x_270 = lean_ctor_get(x_262, 0); +x_271 = lean_ctor_get(x_262, 1); +lean_inc(x_271); +lean_inc(x_270); +lean_dec(x_262); +x_272 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_272, 0, x_270); +lean_ctor_set(x_272, 1, x_271); +return x_272; } } } else { -lean_object* x_225; lean_object* x_226; lean_object* x_227; -lean_dec(x_206); -x_225 = lean_ctor_get(x_211, 1); -lean_inc(x_225); -lean_dec(x_211); -x_226 = lean_ctor_get(x_212, 0); -lean_inc(x_226); -lean_dec(x_212); -x_227 = l___private_Lean_Meta_WHNF_3__cache(x_201, x_1, x_226, x_2, x_225); -lean_dec(x_2); -return x_227; +lean_object* x_273; lean_object* x_274; lean_object* x_275; +lean_dec(x_254); +x_273 = lean_ctor_get(x_259, 1); +lean_inc(x_273); +lean_dec(x_259); +x_274 = lean_ctor_get(x_260, 0); +lean_inc(x_274); +lean_dec(x_260); +x_275 = l___private_Lean_Meta_WHNF_3__cache(x_249, x_1, x_274, x_2, x_273); +return x_275; } } else { -uint8_t x_228; -lean_dec(x_206); +uint8_t x_276; +lean_dec(x_254); lean_dec(x_2); lean_dec(x_1); -x_228 = !lean_is_exclusive(x_211); -if (x_228 == 0) +x_276 = !lean_is_exclusive(x_259); +if (x_276 == 0) { -return x_211; +return x_259; } else { -lean_object* x_229; lean_object* x_230; lean_object* x_231; -x_229 = lean_ctor_get(x_211, 0); -x_230 = lean_ctor_get(x_211, 1); -lean_inc(x_230); -lean_inc(x_229); -lean_dec(x_211); -x_231 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_231, 0, x_229); -lean_ctor_set(x_231, 1, x_230); -return x_231; +lean_object* x_277; lean_object* x_278; lean_object* x_279; +x_277 = lean_ctor_get(x_259, 0); +x_278 = lean_ctor_get(x_259, 1); +lean_inc(x_278); +lean_inc(x_277); +lean_dec(x_259); +x_279 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_279, 0, x_277); +lean_ctor_set(x_279, 1, x_278); +return x_279; } } } else { -lean_object* x_232; lean_object* x_233; lean_object* x_234; -lean_dec(x_206); -x_232 = lean_ctor_get(x_208, 1); -lean_inc(x_232); -lean_dec(x_208); -x_233 = lean_ctor_get(x_209, 0); -lean_inc(x_233); -lean_dec(x_209); -x_234 = l___private_Lean_Meta_WHNF_3__cache(x_201, x_1, x_233, x_2, x_232); -lean_dec(x_2); -return x_234; +lean_object* x_280; lean_object* x_281; lean_object* x_282; +lean_dec(x_254); +x_280 = lean_ctor_get(x_256, 1); +lean_inc(x_280); +lean_dec(x_256); +x_281 = lean_ctor_get(x_257, 0); +lean_inc(x_281); +lean_dec(x_257); +x_282 = l___private_Lean_Meta_WHNF_3__cache(x_249, x_1, x_281, x_2, x_280); +return x_282; } } else { -uint8_t x_235; -lean_dec(x_206); +uint8_t x_283; +lean_dec(x_254); lean_dec(x_2); lean_dec(x_1); -x_235 = !lean_is_exclusive(x_208); -if (x_235 == 0) +x_283 = !lean_is_exclusive(x_256); +if (x_283 == 0) { -return x_208; +return x_256; } else { -lean_object* x_236; lean_object* x_237; lean_object* x_238; -x_236 = lean_ctor_get(x_208, 0); -x_237 = lean_ctor_get(x_208, 1); -lean_inc(x_237); -lean_inc(x_236); -lean_dec(x_208); -x_238 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_238, 0, x_236); -lean_ctor_set(x_238, 1, x_237); -return x_238; +lean_object* x_284; lean_object* x_285; lean_object* x_286; +x_284 = lean_ctor_get(x_256, 0); +x_285 = lean_ctor_get(x_256, 1); +lean_inc(x_285); +lean_inc(x_284); +lean_dec(x_256); +x_286 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_286, 0, x_284); +lean_ctor_set(x_286, 1, x_285); +return x_286; } } } else { -uint8_t x_239; +uint8_t x_287; lean_dec(x_2); lean_dec(x_1); -x_239 = !lean_is_exclusive(x_205); -if (x_239 == 0) +x_287 = !lean_is_exclusive(x_253); +if (x_287 == 0) { -return x_205; +return x_253; } else { -lean_object* x_240; lean_object* x_241; lean_object* x_242; -x_240 = lean_ctor_get(x_205, 0); -x_241 = lean_ctor_get(x_205, 1); -lean_inc(x_241); -lean_inc(x_240); -lean_dec(x_205); -x_242 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_242, 0, x_240); -lean_ctor_set(x_242, 1, x_241); -return x_242; +lean_object* x_288; lean_object* x_289; lean_object* x_290; +x_288 = lean_ctor_get(x_253, 0); +x_289 = lean_ctor_get(x_253, 1); +lean_inc(x_289); +lean_inc(x_288); +lean_dec(x_253); +x_290 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_290, 0, x_288); +lean_ctor_set(x_290, 1, x_289); +return x_290; } } } else { -lean_object* x_243; lean_object* x_244; +lean_object* x_291; lean_object* x_292; lean_dec(x_2); lean_dec(x_1); -x_243 = lean_ctor_get(x_203, 0); -lean_inc(x_243); -lean_dec(x_203); -x_244 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_244, 0, x_243); -lean_ctor_set(x_244, 1, x_204); -return x_244; +x_291 = lean_ctor_get(x_251, 0); +lean_inc(x_291); +lean_dec(x_251); +x_292 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_292, 0, x_291); +lean_ctor_set(x_292, 1, x_252); +return x_292; } } } } case 12: { -lean_object* x_257; lean_object* x_258; lean_object* x_259; +lean_object* x_321; lean_object* x_322; lean_object* x_323; lean_dec(x_1); -x_257 = l_Lean_WHNF_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__1___closed__1; -x_258 = l_unreachable_x21___rarg(x_257); -x_259 = lean_apply_2(x_258, x_2, x_3); -return x_259; +x_321 = l_Lean_WHNF_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__1___closed__1; +x_322 = l_unreachable_x21___rarg(x_321); +x_323 = lean_apply_2(x_322, x_2, x_3); +return x_323; } default: { -lean_object* x_260; +lean_object* x_324; lean_dec(x_2); -x_260 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_260, 0, x_1); -lean_ctor_set(x_260, 1, x_3); -return x_260; +x_324 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_324, 0, x_1); +lean_ctor_set(x_324, 1, x_3); +return x_324; } } } diff --git a/stage0/stdlib/Lean/Parser/Term.c b/stage0/stdlib/Lean/Parser/Term.c index 0e76e5a429..522a812b32 100644 --- a/stage0/stdlib/Lean/Parser/Term.c +++ b/stage0/stdlib/Lean/Parser/Term.c @@ -52610,7 +52610,7 @@ _start: lean_object* x_1; lean_object* x_2; lean_object* x_3; x_1 = l_Lean_Parser_Term_bindOp___elambda__1___closed__3; x_2 = lean_unsigned_to_nat(55u); -x_3 = l_Lean_Parser_Term_infixR(x_1, x_2); +x_3 = l_Lean_Parser_Term_infixL(x_1, x_2); return x_3; } } diff --git a/stage0/stdlib/Lean/Util/Closure.c b/stage0/stdlib/Lean/Util/Closure.c index 42f82b4585..ebad1e9bc5 100644 --- a/stage0/stdlib/Lean/Util/Closure.c +++ b/stage0/stdlib/Lean/Util/Closure.c @@ -20,19 +20,22 @@ lean_object* l_Lean_Closure_mkNewLevelParam___closed__2; lean_object* l_Lean_Closure_mkLetDecl___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Std_mkHashMap___at_Lean_Closure_mkClosure___spec__2(lean_object*); lean_object* l_Lean_Closure_getUserName(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Closure_collectLevel___boxed(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_MetavarContext_instantiateMVars(lean_object*, lean_object*); lean_object* lean_array_uget(lean_object*, size_t); lean_object* l_Lean_Closure_mkLetDecl(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_expr_update_mdata(lean_object*, lean_object*); +lean_object* l_List_mapM___main___at_Lean_Closure_collectExprAux___main___spec__1___boxed(lean_object*, lean_object*, lean_object*); lean_object* lean_local_ctx_mk_let_decl(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Expr_updateMData_x21___closed__2; lean_object* lean_array_uset(lean_object*, size_t, lean_object*); -lean_object* lean_metavar_ctx_get_expr_assignment(lean_object*, lean_object*); extern lean_object* l_Array_empty___closed__1; uint8_t l_Lean_Level_hasMVar(lean_object*); extern lean_object* l_Lean_MetavarContext_getDecl___closed__2; extern lean_object* l_Std_ShareCommon_State_empty; lean_object* l_Std_HashMapImp_moveEntries___main___at_Lean_Closure_visitExpr___spec__6(lean_object*, lean_object*, lean_object*); size_t l_Lean_Level_hash(lean_object*); +lean_object* l_Lean_Closure_collectLevelAux___main___boxed(lean_object*, lean_object*, lean_object*); lean_object* lean_array_push(lean_object*, lean_object*); lean_object* lean_array_get_size(lean_object*); extern lean_object* l_Lean_Level_Inhabited; @@ -48,13 +51,14 @@ uint32_t l_UInt32_add(uint32_t, uint32_t); uint8_t l_Lean_Environment_hasUnsafe(lean_object*, lean_object*); lean_object* l_Lean_LocalContext_getFVars(lean_object*); extern lean_object* l_Lean_LocalContext_Inhabited___closed__2; +lean_object* l_Lean_Closure_getMCtx(lean_object*); lean_object* l_Lean_mkAuxDefinition(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, uint8_t); +lean_object* l_Lean_Closure_getMCtx___rarg(lean_object*); lean_object* l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitExpr___spec__1(lean_object*, lean_object*); lean_object* lean_array_fget(lean_object*, lean_object*); lean_object* l_Lean_Closure_mkClosure___closed__4; lean_object* lean_state_sharecommon(lean_object*, lean_object*); uint8_t l_Lean_Expr_hasLevelParam(lean_object*); -lean_object* lean_metavar_ctx_get_level_assignment(lean_object*, lean_object*); lean_object* l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitExpr___spec__1___boxed(lean_object*, lean_object*); lean_object* l_Lean_Closure_mkNextUserName___rarg(lean_object*); lean_object* l_Std_AssocList_find_x3f___main___at_Lean_Closure_visitLevel___spec__2(lean_object*, lean_object*); @@ -71,7 +75,6 @@ size_t l_Lean_Expr_hash(lean_object*); lean_object* lean_name_mk_string(lean_object*, lean_object*); lean_object* l_Lean_Closure_mkFreshFVarId___rarg(lean_object*); lean_object* l_Std_AssocList_contains___main___at_Lean_Closure_visitLevel___spec__4___boxed(lean_object*, lean_object*); -lean_object* l_Lean_Closure_mkClosure___closed__6; lean_object* l_Std_HashMapImp_expand___at_Lean_Closure_visitExpr___spec__5(lean_object*, lean_object*); size_t lean_usize_modn(size_t, lean_object*); lean_object* l_Lean_getMaxHeight(lean_object*, lean_object*); @@ -82,6 +85,8 @@ lean_object* l_Lean_Closure_mkClosure___closed__3; lean_object* lean_expr_update_let(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Closure_collectExprAux(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_mkFVar(lean_object*); +lean_object* l_Lean_Closure_getMCtx___boxed(lean_object*); +lean_object* l_Lean_Closure_collectLevelAux___boxed(lean_object*, lean_object*, lean_object*); uint8_t l_Lean_Expr_Data_binderInfo(uint64_t); lean_object* l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitLevel___spec__1___boxed(lean_object*, lean_object*); lean_object* l_Std_AssocList_foldlM___main___at_Lean_Closure_visitLevel___spec__7(lean_object*, lean_object*); @@ -98,6 +103,7 @@ lean_object* l_Std_AssocList_replace___main___at_Lean_Closure_visitLevel___spec_ uint8_t lean_expr_equal(lean_object*, lean_object*); lean_object* lean_expr_update_sort(lean_object*, lean_object*); lean_object* l_List_mapM___main___at_Lean_Closure_collectExprAux___main___spec__1(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Closure_instantiateMVars___boxed(lean_object*, lean_object*, lean_object*); uint8_t lean_nat_dec_le(lean_object*, lean_object*); uint8_t l_Lean_Expr_hasMVar(lean_object*); lean_object* l_Lean_Closure_mkClosure___closed__1; @@ -142,6 +148,7 @@ extern lean_object* l_Lean_Expr_updateForallE_x21___closed__1; lean_object* lean_name_mk_numeral(lean_object*, lean_object*); lean_object* lean_expr_update_const(lean_object*, lean_object*); extern lean_object* l_Lean_Level_updateIMax_x21___closed__2; +lean_object* l_Lean_Closure_instantiateMVars(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Closure_visitLevel(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitLevel___spec__1(lean_object*, lean_object*); lean_object* l_Std_AssocList_find_x3f___main___at_Lean_Closure_visitExpr___spec__2(lean_object*, lean_object*); @@ -508,42 +515,42 @@ return x_36; lean_object* l_Lean_Closure_visitLevel(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { -lean_object* x_5; uint8_t x_49; -x_49 = l_Lean_Level_hasMVar(x_2); -if (x_49 == 0) +lean_object* x_5; uint8_t x_51; +x_51 = l_Lean_Level_hasMVar(x_2); +if (x_51 == 0) { -uint8_t x_50; -x_50 = l_Lean_Level_hasParam(x_2); -if (x_50 == 0) -{ -lean_object* x_51; -lean_dec(x_3); -lean_dec(x_1); -x_51 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_51, 0, x_2); -lean_ctor_set(x_51, 1, x_4); -return x_51; -} -else -{ -lean_object* x_52; -x_52 = lean_box(0); -x_5 = x_52; -goto block_48; -} -} -else +uint8_t x_52; +x_52 = l_Lean_Level_hasParam(x_2); +if (x_52 == 0) { lean_object* x_53; -x_53 = lean_box(0); -x_5 = x_53; -goto block_48; +lean_dec(x_3); +lean_dec(x_1); +x_53 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_53, 0, x_2); +lean_ctor_set(x_53, 1, x_4); +return x_53; } -block_48: +else +{ +lean_object* x_54; +x_54 = lean_box(0); +x_5 = x_54; +goto block_50; +} +} +else +{ +lean_object* x_55; +x_55 = lean_box(0); +x_5 = x_55; +goto block_50; +} +block_50: { lean_object* x_6; lean_object* x_7; lean_dec(x_5); -x_6 = lean_ctor_get(x_4, 2); +x_6 = lean_ctor_get(x_4, 3); lean_inc(x_6); x_7 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitLevel___spec__1(x_6, x_2); lean_dec(x_6); @@ -565,15 +572,15 @@ if (x_11 == 0) { lean_object* x_12; lean_object* x_13; lean_object* x_14; x_12 = lean_ctor_get(x_8, 0); -x_13 = lean_ctor_get(x_10, 2); +x_13 = lean_ctor_get(x_10, 3); lean_inc(x_12); x_14 = l_Std_HashMapImp_insert___at_Lean_Closure_visitLevel___spec__3(x_13, x_2, x_12); -lean_ctor_set(x_10, 2, x_14); +lean_ctor_set(x_10, 3, x_14); return x_8; } else { -lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; 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_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; x_15 = lean_ctor_get(x_8, 0); x_16 = lean_ctor_get(x_10, 0); x_17 = lean_ctor_get(x_10, 1); @@ -584,6 +591,8 @@ x_21 = lean_ctor_get(x_10, 5); x_22 = lean_ctor_get(x_10, 6); x_23 = lean_ctor_get(x_10, 7); x_24 = lean_ctor_get(x_10, 8); +x_25 = lean_ctor_get(x_10, 9); +lean_inc(x_25); lean_inc(x_24); lean_inc(x_23); lean_inc(x_22); @@ -595,121 +604,126 @@ lean_inc(x_17); lean_inc(x_16); lean_dec(x_10); lean_inc(x_15); -x_25 = l_Std_HashMapImp_insert___at_Lean_Closure_visitLevel___spec__3(x_18, x_2, x_15); -x_26 = lean_alloc_ctor(0, 9, 0); -lean_ctor_set(x_26, 0, x_16); -lean_ctor_set(x_26, 1, x_17); -lean_ctor_set(x_26, 2, x_25); -lean_ctor_set(x_26, 3, x_19); -lean_ctor_set(x_26, 4, x_20); -lean_ctor_set(x_26, 5, x_21); -lean_ctor_set(x_26, 6, x_22); -lean_ctor_set(x_26, 7, x_23); -lean_ctor_set(x_26, 8, x_24); -lean_ctor_set(x_8, 1, x_26); +x_26 = l_Std_HashMapImp_insert___at_Lean_Closure_visitLevel___spec__3(x_19, x_2, x_15); +x_27 = lean_alloc_ctor(0, 10, 0); +lean_ctor_set(x_27, 0, x_16); +lean_ctor_set(x_27, 1, x_17); +lean_ctor_set(x_27, 2, x_18); +lean_ctor_set(x_27, 3, x_26); +lean_ctor_set(x_27, 4, x_20); +lean_ctor_set(x_27, 5, x_21); +lean_ctor_set(x_27, 6, x_22); +lean_ctor_set(x_27, 7, x_23); +lean_ctor_set(x_27, 8, x_24); +lean_ctor_set(x_27, 9, x_25); +lean_ctor_set(x_8, 1, x_27); return x_8; } } else { -lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; -x_27 = lean_ctor_get(x_8, 1); -x_28 = lean_ctor_get(x_8, 0); -lean_inc(x_27); +lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; +x_28 = lean_ctor_get(x_8, 1); +x_29 = lean_ctor_get(x_8, 0); lean_inc(x_28); -lean_dec(x_8); -x_29 = lean_ctor_get(x_27, 0); lean_inc(x_29); -x_30 = lean_ctor_get(x_27, 1); +lean_dec(x_8); +x_30 = lean_ctor_get(x_28, 0); lean_inc(x_30); -x_31 = lean_ctor_get(x_27, 2); +x_31 = lean_ctor_get(x_28, 1); lean_inc(x_31); -x_32 = lean_ctor_get(x_27, 3); +x_32 = lean_ctor_get(x_28, 2); lean_inc(x_32); -x_33 = lean_ctor_get(x_27, 4); +x_33 = lean_ctor_get(x_28, 3); lean_inc(x_33); -x_34 = lean_ctor_get(x_27, 5); +x_34 = lean_ctor_get(x_28, 4); lean_inc(x_34); -x_35 = lean_ctor_get(x_27, 6); +x_35 = lean_ctor_get(x_28, 5); lean_inc(x_35); -x_36 = lean_ctor_get(x_27, 7); +x_36 = lean_ctor_get(x_28, 6); lean_inc(x_36); -x_37 = lean_ctor_get(x_27, 8); +x_37 = lean_ctor_get(x_28, 7); lean_inc(x_37); -if (lean_is_exclusive(x_27)) { - lean_ctor_release(x_27, 0); - lean_ctor_release(x_27, 1); - lean_ctor_release(x_27, 2); - lean_ctor_release(x_27, 3); - lean_ctor_release(x_27, 4); - lean_ctor_release(x_27, 5); - lean_ctor_release(x_27, 6); - lean_ctor_release(x_27, 7); - lean_ctor_release(x_27, 8); - x_38 = x_27; +x_38 = lean_ctor_get(x_28, 8); +lean_inc(x_38); +x_39 = lean_ctor_get(x_28, 9); +lean_inc(x_39); +if (lean_is_exclusive(x_28)) { + lean_ctor_release(x_28, 0); + lean_ctor_release(x_28, 1); + lean_ctor_release(x_28, 2); + lean_ctor_release(x_28, 3); + lean_ctor_release(x_28, 4); + lean_ctor_release(x_28, 5); + lean_ctor_release(x_28, 6); + lean_ctor_release(x_28, 7); + lean_ctor_release(x_28, 8); + lean_ctor_release(x_28, 9); + x_40 = x_28; } else { - lean_dec_ref(x_27); - x_38 = lean_box(0); + lean_dec_ref(x_28); + x_40 = lean_box(0); } -lean_inc(x_28); -x_39 = l_Std_HashMapImp_insert___at_Lean_Closure_visitLevel___spec__3(x_31, x_2, x_28); -if (lean_is_scalar(x_38)) { - x_40 = lean_alloc_ctor(0, 9, 0); +lean_inc(x_29); +x_41 = l_Std_HashMapImp_insert___at_Lean_Closure_visitLevel___spec__3(x_33, x_2, x_29); +if (lean_is_scalar(x_40)) { + x_42 = lean_alloc_ctor(0, 10, 0); } else { - x_40 = x_38; + x_42 = x_40; } -lean_ctor_set(x_40, 0, x_29); -lean_ctor_set(x_40, 1, x_30); -lean_ctor_set(x_40, 2, x_39); -lean_ctor_set(x_40, 3, x_32); -lean_ctor_set(x_40, 4, x_33); -lean_ctor_set(x_40, 5, x_34); -lean_ctor_set(x_40, 6, x_35); -lean_ctor_set(x_40, 7, x_36); -lean_ctor_set(x_40, 8, x_37); -x_41 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_41, 0, x_28); -lean_ctor_set(x_41, 1, x_40); -return x_41; +lean_ctor_set(x_42, 0, x_30); +lean_ctor_set(x_42, 1, x_31); +lean_ctor_set(x_42, 2, x_32); +lean_ctor_set(x_42, 3, x_41); +lean_ctor_set(x_42, 4, x_34); +lean_ctor_set(x_42, 5, x_35); +lean_ctor_set(x_42, 6, x_36); +lean_ctor_set(x_42, 7, x_37); +lean_ctor_set(x_42, 8, x_38); +lean_ctor_set(x_42, 9, x_39); +x_43 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_43, 0, x_29); +lean_ctor_set(x_43, 1, x_42); +return x_43; } } else { -uint8_t x_42; +uint8_t x_44; lean_dec(x_2); -x_42 = !lean_is_exclusive(x_8); -if (x_42 == 0) +x_44 = !lean_is_exclusive(x_8); +if (x_44 == 0) { return x_8; } else { -lean_object* x_43; lean_object* x_44; lean_object* x_45; -x_43 = lean_ctor_get(x_8, 0); -x_44 = lean_ctor_get(x_8, 1); -lean_inc(x_44); -lean_inc(x_43); +lean_object* x_45; lean_object* x_46; lean_object* x_47; +x_45 = lean_ctor_get(x_8, 0); +x_46 = lean_ctor_get(x_8, 1); +lean_inc(x_46); +lean_inc(x_45); lean_dec(x_8); -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_47 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_47, 0, x_45); +lean_ctor_set(x_47, 1, x_46); +return x_47; } } } else { -lean_object* x_46; lean_object* x_47; +lean_object* x_48; lean_object* x_49; lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_46 = lean_ctor_get(x_7, 0); -lean_inc(x_46); +x_48 = lean_ctor_get(x_7, 0); +lean_inc(x_48); lean_dec(x_7); -x_47 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_47, 0, x_46); -lean_ctor_set(x_47, 1, x_4); -return x_47; +x_49 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_49, 0, x_48); +lean_ctor_set(x_49, 1, x_4); +return x_49; } } } @@ -771,9 +785,9 @@ x_4 = !lean_is_exclusive(x_3); if (x_4 == 0) { 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; -x_5 = lean_ctor_get(x_3, 4); -x_6 = lean_ctor_get(x_3, 5); -x_7 = lean_ctor_get(x_3, 6); +x_5 = lean_ctor_get(x_3, 5); +x_6 = lean_ctor_get(x_3, 6); +x_7 = lean_ctor_get(x_3, 7); x_8 = l_Lean_Closure_mkNewLevelParam___closed__2; lean_inc(x_6); x_9 = l_Lean_Name_appendIndexAfter(x_8, x_6); @@ -784,9 +798,9 @@ x_12 = lean_unsigned_to_nat(1u); x_13 = lean_nat_add(x_6, x_12); lean_dec(x_6); x_14 = lean_array_push(x_7, x_1); -lean_ctor_set(x_3, 6, x_14); -lean_ctor_set(x_3, 5, x_13); -lean_ctor_set(x_3, 4, x_11); +lean_ctor_set(x_3, 7, x_14); +lean_ctor_set(x_3, 6, x_13); +lean_ctor_set(x_3, 5, x_11); x_15 = lean_alloc_ctor(0, 2, 0); lean_ctor_set(x_15, 0, x_10); lean_ctor_set(x_15, 1, x_3); @@ -794,7 +808,7 @@ return x_15; } else { -lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; +lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; x_16 = lean_ctor_get(x_3, 0); x_17 = lean_ctor_get(x_3, 1); x_18 = lean_ctor_get(x_3, 2); @@ -804,6 +818,8 @@ x_21 = lean_ctor_get(x_3, 5); x_22 = lean_ctor_get(x_3, 6); x_23 = lean_ctor_get(x_3, 7); x_24 = lean_ctor_get(x_3, 8); +x_25 = lean_ctor_get(x_3, 9); +lean_inc(x_25); lean_inc(x_24); lean_inc(x_23); lean_inc(x_22); @@ -814,30 +830,31 @@ lean_inc(x_18); lean_inc(x_17); lean_inc(x_16); lean_dec(x_3); -x_25 = l_Lean_Closure_mkNewLevelParam___closed__2; -lean_inc(x_21); -x_26 = l_Lean_Name_appendIndexAfter(x_25, x_21); -lean_inc(x_26); -x_27 = l_Lean_mkLevelParam(x_26); -x_28 = lean_array_push(x_20, x_26); -x_29 = lean_unsigned_to_nat(1u); -x_30 = lean_nat_add(x_21, x_29); -lean_dec(x_21); -x_31 = lean_array_push(x_22, x_1); -x_32 = lean_alloc_ctor(0, 9, 0); -lean_ctor_set(x_32, 0, x_16); -lean_ctor_set(x_32, 1, x_17); -lean_ctor_set(x_32, 2, x_18); -lean_ctor_set(x_32, 3, x_19); -lean_ctor_set(x_32, 4, x_28); -lean_ctor_set(x_32, 5, x_30); -lean_ctor_set(x_32, 6, x_31); -lean_ctor_set(x_32, 7, x_23); -lean_ctor_set(x_32, 8, x_24); -x_33 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_33, 0, x_27); -lean_ctor_set(x_33, 1, x_32); -return x_33; +x_26 = l_Lean_Closure_mkNewLevelParam___closed__2; +lean_inc(x_22); +x_27 = l_Lean_Name_appendIndexAfter(x_26, x_22); +lean_inc(x_27); +x_28 = l_Lean_mkLevelParam(x_27); +x_29 = lean_array_push(x_21, x_27); +x_30 = lean_unsigned_to_nat(1u); +x_31 = lean_nat_add(x_22, x_30); +lean_dec(x_22); +x_32 = lean_array_push(x_23, x_1); +x_33 = lean_alloc_ctor(0, 10, 0); +lean_ctor_set(x_33, 0, x_16); +lean_ctor_set(x_33, 1, x_17); +lean_ctor_set(x_33, 2, x_18); +lean_ctor_set(x_33, 3, x_19); +lean_ctor_set(x_33, 4, x_20); +lean_ctor_set(x_33, 5, x_29); +lean_ctor_set(x_33, 6, x_31); +lean_ctor_set(x_33, 7, x_32); +lean_ctor_set(x_33, 8, x_24); +lean_ctor_set(x_33, 9, x_25); +x_34 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_34, 0, x_28); +lean_ctor_set(x_34, 1, x_33); +return x_34; } } } @@ -850,6 +867,113 @@ lean_dec(x_2); return x_4; } } +lean_object* l_Lean_Closure_getMCtx___rarg(lean_object* x_1) { +_start: +{ +lean_object* x_2; lean_object* x_3; +x_2 = lean_ctor_get(x_1, 0); +lean_inc(x_2); +x_3 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_3, 0, x_2); +lean_ctor_set(x_3, 1, x_1); +return x_3; +} +} +lean_object* l_Lean_Closure_getMCtx(lean_object* x_1) { +_start: +{ +lean_object* x_2; +x_2 = lean_alloc_closure((void*)(l_Lean_Closure_getMCtx___rarg), 1, 0); +return x_2; +} +} +lean_object* l_Lean_Closure_getMCtx___boxed(lean_object* x_1) { +_start: +{ +lean_object* x_2; +x_2 = l_Lean_Closure_getMCtx(x_1); +lean_dec(x_1); +return x_2; +} +} +lean_object* l_Lean_Closure_instantiateMVars(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +uint8_t x_4; +x_4 = !lean_is_exclusive(x_3); +if (x_4 == 0) +{ +lean_object* x_5; lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; +x_5 = lean_ctor_get(x_3, 0); +x_6 = l_Lean_MetavarContext_instantiateMVars(x_5, x_1); +x_7 = lean_ctor_get(x_6, 0); +lean_inc(x_7); +x_8 = lean_ctor_get(x_6, 1); +lean_inc(x_8); +lean_dec(x_6); +lean_ctor_set(x_3, 0, x_8); +x_9 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_9, 0, x_7); +lean_ctor_set(x_9, 1, x_3); +return x_9; +} +else +{ +lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; +x_10 = lean_ctor_get(x_3, 0); +x_11 = lean_ctor_get(x_3, 1); +x_12 = lean_ctor_get(x_3, 2); +x_13 = lean_ctor_get(x_3, 3); +x_14 = lean_ctor_get(x_3, 4); +x_15 = lean_ctor_get(x_3, 5); +x_16 = lean_ctor_get(x_3, 6); +x_17 = lean_ctor_get(x_3, 7); +x_18 = lean_ctor_get(x_3, 8); +x_19 = lean_ctor_get(x_3, 9); +lean_inc(x_19); +lean_inc(x_18); +lean_inc(x_17); +lean_inc(x_16); +lean_inc(x_15); +lean_inc(x_14); +lean_inc(x_13); +lean_inc(x_12); +lean_inc(x_11); +lean_inc(x_10); +lean_dec(x_3); +x_20 = l_Lean_MetavarContext_instantiateMVars(x_10, x_1); +x_21 = lean_ctor_get(x_20, 0); +lean_inc(x_21); +x_22 = lean_ctor_get(x_20, 1); +lean_inc(x_22); +lean_dec(x_20); +x_23 = lean_alloc_ctor(0, 10, 0); +lean_ctor_set(x_23, 0, x_22); +lean_ctor_set(x_23, 1, x_11); +lean_ctor_set(x_23, 2, x_12); +lean_ctor_set(x_23, 3, x_13); +lean_ctor_set(x_23, 4, x_14); +lean_ctor_set(x_23, 5, x_15); +lean_ctor_set(x_23, 6, x_16); +lean_ctor_set(x_23, 7, x_17); +lean_ctor_set(x_23, 8, x_18); +lean_ctor_set(x_23, 9, x_19); +x_24 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_24, 0, x_21); +lean_ctor_set(x_24, 1, x_23); +return x_24; +} +} +} +lean_object* l_Lean_Closure_instantiateMVars___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; +x_4 = l_Lean_Closure_instantiateMVars(x_1, x_2, x_3); +lean_dec(x_2); +return x_4; +} +} lean_object* l_Lean_Closure_collectLevelAux___main(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { @@ -858,7 +982,6 @@ switch (lean_obj_tag(x_1)) { case 0: { lean_object* x_13; -lean_dec(x_2); x_13 = lean_alloc_ctor(0, 2, 0); lean_ctor_set(x_13, 0, x_1); lean_ctor_set(x_13, 1, x_3); @@ -866,41 +989,40 @@ return x_13; } case 1: { -lean_object* x_14; lean_object* x_15; uint8_t x_37; +lean_object* x_14; lean_object* x_15; uint8_t x_38; x_14 = lean_ctor_get(x_1, 0); lean_inc(x_14); -x_37 = l_Lean_Level_hasMVar(x_14); -if (x_37 == 0) -{ -uint8_t x_38; -x_38 = l_Lean_Level_hasParam(x_14); +x_38 = l_Lean_Level_hasMVar(x_14); if (x_38 == 0) { -lean_dec(x_2); +uint8_t x_39; +x_39 = l_Lean_Level_hasParam(x_14); +if (x_39 == 0) +{ x_4 = x_14; x_5 = x_3; goto block_12; } else { -lean_object* x_39; -x_39 = lean_box(0); -x_15 = x_39; -goto block_36; +lean_object* x_40; +x_40 = lean_box(0); +x_15 = x_40; +goto block_37; } } else { -lean_object* x_40; -x_40 = lean_box(0); -x_15 = x_40; -goto block_36; +lean_object* x_41; +x_41 = lean_box(0); +x_15 = x_41; +goto block_37; } -block_36: +block_37: { lean_object* x_16; lean_object* x_17; lean_dec(x_15); -x_16 = lean_ctor_get(x_3, 2); +x_16 = lean_ctor_get(x_3, 3); lean_inc(x_16); x_17 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitLevel___spec__1(x_16, x_14); lean_dec(x_16); @@ -918,17 +1040,17 @@ x_21 = !lean_is_exclusive(x_19); if (x_21 == 0) { lean_object* x_22; lean_object* x_23; -x_22 = lean_ctor_get(x_19, 2); +x_22 = lean_ctor_get(x_19, 3); lean_inc(x_20); x_23 = l_Std_HashMapImp_insert___at_Lean_Closure_visitLevel___spec__3(x_22, x_14, x_20); -lean_ctor_set(x_19, 2, x_23); +lean_ctor_set(x_19, 3, x_23); x_4 = x_20; x_5 = x_19; goto block_12; } else { -lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; +lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; x_24 = lean_ctor_get(x_19, 0); x_25 = lean_ctor_get(x_19, 1); x_26 = lean_ctor_get(x_19, 2); @@ -938,6 +1060,8 @@ x_29 = lean_ctor_get(x_19, 5); x_30 = lean_ctor_get(x_19, 6); x_31 = lean_ctor_get(x_19, 7); x_32 = lean_ctor_get(x_19, 8); +x_33 = lean_ctor_get(x_19, 9); +lean_inc(x_33); lean_inc(x_32); lean_inc(x_31); lean_inc(x_30); @@ -949,31 +1073,31 @@ lean_inc(x_25); lean_inc(x_24); lean_dec(x_19); lean_inc(x_20); -x_33 = l_Std_HashMapImp_insert___at_Lean_Closure_visitLevel___spec__3(x_26, x_14, x_20); -x_34 = lean_alloc_ctor(0, 9, 0); -lean_ctor_set(x_34, 0, x_24); -lean_ctor_set(x_34, 1, x_25); -lean_ctor_set(x_34, 2, x_33); -lean_ctor_set(x_34, 3, x_27); -lean_ctor_set(x_34, 4, x_28); -lean_ctor_set(x_34, 5, x_29); -lean_ctor_set(x_34, 6, x_30); -lean_ctor_set(x_34, 7, x_31); -lean_ctor_set(x_34, 8, x_32); +x_34 = l_Std_HashMapImp_insert___at_Lean_Closure_visitLevel___spec__3(x_27, x_14, x_20); +x_35 = lean_alloc_ctor(0, 10, 0); +lean_ctor_set(x_35, 0, x_24); +lean_ctor_set(x_35, 1, x_25); +lean_ctor_set(x_35, 2, x_26); +lean_ctor_set(x_35, 3, x_34); +lean_ctor_set(x_35, 4, x_28); +lean_ctor_set(x_35, 5, x_29); +lean_ctor_set(x_35, 6, x_30); +lean_ctor_set(x_35, 7, x_31); +lean_ctor_set(x_35, 8, x_32); +lean_ctor_set(x_35, 9, x_33); x_4 = x_20; -x_5 = x_34; +x_5 = x_35; goto block_12; } } else { -lean_object* x_35; +lean_object* x_36; lean_dec(x_14); -lean_dec(x_2); -x_35 = lean_ctor_get(x_17, 0); -lean_inc(x_35); +x_36 = lean_ctor_get(x_17, 0); +lean_inc(x_36); lean_dec(x_17); -x_4 = x_35; +x_4 = x_36; x_5 = x_3; goto block_12; } @@ -981,135 +1105,137 @@ goto block_12; } case 2: { -lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_81; uint8_t x_103; -x_41 = lean_ctor_get(x_1, 0); -lean_inc(x_41); -x_42 = lean_ctor_get(x_1, 1); +lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_83; uint8_t x_106; +x_42 = lean_ctor_get(x_1, 0); lean_inc(x_42); -x_103 = l_Lean_Level_hasMVar(x_41); -if (x_103 == 0) +x_43 = lean_ctor_get(x_1, 1); +lean_inc(x_43); +x_106 = l_Lean_Level_hasMVar(x_42); +if (x_106 == 0) { -uint8_t x_104; -x_104 = l_Lean_Level_hasParam(x_41); -if (x_104 == 0) +uint8_t x_107; +x_107 = l_Lean_Level_hasParam(x_42); +if (x_107 == 0) { -x_43 = x_41; -x_44 = x_3; -goto block_80; +x_44 = x_42; +x_45 = x_3; +goto block_82; } else { -lean_object* x_105; -x_105 = lean_box(0); -x_81 = x_105; -goto block_102; +lean_object* x_108; +x_108 = lean_box(0); +x_83 = x_108; +goto block_105; } } else { -lean_object* x_106; -x_106 = lean_box(0); -x_81 = x_106; -goto block_102; +lean_object* x_109; +x_109 = lean_box(0); +x_83 = x_109; +goto block_105; } -block_80: +block_82: { -lean_object* x_45; lean_object* x_46; lean_object* x_54; uint8_t x_76; -x_76 = l_Lean_Level_hasMVar(x_42); -if (x_76 == 0) +lean_object* x_46; lean_object* x_47; lean_object* x_55; uint8_t x_78; +x_78 = l_Lean_Level_hasMVar(x_43); +if (x_78 == 0) { -uint8_t x_77; -x_77 = l_Lean_Level_hasParam(x_42); -if (x_77 == 0) +uint8_t x_79; +x_79 = l_Lean_Level_hasParam(x_43); +if (x_79 == 0) { -lean_dec(x_2); -x_45 = x_42; -x_46 = x_44; -goto block_53; +x_46 = x_43; +x_47 = x_45; +goto block_54; } else { -lean_object* x_78; -x_78 = lean_box(0); -x_54 = x_78; -goto block_75; +lean_object* x_80; +x_80 = lean_box(0); +x_55 = x_80; +goto block_77; } } else { -lean_object* x_79; -x_79 = lean_box(0); -x_54 = x_79; -goto block_75; +lean_object* x_81; +x_81 = lean_box(0); +x_55 = x_81; +goto block_77; } -block_53: +block_54: { if (lean_obj_tag(x_1) == 2) { -lean_object* x_47; lean_object* x_48; -x_47 = lean_level_update_max(x_1, x_43, x_45); -x_48 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_48, 0, x_47); -lean_ctor_set(x_48, 1, x_46); -return x_48; +lean_object* x_48; lean_object* x_49; +x_48 = lean_level_update_max(x_1, x_44, x_46); +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; } else { -lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; -lean_dec(x_45); -lean_dec(x_43); +lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; +lean_dec(x_46); +lean_dec(x_44); lean_dec(x_1); -x_49 = l_Lean_Level_Inhabited; -x_50 = l_Lean_Level_updateMax_x21___closed__2; -x_51 = lean_panic_fn(x_49, x_50); -x_52 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_52, 0, x_51); -lean_ctor_set(x_52, 1, x_46); -return x_52; +x_50 = l_Lean_Level_Inhabited; +x_51 = l_Lean_Level_updateMax_x21___closed__2; +x_52 = lean_panic_fn(x_50, 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; } } -block_75: +block_77: { -lean_object* x_55; lean_object* x_56; -lean_dec(x_54); -x_55 = lean_ctor_get(x_44, 2); -lean_inc(x_55); -x_56 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitLevel___spec__1(x_55, x_42); +lean_object* x_56; lean_object* x_57; lean_dec(x_55); -if (lean_obj_tag(x_56) == 0) +x_56 = lean_ctor_get(x_45, 3); +lean_inc(x_56); +x_57 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitLevel___spec__1(x_56, x_43); +lean_dec(x_56); +if (lean_obj_tag(x_57) == 0) { -lean_object* x_57; lean_object* x_58; lean_object* x_59; uint8_t x_60; -lean_inc(x_42); -x_57 = l_Lean_Closure_collectLevelAux___main(x_42, x_2, x_44); -x_58 = lean_ctor_get(x_57, 1); -lean_inc(x_58); -x_59 = lean_ctor_get(x_57, 0); +lean_object* x_58; lean_object* x_59; lean_object* x_60; uint8_t x_61; +lean_inc(x_43); +x_58 = l_Lean_Closure_collectLevelAux___main(x_43, x_2, x_45); +x_59 = lean_ctor_get(x_58, 1); lean_inc(x_59); -lean_dec(x_57); -x_60 = !lean_is_exclusive(x_58); -if (x_60 == 0) +x_60 = lean_ctor_get(x_58, 0); +lean_inc(x_60); +lean_dec(x_58); +x_61 = !lean_is_exclusive(x_59); +if (x_61 == 0) { -lean_object* x_61; lean_object* x_62; -x_61 = lean_ctor_get(x_58, 2); -lean_inc(x_59); -x_62 = l_Std_HashMapImp_insert___at_Lean_Closure_visitLevel___spec__3(x_61, x_42, x_59); -lean_ctor_set(x_58, 2, x_62); -x_45 = x_59; -x_46 = x_58; -goto block_53; +lean_object* x_62; lean_object* x_63; +x_62 = lean_ctor_get(x_59, 3); +lean_inc(x_60); +x_63 = l_Std_HashMapImp_insert___at_Lean_Closure_visitLevel___spec__3(x_62, x_43, x_60); +lean_ctor_set(x_59, 3, x_63); +x_46 = x_60; +x_47 = x_59; +goto block_54; } else { -lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; -x_63 = lean_ctor_get(x_58, 0); -x_64 = lean_ctor_get(x_58, 1); -x_65 = lean_ctor_get(x_58, 2); -x_66 = lean_ctor_get(x_58, 3); -x_67 = lean_ctor_get(x_58, 4); -x_68 = lean_ctor_get(x_58, 5); -x_69 = lean_ctor_get(x_58, 6); -x_70 = lean_ctor_get(x_58, 7); -x_71 = lean_ctor_get(x_58, 8); +lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; +x_64 = lean_ctor_get(x_59, 0); +x_65 = lean_ctor_get(x_59, 1); +x_66 = lean_ctor_get(x_59, 2); +x_67 = lean_ctor_get(x_59, 3); +x_68 = lean_ctor_get(x_59, 4); +x_69 = lean_ctor_get(x_59, 5); +x_70 = lean_ctor_get(x_59, 6); +x_71 = lean_ctor_get(x_59, 7); +x_72 = lean_ctor_get(x_59, 8); +x_73 = lean_ctor_get(x_59, 9); +lean_inc(x_73); +lean_inc(x_72); lean_inc(x_71); lean_inc(x_70); lean_inc(x_69); @@ -1118,82 +1244,84 @@ lean_inc(x_67); lean_inc(x_66); lean_inc(x_65); lean_inc(x_64); -lean_inc(x_63); -lean_dec(x_58); -lean_inc(x_59); -x_72 = l_Std_HashMapImp_insert___at_Lean_Closure_visitLevel___spec__3(x_65, x_42, x_59); -x_73 = lean_alloc_ctor(0, 9, 0); -lean_ctor_set(x_73, 0, x_63); -lean_ctor_set(x_73, 1, x_64); -lean_ctor_set(x_73, 2, x_72); -lean_ctor_set(x_73, 3, x_66); -lean_ctor_set(x_73, 4, x_67); -lean_ctor_set(x_73, 5, x_68); -lean_ctor_set(x_73, 6, x_69); -lean_ctor_set(x_73, 7, x_70); -lean_ctor_set(x_73, 8, x_71); -x_45 = x_59; -x_46 = x_73; -goto block_53; +lean_dec(x_59); +lean_inc(x_60); +x_74 = l_Std_HashMapImp_insert___at_Lean_Closure_visitLevel___spec__3(x_67, x_43, x_60); +x_75 = lean_alloc_ctor(0, 10, 0); +lean_ctor_set(x_75, 0, x_64); +lean_ctor_set(x_75, 1, x_65); +lean_ctor_set(x_75, 2, x_66); +lean_ctor_set(x_75, 3, x_74); +lean_ctor_set(x_75, 4, x_68); +lean_ctor_set(x_75, 5, x_69); +lean_ctor_set(x_75, 6, x_70); +lean_ctor_set(x_75, 7, x_71); +lean_ctor_set(x_75, 8, x_72); +lean_ctor_set(x_75, 9, x_73); +x_46 = x_60; +x_47 = x_75; +goto block_54; } } else { -lean_object* x_74; -lean_dec(x_42); -lean_dec(x_2); -x_74 = lean_ctor_get(x_56, 0); -lean_inc(x_74); -lean_dec(x_56); -x_45 = x_74; -x_46 = x_44; -goto block_53; +lean_object* x_76; +lean_dec(x_43); +x_76 = lean_ctor_get(x_57, 0); +lean_inc(x_76); +lean_dec(x_57); +x_46 = x_76; +x_47 = x_45; +goto block_54; } } } -block_102: +block_105: { -lean_object* x_82; lean_object* x_83; -lean_dec(x_81); -x_82 = lean_ctor_get(x_3, 2); -lean_inc(x_82); -x_83 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitLevel___spec__1(x_82, x_41); -lean_dec(x_82); -if (lean_obj_tag(x_83) == 0) -{ -lean_object* x_84; lean_object* x_85; lean_object* x_86; uint8_t x_87; -lean_inc(x_2); -lean_inc(x_41); -x_84 = l_Lean_Closure_collectLevelAux___main(x_41, x_2, x_3); -x_85 = lean_ctor_get(x_84, 1); -lean_inc(x_85); -x_86 = lean_ctor_get(x_84, 0); -lean_inc(x_86); +lean_object* x_84; lean_object* x_85; +lean_dec(x_83); +x_84 = lean_ctor_get(x_3, 3); +lean_inc(x_84); +x_85 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitLevel___spec__1(x_84, x_42); lean_dec(x_84); -x_87 = !lean_is_exclusive(x_85); -if (x_87 == 0) +if (lean_obj_tag(x_85) == 0) { -lean_object* x_88; lean_object* x_89; -x_88 = lean_ctor_get(x_85, 2); -lean_inc(x_86); -x_89 = l_Std_HashMapImp_insert___at_Lean_Closure_visitLevel___spec__3(x_88, x_41, x_86); -lean_ctor_set(x_85, 2, x_89); -x_43 = x_86; -x_44 = x_85; -goto block_80; +lean_object* x_86; lean_object* x_87; lean_object* x_88; uint8_t x_89; +lean_inc(x_42); +x_86 = l_Lean_Closure_collectLevelAux___main(x_42, x_2, x_3); +x_87 = lean_ctor_get(x_86, 1); +lean_inc(x_87); +x_88 = lean_ctor_get(x_86, 0); +lean_inc(x_88); +lean_dec(x_86); +x_89 = !lean_is_exclusive(x_87); +if (x_89 == 0) +{ +lean_object* x_90; lean_object* x_91; +x_90 = lean_ctor_get(x_87, 3); +lean_inc(x_88); +x_91 = l_Std_HashMapImp_insert___at_Lean_Closure_visitLevel___spec__3(x_90, x_42, x_88); +lean_ctor_set(x_87, 3, x_91); +x_44 = x_88; +x_45 = x_87; +goto block_82; } else { -lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; -x_90 = lean_ctor_get(x_85, 0); -x_91 = lean_ctor_get(x_85, 1); -x_92 = lean_ctor_get(x_85, 2); -x_93 = lean_ctor_get(x_85, 3); -x_94 = lean_ctor_get(x_85, 4); -x_95 = lean_ctor_get(x_85, 5); -x_96 = lean_ctor_get(x_85, 6); -x_97 = lean_ctor_get(x_85, 7); -x_98 = lean_ctor_get(x_85, 8); +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; +x_92 = lean_ctor_get(x_87, 0); +x_93 = lean_ctor_get(x_87, 1); +x_94 = lean_ctor_get(x_87, 2); +x_95 = lean_ctor_get(x_87, 3); +x_96 = lean_ctor_get(x_87, 4); +x_97 = lean_ctor_get(x_87, 5); +x_98 = lean_ctor_get(x_87, 6); +x_99 = lean_ctor_get(x_87, 7); +x_100 = lean_ctor_get(x_87, 8); +x_101 = lean_ctor_get(x_87, 9); +lean_inc(x_101); +lean_inc(x_100); +lean_inc(x_99); lean_inc(x_98); lean_inc(x_97); lean_inc(x_96); @@ -1201,498 +1329,301 @@ lean_inc(x_95); lean_inc(x_94); lean_inc(x_93); lean_inc(x_92); -lean_inc(x_91); -lean_inc(x_90); -lean_dec(x_85); -lean_inc(x_86); -x_99 = l_Std_HashMapImp_insert___at_Lean_Closure_visitLevel___spec__3(x_92, x_41, x_86); -x_100 = lean_alloc_ctor(0, 9, 0); -lean_ctor_set(x_100, 0, x_90); -lean_ctor_set(x_100, 1, x_91); -lean_ctor_set(x_100, 2, x_99); -lean_ctor_set(x_100, 3, x_93); -lean_ctor_set(x_100, 4, x_94); -lean_ctor_set(x_100, 5, x_95); -lean_ctor_set(x_100, 6, x_96); -lean_ctor_set(x_100, 7, x_97); -lean_ctor_set(x_100, 8, x_98); -x_43 = x_86; -x_44 = x_100; -goto block_80; +lean_dec(x_87); +lean_inc(x_88); +x_102 = l_Std_HashMapImp_insert___at_Lean_Closure_visitLevel___spec__3(x_95, x_42, x_88); +x_103 = lean_alloc_ctor(0, 10, 0); +lean_ctor_set(x_103, 0, x_92); +lean_ctor_set(x_103, 1, x_93); +lean_ctor_set(x_103, 2, x_94); +lean_ctor_set(x_103, 3, x_102); +lean_ctor_set(x_103, 4, x_96); +lean_ctor_set(x_103, 5, x_97); +lean_ctor_set(x_103, 6, x_98); +lean_ctor_set(x_103, 7, x_99); +lean_ctor_set(x_103, 8, x_100); +lean_ctor_set(x_103, 9, x_101); +x_44 = x_88; +x_45 = x_103; +goto block_82; } } else { -lean_object* x_101; -lean_dec(x_41); -x_101 = lean_ctor_get(x_83, 0); -lean_inc(x_101); -lean_dec(x_83); -x_43 = x_101; -x_44 = x_3; -goto block_80; +lean_object* x_104; +lean_dec(x_42); +x_104 = lean_ctor_get(x_85, 0); +lean_inc(x_104); +lean_dec(x_85); +x_44 = x_104; +x_45 = x_3; +goto block_82; } } } case 3: { -lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_147; uint8_t x_169; -x_107 = lean_ctor_get(x_1, 0); -lean_inc(x_107); -x_108 = lean_ctor_get(x_1, 1); -lean_inc(x_108); -x_169 = l_Lean_Level_hasMVar(x_107); -if (x_169 == 0) +lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_151; uint8_t x_174; +x_110 = lean_ctor_get(x_1, 0); +lean_inc(x_110); +x_111 = lean_ctor_get(x_1, 1); +lean_inc(x_111); +x_174 = l_Lean_Level_hasMVar(x_110); +if (x_174 == 0) { -uint8_t x_170; -x_170 = l_Lean_Level_hasParam(x_107); -if (x_170 == 0) +uint8_t x_175; +x_175 = l_Lean_Level_hasParam(x_110); +if (x_175 == 0) { -x_109 = x_107; -x_110 = x_3; -goto block_146; -} -else -{ -lean_object* x_171; -x_171 = lean_box(0); -x_147 = x_171; -goto block_168; -} -} -else -{ -lean_object* x_172; -x_172 = lean_box(0); -x_147 = x_172; -goto block_168; -} -block_146: -{ -lean_object* x_111; lean_object* x_112; lean_object* x_120; uint8_t x_142; -x_142 = l_Lean_Level_hasMVar(x_108); -if (x_142 == 0) -{ -uint8_t x_143; -x_143 = l_Lean_Level_hasParam(x_108); -if (x_143 == 0) -{ -lean_dec(x_2); -x_111 = x_108; x_112 = x_110; -goto block_119; +x_113 = x_3; +goto block_150; } else { -lean_object* x_144; -x_144 = lean_box(0); -x_120 = x_144; -goto block_141; +lean_object* x_176; +x_176 = lean_box(0); +x_151 = x_176; +goto block_173; } } else { -lean_object* x_145; -x_145 = lean_box(0); -x_120 = x_145; -goto block_141; +lean_object* x_177; +x_177 = lean_box(0); +x_151 = x_177; +goto block_173; } -block_119: +block_150: +{ +lean_object* x_114; lean_object* x_115; lean_object* x_123; uint8_t x_146; +x_146 = l_Lean_Level_hasMVar(x_111); +if (x_146 == 0) +{ +uint8_t x_147; +x_147 = l_Lean_Level_hasParam(x_111); +if (x_147 == 0) +{ +x_114 = x_111; +x_115 = x_113; +goto block_122; +} +else +{ +lean_object* x_148; +x_148 = lean_box(0); +x_123 = x_148; +goto block_145; +} +} +else +{ +lean_object* x_149; +x_149 = lean_box(0); +x_123 = x_149; +goto block_145; +} +block_122: { if (lean_obj_tag(x_1) == 3) { -lean_object* x_113; lean_object* x_114; -x_113 = lean_level_update_imax(x_1, x_109, x_111); -x_114 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_114, 0, x_113); -lean_ctor_set(x_114, 1, x_112); -return x_114; +lean_object* x_116; lean_object* x_117; +x_116 = lean_level_update_imax(x_1, x_112, x_114); +x_117 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_117, 0, x_116); +lean_ctor_set(x_117, 1, x_115); +return x_117; } else { -lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; -lean_dec(x_111); -lean_dec(x_109); +lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; +lean_dec(x_114); +lean_dec(x_112); lean_dec(x_1); -x_115 = l_Lean_Level_Inhabited; -x_116 = l_Lean_Level_updateIMax_x21___closed__2; -x_117 = lean_panic_fn(x_115, x_116); -x_118 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_118, 0, x_117); -lean_ctor_set(x_118, 1, x_112); -return x_118; +x_118 = l_Lean_Level_Inhabited; +x_119 = l_Lean_Level_updateIMax_x21___closed__2; +x_120 = lean_panic_fn(x_118, x_119); +x_121 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_121, 0, x_120); +lean_ctor_set(x_121, 1, x_115); +return x_121; } } -block_141: +block_145: { -lean_object* x_121; lean_object* x_122; -lean_dec(x_120); -x_121 = lean_ctor_get(x_110, 2); -lean_inc(x_121); -x_122 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitLevel___spec__1(x_121, x_108); -lean_dec(x_121); -if (lean_obj_tag(x_122) == 0) -{ -lean_object* x_123; lean_object* x_124; lean_object* x_125; uint8_t x_126; -lean_inc(x_108); -x_123 = l_Lean_Closure_collectLevelAux___main(x_108, x_2, x_110); -x_124 = lean_ctor_get(x_123, 1); -lean_inc(x_124); -x_125 = lean_ctor_get(x_123, 0); -lean_inc(x_125); +lean_object* x_124; lean_object* x_125; lean_dec(x_123); -x_126 = !lean_is_exclusive(x_124); -if (x_126 == 0) +x_124 = lean_ctor_get(x_113, 3); +lean_inc(x_124); +x_125 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitLevel___spec__1(x_124, x_111); +lean_dec(x_124); +if (lean_obj_tag(x_125) == 0) { -lean_object* x_127; lean_object* x_128; -x_127 = lean_ctor_get(x_124, 2); -lean_inc(x_125); -x_128 = l_Std_HashMapImp_insert___at_Lean_Closure_visitLevel___spec__3(x_127, x_108, x_125); -lean_ctor_set(x_124, 2, x_128); -x_111 = x_125; -x_112 = x_124; -goto block_119; +lean_object* x_126; lean_object* x_127; lean_object* x_128; uint8_t x_129; +lean_inc(x_111); +x_126 = l_Lean_Closure_collectLevelAux___main(x_111, x_2, x_113); +x_127 = lean_ctor_get(x_126, 1); +lean_inc(x_127); +x_128 = lean_ctor_get(x_126, 0); +lean_inc(x_128); +lean_dec(x_126); +x_129 = !lean_is_exclusive(x_127); +if (x_129 == 0) +{ +lean_object* x_130; lean_object* x_131; +x_130 = lean_ctor_get(x_127, 3); +lean_inc(x_128); +x_131 = l_Std_HashMapImp_insert___at_Lean_Closure_visitLevel___spec__3(x_130, x_111, x_128); +lean_ctor_set(x_127, 3, x_131); +x_114 = x_128; +x_115 = x_127; +goto block_122; } else { -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; -x_129 = lean_ctor_get(x_124, 0); -x_130 = lean_ctor_get(x_124, 1); -x_131 = lean_ctor_get(x_124, 2); -x_132 = lean_ctor_get(x_124, 3); -x_133 = lean_ctor_get(x_124, 4); -x_134 = lean_ctor_get(x_124, 5); -x_135 = lean_ctor_get(x_124, 6); -x_136 = lean_ctor_get(x_124, 7); -x_137 = lean_ctor_get(x_124, 8); +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; +x_132 = lean_ctor_get(x_127, 0); +x_133 = lean_ctor_get(x_127, 1); +x_134 = lean_ctor_get(x_127, 2); +x_135 = lean_ctor_get(x_127, 3); +x_136 = lean_ctor_get(x_127, 4); +x_137 = lean_ctor_get(x_127, 5); +x_138 = lean_ctor_get(x_127, 6); +x_139 = lean_ctor_get(x_127, 7); +x_140 = lean_ctor_get(x_127, 8); +x_141 = lean_ctor_get(x_127, 9); +lean_inc(x_141); +lean_inc(x_140); +lean_inc(x_139); +lean_inc(x_138); lean_inc(x_137); lean_inc(x_136); lean_inc(x_135); lean_inc(x_134); lean_inc(x_133); lean_inc(x_132); -lean_inc(x_131); -lean_inc(x_130); -lean_inc(x_129); -lean_dec(x_124); -lean_inc(x_125); -x_138 = l_Std_HashMapImp_insert___at_Lean_Closure_visitLevel___spec__3(x_131, x_108, x_125); -x_139 = lean_alloc_ctor(0, 9, 0); -lean_ctor_set(x_139, 0, x_129); -lean_ctor_set(x_139, 1, x_130); -lean_ctor_set(x_139, 2, x_138); -lean_ctor_set(x_139, 3, x_132); -lean_ctor_set(x_139, 4, x_133); -lean_ctor_set(x_139, 5, x_134); -lean_ctor_set(x_139, 6, x_135); -lean_ctor_set(x_139, 7, x_136); -lean_ctor_set(x_139, 8, x_137); -x_111 = x_125; -x_112 = x_139; -goto block_119; +lean_dec(x_127); +lean_inc(x_128); +x_142 = l_Std_HashMapImp_insert___at_Lean_Closure_visitLevel___spec__3(x_135, x_111, x_128); +x_143 = lean_alloc_ctor(0, 10, 0); +lean_ctor_set(x_143, 0, x_132); +lean_ctor_set(x_143, 1, x_133); +lean_ctor_set(x_143, 2, x_134); +lean_ctor_set(x_143, 3, x_142); +lean_ctor_set(x_143, 4, x_136); +lean_ctor_set(x_143, 5, x_137); +lean_ctor_set(x_143, 6, x_138); +lean_ctor_set(x_143, 7, x_139); +lean_ctor_set(x_143, 8, x_140); +lean_ctor_set(x_143, 9, x_141); +x_114 = x_128; +x_115 = x_143; +goto block_122; } } else { -lean_object* x_140; -lean_dec(x_108); -lean_dec(x_2); -x_140 = lean_ctor_get(x_122, 0); -lean_inc(x_140); -lean_dec(x_122); -x_111 = x_140; -x_112 = x_110; -goto block_119; +lean_object* x_144; +lean_dec(x_111); +x_144 = lean_ctor_get(x_125, 0); +lean_inc(x_144); +lean_dec(x_125); +x_114 = x_144; +x_115 = x_113; +goto block_122; } } } -block_168: +block_173: { -lean_object* x_148; lean_object* x_149; -lean_dec(x_147); -x_148 = lean_ctor_get(x_3, 2); -lean_inc(x_148); -x_149 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitLevel___spec__1(x_148, x_107); -lean_dec(x_148); -if (lean_obj_tag(x_149) == 0) -{ -lean_object* x_150; lean_object* x_151; lean_object* x_152; uint8_t x_153; -lean_inc(x_2); -lean_inc(x_107); -x_150 = l_Lean_Closure_collectLevelAux___main(x_107, x_2, x_3); -x_151 = lean_ctor_get(x_150, 1); -lean_inc(x_151); -x_152 = lean_ctor_get(x_150, 0); +lean_object* x_152; lean_object* x_153; +lean_dec(x_151); +x_152 = lean_ctor_get(x_3, 3); lean_inc(x_152); -lean_dec(x_150); -x_153 = !lean_is_exclusive(x_151); -if (x_153 == 0) +x_153 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitLevel___spec__1(x_152, x_110); +lean_dec(x_152); +if (lean_obj_tag(x_153) == 0) { -lean_object* x_154; lean_object* x_155; -x_154 = lean_ctor_get(x_151, 2); -lean_inc(x_152); -x_155 = l_Std_HashMapImp_insert___at_Lean_Closure_visitLevel___spec__3(x_154, x_107, x_152); -lean_ctor_set(x_151, 2, x_155); -x_109 = x_152; -x_110 = x_151; -goto block_146; +lean_object* x_154; lean_object* x_155; lean_object* x_156; uint8_t x_157; +lean_inc(x_110); +x_154 = l_Lean_Closure_collectLevelAux___main(x_110, x_2, x_3); +x_155 = lean_ctor_get(x_154, 1); +lean_inc(x_155); +x_156 = lean_ctor_get(x_154, 0); +lean_inc(x_156); +lean_dec(x_154); +x_157 = !lean_is_exclusive(x_155); +if (x_157 == 0) +{ +lean_object* x_158; lean_object* x_159; +x_158 = lean_ctor_get(x_155, 3); +lean_inc(x_156); +x_159 = l_Std_HashMapImp_insert___at_Lean_Closure_visitLevel___spec__3(x_158, x_110, x_156); +lean_ctor_set(x_155, 3, x_159); +x_112 = x_156; +x_113 = x_155; +goto block_150; } else { -lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; -x_156 = lean_ctor_get(x_151, 0); -x_157 = lean_ctor_get(x_151, 1); -x_158 = lean_ctor_get(x_151, 2); -x_159 = lean_ctor_get(x_151, 3); -x_160 = lean_ctor_get(x_151, 4); -x_161 = lean_ctor_get(x_151, 5); -x_162 = lean_ctor_get(x_151, 6); -x_163 = lean_ctor_get(x_151, 7); -x_164 = lean_ctor_get(x_151, 8); +lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; +x_160 = lean_ctor_get(x_155, 0); +x_161 = lean_ctor_get(x_155, 1); +x_162 = lean_ctor_get(x_155, 2); +x_163 = lean_ctor_get(x_155, 3); +x_164 = lean_ctor_get(x_155, 4); +x_165 = lean_ctor_get(x_155, 5); +x_166 = lean_ctor_get(x_155, 6); +x_167 = lean_ctor_get(x_155, 7); +x_168 = lean_ctor_get(x_155, 8); +x_169 = lean_ctor_get(x_155, 9); +lean_inc(x_169); +lean_inc(x_168); +lean_inc(x_167); +lean_inc(x_166); +lean_inc(x_165); lean_inc(x_164); lean_inc(x_163); lean_inc(x_162); lean_inc(x_161); lean_inc(x_160); -lean_inc(x_159); -lean_inc(x_158); -lean_inc(x_157); +lean_dec(x_155); lean_inc(x_156); -lean_dec(x_151); -lean_inc(x_152); -x_165 = l_Std_HashMapImp_insert___at_Lean_Closure_visitLevel___spec__3(x_158, x_107, x_152); -x_166 = lean_alloc_ctor(0, 9, 0); -lean_ctor_set(x_166, 0, x_156); -lean_ctor_set(x_166, 1, x_157); -lean_ctor_set(x_166, 2, x_165); -lean_ctor_set(x_166, 3, x_159); -lean_ctor_set(x_166, 4, x_160); -lean_ctor_set(x_166, 5, x_161); -lean_ctor_set(x_166, 6, x_162); -lean_ctor_set(x_166, 7, x_163); -lean_ctor_set(x_166, 8, x_164); -x_109 = x_152; -x_110 = x_166; -goto block_146; +x_170 = l_Std_HashMapImp_insert___at_Lean_Closure_visitLevel___spec__3(x_163, x_110, x_156); +x_171 = lean_alloc_ctor(0, 10, 0); +lean_ctor_set(x_171, 0, x_160); +lean_ctor_set(x_171, 1, x_161); +lean_ctor_set(x_171, 2, x_162); +lean_ctor_set(x_171, 3, x_170); +lean_ctor_set(x_171, 4, x_164); +lean_ctor_set(x_171, 5, x_165); +lean_ctor_set(x_171, 6, x_166); +lean_ctor_set(x_171, 7, x_167); +lean_ctor_set(x_171, 8, x_168); +lean_ctor_set(x_171, 9, x_169); +x_112 = x_156; +x_113 = x_171; +goto block_150; } } else { -lean_object* x_167; -lean_dec(x_107); -x_167 = lean_ctor_get(x_149, 0); -lean_inc(x_167); -lean_dec(x_149); -x_109 = x_167; -x_110 = x_3; -goto block_146; +lean_object* x_172; +lean_dec(x_110); +x_172 = lean_ctor_get(x_153, 0); +lean_inc(x_172); +lean_dec(x_153); +x_112 = x_172; +x_113 = x_3; +goto block_150; } } } -case 4: -{ -lean_object* x_173; -x_173 = l_Lean_Closure_mkNewLevelParam(x_1, x_2, x_3); -lean_dec(x_2); -return x_173; -} default: { -lean_object* x_174; lean_object* x_175; lean_object* x_176; -x_174 = lean_ctor_get(x_1, 0); -lean_inc(x_174); -x_175 = lean_ctor_get(x_2, 0); -lean_inc(x_175); -x_176 = lean_metavar_ctx_get_level_assignment(x_175, x_174); -if (lean_obj_tag(x_176) == 0) -{ -lean_object* x_177; -x_177 = l_Lean_Closure_mkNewLevelParam(x_1, x_2, x_3); -lean_dec(x_2); -return x_177; -} -else -{ -lean_object* x_178; lean_object* x_179; uint8_t x_219; -lean_dec(x_1); -x_178 = lean_ctor_get(x_176, 0); -lean_inc(x_178); -lean_dec(x_176); -x_219 = l_Lean_Level_hasMVar(x_178); -if (x_219 == 0) -{ -uint8_t x_220; -x_220 = l_Lean_Level_hasParam(x_178); -if (x_220 == 0) -{ -lean_object* x_221; -lean_dec(x_2); -x_221 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_221, 0, x_178); -lean_ctor_set(x_221, 1, x_3); -return x_221; -} -else -{ -lean_object* x_222; -x_222 = lean_box(0); -x_179 = x_222; -goto block_218; -} -} -else -{ -lean_object* x_223; -x_223 = lean_box(0); -x_179 = x_223; -goto block_218; -} -block_218: -{ -lean_object* x_180; lean_object* x_181; -lean_dec(x_179); -x_180 = lean_ctor_get(x_3, 2); -lean_inc(x_180); -x_181 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitLevel___spec__1(x_180, x_178); -lean_dec(x_180); -if (lean_obj_tag(x_181) == 0) -{ -lean_object* x_182; uint8_t x_183; -lean_inc(x_178); -x_182 = l_Lean_Closure_collectLevelAux___main(x_178, x_2, x_3); -x_183 = !lean_is_exclusive(x_182); -if (x_183 == 0) -{ -lean_object* x_184; uint8_t x_185; -x_184 = lean_ctor_get(x_182, 1); -x_185 = !lean_is_exclusive(x_184); -if (x_185 == 0) -{ -lean_object* x_186; lean_object* x_187; lean_object* x_188; -x_186 = lean_ctor_get(x_182, 0); -x_187 = lean_ctor_get(x_184, 2); -lean_inc(x_186); -x_188 = l_Std_HashMapImp_insert___at_Lean_Closure_visitLevel___spec__3(x_187, x_178, x_186); -lean_ctor_set(x_184, 2, x_188); -return x_182; -} -else -{ -lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; -x_189 = lean_ctor_get(x_182, 0); -x_190 = lean_ctor_get(x_184, 0); -x_191 = lean_ctor_get(x_184, 1); -x_192 = lean_ctor_get(x_184, 2); -x_193 = lean_ctor_get(x_184, 3); -x_194 = lean_ctor_get(x_184, 4); -x_195 = lean_ctor_get(x_184, 5); -x_196 = lean_ctor_get(x_184, 6); -x_197 = lean_ctor_get(x_184, 7); -x_198 = lean_ctor_get(x_184, 8); -lean_inc(x_198); -lean_inc(x_197); -lean_inc(x_196); -lean_inc(x_195); -lean_inc(x_194); -lean_inc(x_193); -lean_inc(x_192); -lean_inc(x_191); -lean_inc(x_190); -lean_dec(x_184); -lean_inc(x_189); -x_199 = l_Std_HashMapImp_insert___at_Lean_Closure_visitLevel___spec__3(x_192, x_178, x_189); -x_200 = lean_alloc_ctor(0, 9, 0); -lean_ctor_set(x_200, 0, x_190); -lean_ctor_set(x_200, 1, x_191); -lean_ctor_set(x_200, 2, x_199); -lean_ctor_set(x_200, 3, x_193); -lean_ctor_set(x_200, 4, x_194); -lean_ctor_set(x_200, 5, x_195); -lean_ctor_set(x_200, 6, x_196); -lean_ctor_set(x_200, 7, x_197); -lean_ctor_set(x_200, 8, x_198); -lean_ctor_set(x_182, 1, x_200); -return x_182; -} -} -else -{ -lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; -x_201 = lean_ctor_get(x_182, 1); -x_202 = lean_ctor_get(x_182, 0); -lean_inc(x_201); -lean_inc(x_202); -lean_dec(x_182); -x_203 = lean_ctor_get(x_201, 0); -lean_inc(x_203); -x_204 = lean_ctor_get(x_201, 1); -lean_inc(x_204); -x_205 = lean_ctor_get(x_201, 2); -lean_inc(x_205); -x_206 = lean_ctor_get(x_201, 3); -lean_inc(x_206); -x_207 = lean_ctor_get(x_201, 4); -lean_inc(x_207); -x_208 = lean_ctor_get(x_201, 5); -lean_inc(x_208); -x_209 = lean_ctor_get(x_201, 6); -lean_inc(x_209); -x_210 = lean_ctor_get(x_201, 7); -lean_inc(x_210); -x_211 = lean_ctor_get(x_201, 8); -lean_inc(x_211); -if (lean_is_exclusive(x_201)) { - lean_ctor_release(x_201, 0); - lean_ctor_release(x_201, 1); - lean_ctor_release(x_201, 2); - lean_ctor_release(x_201, 3); - lean_ctor_release(x_201, 4); - lean_ctor_release(x_201, 5); - lean_ctor_release(x_201, 6); - lean_ctor_release(x_201, 7); - lean_ctor_release(x_201, 8); - x_212 = x_201; -} else { - lean_dec_ref(x_201); - x_212 = lean_box(0); -} -lean_inc(x_202); -x_213 = l_Std_HashMapImp_insert___at_Lean_Closure_visitLevel___spec__3(x_205, x_178, x_202); -if (lean_is_scalar(x_212)) { - x_214 = lean_alloc_ctor(0, 9, 0); -} else { - x_214 = x_212; -} -lean_ctor_set(x_214, 0, x_203); -lean_ctor_set(x_214, 1, x_204); -lean_ctor_set(x_214, 2, x_213); -lean_ctor_set(x_214, 3, x_206); -lean_ctor_set(x_214, 4, x_207); -lean_ctor_set(x_214, 5, x_208); -lean_ctor_set(x_214, 6, x_209); -lean_ctor_set(x_214, 7, x_210); -lean_ctor_set(x_214, 8, x_211); -x_215 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_215, 0, x_202); -lean_ctor_set(x_215, 1, x_214); -return x_215; -} -} -else -{ -lean_object* x_216; lean_object* x_217; -lean_dec(x_178); -lean_dec(x_2); -x_216 = lean_ctor_get(x_181, 0); -lean_inc(x_216); -lean_dec(x_181); -x_217 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_217, 0, x_216); -lean_ctor_set(x_217, 1, x_3); -return x_217; -} -} -} +lean_object* x_178; +x_178 = l_Lean_Closure_mkNewLevelParam(x_1, x_2, x_3); +return x_178; } } block_12: @@ -1722,6 +1653,15 @@ return x_11; } } } +lean_object* l_Lean_Closure_collectLevelAux___main___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; +x_4 = l_Lean_Closure_collectLevelAux___main(x_1, x_2, x_3); +lean_dec(x_2); +return x_4; +} +} lean_object* l_Lean_Closure_collectLevelAux(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { @@ -1730,44 +1670,52 @@ x_4 = l_Lean_Closure_collectLevelAux___main(x_1, x_2, x_3); return x_4; } } +lean_object* l_Lean_Closure_collectLevelAux___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; +x_4 = l_Lean_Closure_collectLevelAux(x_1, x_2, x_3); +lean_dec(x_2); +return x_4; +} +} lean_object* l_Lean_Closure_collectLevel(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { -lean_object* x_4; uint8_t x_44; -x_44 = l_Lean_Level_hasMVar(x_1); -if (x_44 == 0) +lean_object* x_4; uint8_t x_46; +x_46 = l_Lean_Level_hasMVar(x_1); +if (x_46 == 0) { -uint8_t x_45; -x_45 = l_Lean_Level_hasParam(x_1); -if (x_45 == 0) -{ -lean_object* x_46; -lean_dec(x_2); -x_46 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_46, 0, x_1); -lean_ctor_set(x_46, 1, x_3); -return x_46; -} -else -{ -lean_object* x_47; -x_47 = lean_box(0); -x_4 = x_47; -goto block_43; -} -} -else +uint8_t x_47; +x_47 = l_Lean_Level_hasParam(x_1); +if (x_47 == 0) { lean_object* x_48; -x_48 = lean_box(0); -x_4 = x_48; -goto block_43; +x_48 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_48, 0, x_1); +lean_ctor_set(x_48, 1, x_3); +return x_48; } -block_43: +else +{ +lean_object* x_49; +x_49 = lean_box(0); +x_4 = x_49; +goto block_45; +} +} +else +{ +lean_object* x_50; +x_50 = lean_box(0); +x_4 = x_50; +goto block_45; +} +block_45: { lean_object* x_5; lean_object* x_6; lean_dec(x_4); -x_5 = lean_ctor_get(x_3, 2); +x_5 = lean_ctor_get(x_3, 3); lean_inc(x_5); x_6 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitLevel___spec__1(x_5, x_1); lean_dec(x_5); @@ -1786,15 +1734,15 @@ if (x_10 == 0) { lean_object* x_11; lean_object* x_12; lean_object* x_13; x_11 = lean_ctor_get(x_7, 0); -x_12 = lean_ctor_get(x_9, 2); +x_12 = lean_ctor_get(x_9, 3); lean_inc(x_11); x_13 = l_Std_HashMapImp_insert___at_Lean_Closure_visitLevel___spec__3(x_12, x_1, x_11); -lean_ctor_set(x_9, 2, x_13); +lean_ctor_set(x_9, 3, x_13); return x_7; } else { -lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; 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_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; x_14 = lean_ctor_get(x_7, 0); x_15 = lean_ctor_get(x_9, 0); x_16 = lean_ctor_get(x_9, 1); @@ -1805,6 +1753,8 @@ x_20 = lean_ctor_get(x_9, 5); x_21 = lean_ctor_get(x_9, 6); x_22 = lean_ctor_get(x_9, 7); x_23 = lean_ctor_get(x_9, 8); +x_24 = lean_ctor_get(x_9, 9); +lean_inc(x_24); lean_inc(x_23); lean_inc(x_22); lean_inc(x_21); @@ -1816,100 +1766,113 @@ lean_inc(x_16); lean_inc(x_15); lean_dec(x_9); lean_inc(x_14); -x_24 = l_Std_HashMapImp_insert___at_Lean_Closure_visitLevel___spec__3(x_17, x_1, x_14); -x_25 = lean_alloc_ctor(0, 9, 0); -lean_ctor_set(x_25, 0, x_15); -lean_ctor_set(x_25, 1, x_16); -lean_ctor_set(x_25, 2, x_24); -lean_ctor_set(x_25, 3, x_18); -lean_ctor_set(x_25, 4, x_19); -lean_ctor_set(x_25, 5, x_20); -lean_ctor_set(x_25, 6, x_21); -lean_ctor_set(x_25, 7, x_22); -lean_ctor_set(x_25, 8, x_23); -lean_ctor_set(x_7, 1, x_25); +x_25 = l_Std_HashMapImp_insert___at_Lean_Closure_visitLevel___spec__3(x_18, x_1, x_14); +x_26 = lean_alloc_ctor(0, 10, 0); +lean_ctor_set(x_26, 0, x_15); +lean_ctor_set(x_26, 1, x_16); +lean_ctor_set(x_26, 2, x_17); +lean_ctor_set(x_26, 3, x_25); +lean_ctor_set(x_26, 4, x_19); +lean_ctor_set(x_26, 5, x_20); +lean_ctor_set(x_26, 6, x_21); +lean_ctor_set(x_26, 7, x_22); +lean_ctor_set(x_26, 8, x_23); +lean_ctor_set(x_26, 9, x_24); +lean_ctor_set(x_7, 1, x_26); return x_7; } } else { -lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; -x_26 = lean_ctor_get(x_7, 1); -x_27 = lean_ctor_get(x_7, 0); -lean_inc(x_26); +lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; +x_27 = lean_ctor_get(x_7, 1); +x_28 = lean_ctor_get(x_7, 0); lean_inc(x_27); -lean_dec(x_7); -x_28 = lean_ctor_get(x_26, 0); lean_inc(x_28); -x_29 = lean_ctor_get(x_26, 1); +lean_dec(x_7); +x_29 = lean_ctor_get(x_27, 0); lean_inc(x_29); -x_30 = lean_ctor_get(x_26, 2); +x_30 = lean_ctor_get(x_27, 1); lean_inc(x_30); -x_31 = lean_ctor_get(x_26, 3); +x_31 = lean_ctor_get(x_27, 2); lean_inc(x_31); -x_32 = lean_ctor_get(x_26, 4); +x_32 = lean_ctor_get(x_27, 3); lean_inc(x_32); -x_33 = lean_ctor_get(x_26, 5); +x_33 = lean_ctor_get(x_27, 4); lean_inc(x_33); -x_34 = lean_ctor_get(x_26, 6); +x_34 = lean_ctor_get(x_27, 5); lean_inc(x_34); -x_35 = lean_ctor_get(x_26, 7); +x_35 = lean_ctor_get(x_27, 6); lean_inc(x_35); -x_36 = lean_ctor_get(x_26, 8); +x_36 = lean_ctor_get(x_27, 7); lean_inc(x_36); -if (lean_is_exclusive(x_26)) { - lean_ctor_release(x_26, 0); - lean_ctor_release(x_26, 1); - lean_ctor_release(x_26, 2); - lean_ctor_release(x_26, 3); - lean_ctor_release(x_26, 4); - lean_ctor_release(x_26, 5); - lean_ctor_release(x_26, 6); - lean_ctor_release(x_26, 7); - lean_ctor_release(x_26, 8); - x_37 = x_26; +x_37 = lean_ctor_get(x_27, 8); +lean_inc(x_37); +x_38 = lean_ctor_get(x_27, 9); +lean_inc(x_38); +if (lean_is_exclusive(x_27)) { + lean_ctor_release(x_27, 0); + lean_ctor_release(x_27, 1); + lean_ctor_release(x_27, 2); + lean_ctor_release(x_27, 3); + lean_ctor_release(x_27, 4); + lean_ctor_release(x_27, 5); + lean_ctor_release(x_27, 6); + lean_ctor_release(x_27, 7); + lean_ctor_release(x_27, 8); + lean_ctor_release(x_27, 9); + x_39 = x_27; } else { - lean_dec_ref(x_26); - x_37 = lean_box(0); + lean_dec_ref(x_27); + x_39 = lean_box(0); } -lean_inc(x_27); -x_38 = l_Std_HashMapImp_insert___at_Lean_Closure_visitLevel___spec__3(x_30, x_1, x_27); -if (lean_is_scalar(x_37)) { - x_39 = lean_alloc_ctor(0, 9, 0); +lean_inc(x_28); +x_40 = l_Std_HashMapImp_insert___at_Lean_Closure_visitLevel___spec__3(x_32, x_1, x_28); +if (lean_is_scalar(x_39)) { + x_41 = lean_alloc_ctor(0, 10, 0); } else { - x_39 = x_37; + x_41 = x_39; } -lean_ctor_set(x_39, 0, x_28); -lean_ctor_set(x_39, 1, x_29); -lean_ctor_set(x_39, 2, x_38); -lean_ctor_set(x_39, 3, x_31); -lean_ctor_set(x_39, 4, x_32); -lean_ctor_set(x_39, 5, x_33); -lean_ctor_set(x_39, 6, x_34); -lean_ctor_set(x_39, 7, x_35); -lean_ctor_set(x_39, 8, x_36); -x_40 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_40, 0, x_27); -lean_ctor_set(x_40, 1, x_39); -return x_40; +lean_ctor_set(x_41, 0, x_29); +lean_ctor_set(x_41, 1, x_30); +lean_ctor_set(x_41, 2, x_31); +lean_ctor_set(x_41, 3, x_40); +lean_ctor_set(x_41, 4, x_33); +lean_ctor_set(x_41, 5, x_34); +lean_ctor_set(x_41, 6, x_35); +lean_ctor_set(x_41, 7, x_36); +lean_ctor_set(x_41, 8, x_37); +lean_ctor_set(x_41, 9, x_38); +x_42 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_42, 0, x_28); +lean_ctor_set(x_42, 1, x_41); +return x_42; } } else { -lean_object* x_41; lean_object* x_42; -lean_dec(x_2); +lean_object* x_43; lean_object* x_44; lean_dec(x_1); -x_41 = lean_ctor_get(x_6, 0); -lean_inc(x_41); +x_43 = lean_ctor_get(x_6, 0); +lean_inc(x_43); lean_dec(x_6); -x_42 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_42, 0, x_41); -lean_ctor_set(x_42, 1, x_3); -return x_42; +x_44 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_44, 0, x_43); +lean_ctor_set(x_44, 1, x_3); +return x_44; } } } } +lean_object* l_Lean_Closure_collectLevel___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; +x_4 = l_Lean_Closure_collectLevel(x_1, x_2, x_3); +lean_dec(x_2); +return x_4; +} +} lean_object* l_Lean_Closure_mkFreshFVarId___rarg(lean_object* x_1) { _start: { @@ -1918,7 +1881,7 @@ x_2 = !lean_is_exclusive(x_1); if (x_2 == 0) { lean_object* x_3; uint8_t x_4; -x_3 = lean_ctor_get(x_1, 1); +x_3 = lean_ctor_get(x_1, 2); x_4 = !lean_is_exclusive(x_3); if (x_4 == 0) { @@ -1954,7 +1917,7 @@ lean_dec(x_12); x_16 = lean_alloc_ctor(0, 2, 0); lean_ctor_set(x_16, 0, x_11); lean_ctor_set(x_16, 1, x_15); -lean_ctor_set(x_1, 1, x_16); +lean_ctor_set(x_1, 2, x_16); x_17 = lean_alloc_ctor(0, 2, 0); lean_ctor_set(x_17, 0, x_13); lean_ctor_set(x_17, 1, x_1); @@ -1963,65 +1926,68 @@ return x_17; } else { -lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; -x_18 = lean_ctor_get(x_1, 1); +lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; +x_18 = lean_ctor_get(x_1, 2); x_19 = lean_ctor_get(x_1, 0); -x_20 = lean_ctor_get(x_1, 2); +x_20 = lean_ctor_get(x_1, 1); x_21 = lean_ctor_get(x_1, 3); x_22 = lean_ctor_get(x_1, 4); x_23 = lean_ctor_get(x_1, 5); x_24 = lean_ctor_get(x_1, 6); x_25 = lean_ctor_get(x_1, 7); x_26 = lean_ctor_get(x_1, 8); +x_27 = lean_ctor_get(x_1, 9); +lean_inc(x_27); lean_inc(x_26); lean_inc(x_25); lean_inc(x_24); lean_inc(x_23); lean_inc(x_22); lean_inc(x_21); -lean_inc(x_20); lean_inc(x_18); +lean_inc(x_20); lean_inc(x_19); lean_dec(x_1); -x_27 = lean_ctor_get(x_18, 0); -lean_inc(x_27); -x_28 = lean_ctor_get(x_18, 1); +x_28 = lean_ctor_get(x_18, 0); lean_inc(x_28); +x_29 = lean_ctor_get(x_18, 1); +lean_inc(x_29); if (lean_is_exclusive(x_18)) { lean_ctor_release(x_18, 0); lean_ctor_release(x_18, 1); - x_29 = x_18; + x_30 = x_18; } else { lean_dec_ref(x_18); - x_29 = lean_box(0); + x_30 = lean_box(0); } +lean_inc(x_29); lean_inc(x_28); -lean_inc(x_27); -x_30 = lean_name_mk_numeral(x_27, x_28); -x_31 = lean_unsigned_to_nat(1u); -x_32 = lean_nat_add(x_28, x_31); -lean_dec(x_28); -if (lean_is_scalar(x_29)) { - x_33 = lean_alloc_ctor(0, 2, 0); +x_31 = lean_name_mk_numeral(x_28, x_29); +x_32 = lean_unsigned_to_nat(1u); +x_33 = lean_nat_add(x_29, x_32); +lean_dec(x_29); +if (lean_is_scalar(x_30)) { + x_34 = lean_alloc_ctor(0, 2, 0); } else { - x_33 = x_29; + x_34 = x_30; } -lean_ctor_set(x_33, 0, x_27); -lean_ctor_set(x_33, 1, x_32); -x_34 = lean_alloc_ctor(0, 9, 0); -lean_ctor_set(x_34, 0, x_19); +lean_ctor_set(x_34, 0, x_28); lean_ctor_set(x_34, 1, x_33); -lean_ctor_set(x_34, 2, x_20); -lean_ctor_set(x_34, 3, x_21); -lean_ctor_set(x_34, 4, x_22); -lean_ctor_set(x_34, 5, x_23); -lean_ctor_set(x_34, 6, x_24); -lean_ctor_set(x_34, 7, x_25); -lean_ctor_set(x_34, 8, x_26); -x_35 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_35, 0, x_30); -lean_ctor_set(x_35, 1, x_34); -return x_35; +x_35 = lean_alloc_ctor(0, 10, 0); +lean_ctor_set(x_35, 0, x_19); +lean_ctor_set(x_35, 1, x_20); +lean_ctor_set(x_35, 2, x_34); +lean_ctor_set(x_35, 3, x_21); +lean_ctor_set(x_35, 4, x_22); +lean_ctor_set(x_35, 5, x_23); +lean_ctor_set(x_35, 6, x_24); +lean_ctor_set(x_35, 7, x_25); +lean_ctor_set(x_35, 8, x_26); +lean_ctor_set(x_35, 9, x_27); +x_36 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_36, 0, x_31); +lean_ctor_set(x_36, 1, x_35); +return x_36; } } } @@ -2068,14 +2034,14 @@ x_2 = !lean_is_exclusive(x_1); if (x_2 == 0) { lean_object* x_3; lean_object* x_4; lean_object* x_5; lean_object* x_6; lean_object* x_7; lean_object* x_8; -x_3 = lean_ctor_get(x_1, 7); +x_3 = lean_ctor_get(x_1, 8); x_4 = l_Lean_Closure_mkNextUserName___rarg___closed__2; lean_inc(x_3); x_5 = l_Lean_Name_appendIndexAfter(x_4, x_3); x_6 = lean_unsigned_to_nat(1u); x_7 = lean_nat_add(x_3, x_6); lean_dec(x_3); -lean_ctor_set(x_1, 7, x_7); +lean_ctor_set(x_1, 8, x_7); x_8 = lean_alloc_ctor(0, 2, 0); lean_ctor_set(x_8, 0, x_5); lean_ctor_set(x_8, 1, x_1); @@ -2083,7 +2049,7 @@ return x_8; } else { -lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; +lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; x_9 = lean_ctor_get(x_1, 0); x_10 = lean_ctor_get(x_1, 1); x_11 = lean_ctor_get(x_1, 2); @@ -2093,6 +2059,8 @@ x_14 = lean_ctor_get(x_1, 5); x_15 = lean_ctor_get(x_1, 6); x_16 = lean_ctor_get(x_1, 7); x_17 = lean_ctor_get(x_1, 8); +x_18 = lean_ctor_get(x_1, 9); +lean_inc(x_18); lean_inc(x_17); lean_inc(x_16); lean_inc(x_15); @@ -2103,26 +2071,27 @@ lean_inc(x_11); lean_inc(x_10); lean_inc(x_9); lean_dec(x_1); -x_18 = l_Lean_Closure_mkNextUserName___rarg___closed__2; -lean_inc(x_16); -x_19 = l_Lean_Name_appendIndexAfter(x_18, x_16); -x_20 = lean_unsigned_to_nat(1u); -x_21 = lean_nat_add(x_16, x_20); -lean_dec(x_16); -x_22 = lean_alloc_ctor(0, 9, 0); -lean_ctor_set(x_22, 0, x_9); -lean_ctor_set(x_22, 1, x_10); -lean_ctor_set(x_22, 2, x_11); -lean_ctor_set(x_22, 3, x_12); -lean_ctor_set(x_22, 4, x_13); -lean_ctor_set(x_22, 5, x_14); -lean_ctor_set(x_22, 6, x_15); -lean_ctor_set(x_22, 7, x_21); -lean_ctor_set(x_22, 8, x_17); -x_23 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_23, 0, x_19); -lean_ctor_set(x_23, 1, x_22); -return x_23; +x_19 = l_Lean_Closure_mkNextUserName___rarg___closed__2; +lean_inc(x_17); +x_20 = l_Lean_Name_appendIndexAfter(x_19, x_17); +x_21 = lean_unsigned_to_nat(1u); +x_22 = lean_nat_add(x_17, x_21); +lean_dec(x_17); +x_23 = lean_alloc_ctor(0, 10, 0); +lean_ctor_set(x_23, 0, x_9); +lean_ctor_set(x_23, 1, x_10); +lean_ctor_set(x_23, 2, x_11); +lean_ctor_set(x_23, 3, x_12); +lean_ctor_set(x_23, 4, x_13); +lean_ctor_set(x_23, 5, x_14); +lean_ctor_set(x_23, 6, x_15); +lean_ctor_set(x_23, 7, x_16); +lean_ctor_set(x_23, 8, x_22); +lean_ctor_set(x_23, 9, x_18); +x_24 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_24, 0, x_20); +lean_ctor_set(x_24, 1, x_23); +return x_24; } } } @@ -2197,15 +2166,15 @@ x_14 = !lean_is_exclusive(x_12); if (x_14 == 0) { lean_object* x_15; lean_object* x_16; -x_15 = lean_ctor_get(x_12, 0); +x_15 = lean_ctor_get(x_12, 1); x_16 = lean_local_ctx_mk_local_decl(x_15, x_11, x_7, x_2, x_3); -lean_ctor_set(x_12, 0, x_16); +lean_ctor_set(x_12, 1, x_16); lean_ctor_set(x_9, 0, x_13); return x_9; } else { -lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; +lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; x_17 = lean_ctor_get(x_12, 0); x_18 = lean_ctor_get(x_12, 1); x_19 = lean_ctor_get(x_12, 2); @@ -2215,6 +2184,8 @@ x_22 = lean_ctor_get(x_12, 5); x_23 = lean_ctor_get(x_12, 6); x_24 = lean_ctor_get(x_12, 7); x_25 = lean_ctor_get(x_12, 8); +x_26 = lean_ctor_get(x_12, 9); +lean_inc(x_26); lean_inc(x_25); lean_inc(x_24); lean_inc(x_23); @@ -2225,84 +2196,89 @@ lean_inc(x_19); lean_inc(x_18); lean_inc(x_17); lean_dec(x_12); -x_26 = lean_local_ctx_mk_local_decl(x_17, x_11, x_7, x_2, x_3); -x_27 = lean_alloc_ctor(0, 9, 0); -lean_ctor_set(x_27, 0, x_26); -lean_ctor_set(x_27, 1, x_18); -lean_ctor_set(x_27, 2, x_19); -lean_ctor_set(x_27, 3, x_20); -lean_ctor_set(x_27, 4, x_21); -lean_ctor_set(x_27, 5, x_22); -lean_ctor_set(x_27, 6, x_23); -lean_ctor_set(x_27, 7, x_24); -lean_ctor_set(x_27, 8, x_25); -lean_ctor_set(x_9, 1, x_27); +x_27 = lean_local_ctx_mk_local_decl(x_18, x_11, x_7, x_2, x_3); +x_28 = lean_alloc_ctor(0, 10, 0); +lean_ctor_set(x_28, 0, x_17); +lean_ctor_set(x_28, 1, x_27); +lean_ctor_set(x_28, 2, x_19); +lean_ctor_set(x_28, 3, x_20); +lean_ctor_set(x_28, 4, x_21); +lean_ctor_set(x_28, 5, x_22); +lean_ctor_set(x_28, 6, x_23); +lean_ctor_set(x_28, 7, x_24); +lean_ctor_set(x_28, 8, x_25); +lean_ctor_set(x_28, 9, x_26); +lean_ctor_set(x_9, 1, x_28); lean_ctor_set(x_9, 0, x_13); return x_9; } } else { -lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; -x_28 = lean_ctor_get(x_9, 0); -x_29 = lean_ctor_get(x_9, 1); +lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; +x_29 = lean_ctor_get(x_9, 0); +x_30 = lean_ctor_get(x_9, 1); +lean_inc(x_30); lean_inc(x_29); -lean_inc(x_28); lean_dec(x_9); -lean_inc(x_28); -x_30 = l_Lean_mkFVar(x_28); -x_31 = lean_ctor_get(x_29, 0); -lean_inc(x_31); -x_32 = lean_ctor_get(x_29, 1); +lean_inc(x_29); +x_31 = l_Lean_mkFVar(x_29); +x_32 = lean_ctor_get(x_30, 0); lean_inc(x_32); -x_33 = lean_ctor_get(x_29, 2); +x_33 = lean_ctor_get(x_30, 1); lean_inc(x_33); -x_34 = lean_ctor_get(x_29, 3); +x_34 = lean_ctor_get(x_30, 2); lean_inc(x_34); -x_35 = lean_ctor_get(x_29, 4); +x_35 = lean_ctor_get(x_30, 3); lean_inc(x_35); -x_36 = lean_ctor_get(x_29, 5); +x_36 = lean_ctor_get(x_30, 4); lean_inc(x_36); -x_37 = lean_ctor_get(x_29, 6); +x_37 = lean_ctor_get(x_30, 5); lean_inc(x_37); -x_38 = lean_ctor_get(x_29, 7); +x_38 = lean_ctor_get(x_30, 6); lean_inc(x_38); -x_39 = lean_ctor_get(x_29, 8); +x_39 = lean_ctor_get(x_30, 7); lean_inc(x_39); -if (lean_is_exclusive(x_29)) { - lean_ctor_release(x_29, 0); - lean_ctor_release(x_29, 1); - lean_ctor_release(x_29, 2); - lean_ctor_release(x_29, 3); - lean_ctor_release(x_29, 4); - lean_ctor_release(x_29, 5); - lean_ctor_release(x_29, 6); - lean_ctor_release(x_29, 7); - lean_ctor_release(x_29, 8); - x_40 = x_29; +x_40 = lean_ctor_get(x_30, 8); +lean_inc(x_40); +x_41 = lean_ctor_get(x_30, 9); +lean_inc(x_41); +if (lean_is_exclusive(x_30)) { + lean_ctor_release(x_30, 0); + lean_ctor_release(x_30, 1); + lean_ctor_release(x_30, 2); + lean_ctor_release(x_30, 3); + lean_ctor_release(x_30, 4); + lean_ctor_release(x_30, 5); + lean_ctor_release(x_30, 6); + lean_ctor_release(x_30, 7); + lean_ctor_release(x_30, 8); + lean_ctor_release(x_30, 9); + x_42 = x_30; } else { - lean_dec_ref(x_29); - x_40 = lean_box(0); + lean_dec_ref(x_30); + x_42 = lean_box(0); } -x_41 = lean_local_ctx_mk_local_decl(x_31, x_28, x_7, x_2, x_3); -if (lean_is_scalar(x_40)) { - x_42 = lean_alloc_ctor(0, 9, 0); +x_43 = lean_local_ctx_mk_local_decl(x_33, x_29, x_7, x_2, x_3); +if (lean_is_scalar(x_42)) { + x_44 = lean_alloc_ctor(0, 10, 0); } else { - x_42 = x_40; + x_44 = x_42; } -lean_ctor_set(x_42, 0, x_41); -lean_ctor_set(x_42, 1, x_32); -lean_ctor_set(x_42, 2, x_33); -lean_ctor_set(x_42, 3, x_34); -lean_ctor_set(x_42, 4, x_35); -lean_ctor_set(x_42, 5, x_36); -lean_ctor_set(x_42, 6, x_37); -lean_ctor_set(x_42, 7, x_38); -lean_ctor_set(x_42, 8, x_39); -x_43 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_43, 0, x_30); -lean_ctor_set(x_43, 1, x_42); -return x_43; +lean_ctor_set(x_44, 0, x_32); +lean_ctor_set(x_44, 1, x_43); +lean_ctor_set(x_44, 2, x_34); +lean_ctor_set(x_44, 3, x_35); +lean_ctor_set(x_44, 4, x_36); +lean_ctor_set(x_44, 5, x_37); +lean_ctor_set(x_44, 6, x_38); +lean_ctor_set(x_44, 7, x_39); +lean_ctor_set(x_44, 8, x_40); +lean_ctor_set(x_44, 9, x_41); +x_45 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_45, 0, x_31); +lean_ctor_set(x_45, 1, x_44); +return x_45; } } } @@ -2335,15 +2311,15 @@ x_11 = !lean_is_exclusive(x_9); if (x_11 == 0) { lean_object* x_12; lean_object* x_13; -x_12 = lean_ctor_get(x_9, 0); +x_12 = lean_ctor_get(x_9, 1); x_13 = lean_local_ctx_mk_let_decl(x_12, x_8, x_1, x_2, x_3); -lean_ctor_set(x_9, 0, x_13); +lean_ctor_set(x_9, 1, x_13); lean_ctor_set(x_6, 0, x_10); return x_6; } else { -lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; +lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; x_14 = lean_ctor_get(x_9, 0); x_15 = lean_ctor_get(x_9, 1); x_16 = lean_ctor_get(x_9, 2); @@ -2353,6 +2329,8 @@ x_19 = lean_ctor_get(x_9, 5); x_20 = lean_ctor_get(x_9, 6); x_21 = lean_ctor_get(x_9, 7); x_22 = lean_ctor_get(x_9, 8); +x_23 = lean_ctor_get(x_9, 9); +lean_inc(x_23); lean_inc(x_22); lean_inc(x_21); lean_inc(x_20); @@ -2363,84 +2341,89 @@ lean_inc(x_16); lean_inc(x_15); lean_inc(x_14); lean_dec(x_9); -x_23 = lean_local_ctx_mk_let_decl(x_14, x_8, x_1, x_2, x_3); -x_24 = lean_alloc_ctor(0, 9, 0); -lean_ctor_set(x_24, 0, x_23); -lean_ctor_set(x_24, 1, x_15); -lean_ctor_set(x_24, 2, x_16); -lean_ctor_set(x_24, 3, x_17); -lean_ctor_set(x_24, 4, x_18); -lean_ctor_set(x_24, 5, x_19); -lean_ctor_set(x_24, 6, x_20); -lean_ctor_set(x_24, 7, x_21); -lean_ctor_set(x_24, 8, x_22); -lean_ctor_set(x_6, 1, x_24); +x_24 = lean_local_ctx_mk_let_decl(x_15, x_8, x_1, x_2, x_3); +x_25 = lean_alloc_ctor(0, 10, 0); +lean_ctor_set(x_25, 0, x_14); +lean_ctor_set(x_25, 1, x_24); +lean_ctor_set(x_25, 2, x_16); +lean_ctor_set(x_25, 3, x_17); +lean_ctor_set(x_25, 4, x_18); +lean_ctor_set(x_25, 5, x_19); +lean_ctor_set(x_25, 6, x_20); +lean_ctor_set(x_25, 7, x_21); +lean_ctor_set(x_25, 8, x_22); +lean_ctor_set(x_25, 9, x_23); +lean_ctor_set(x_6, 1, x_25); lean_ctor_set(x_6, 0, x_10); return x_6; } } else { -lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; -x_25 = lean_ctor_get(x_6, 0); -x_26 = lean_ctor_get(x_6, 1); +lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; +x_26 = lean_ctor_get(x_6, 0); +x_27 = lean_ctor_get(x_6, 1); +lean_inc(x_27); lean_inc(x_26); -lean_inc(x_25); lean_dec(x_6); -lean_inc(x_25); -x_27 = l_Lean_mkFVar(x_25); -x_28 = lean_ctor_get(x_26, 0); -lean_inc(x_28); -x_29 = lean_ctor_get(x_26, 1); +lean_inc(x_26); +x_28 = l_Lean_mkFVar(x_26); +x_29 = lean_ctor_get(x_27, 0); lean_inc(x_29); -x_30 = lean_ctor_get(x_26, 2); +x_30 = lean_ctor_get(x_27, 1); lean_inc(x_30); -x_31 = lean_ctor_get(x_26, 3); +x_31 = lean_ctor_get(x_27, 2); lean_inc(x_31); -x_32 = lean_ctor_get(x_26, 4); +x_32 = lean_ctor_get(x_27, 3); lean_inc(x_32); -x_33 = lean_ctor_get(x_26, 5); +x_33 = lean_ctor_get(x_27, 4); lean_inc(x_33); -x_34 = lean_ctor_get(x_26, 6); +x_34 = lean_ctor_get(x_27, 5); lean_inc(x_34); -x_35 = lean_ctor_get(x_26, 7); +x_35 = lean_ctor_get(x_27, 6); lean_inc(x_35); -x_36 = lean_ctor_get(x_26, 8); +x_36 = lean_ctor_get(x_27, 7); lean_inc(x_36); -if (lean_is_exclusive(x_26)) { - lean_ctor_release(x_26, 0); - lean_ctor_release(x_26, 1); - lean_ctor_release(x_26, 2); - lean_ctor_release(x_26, 3); - lean_ctor_release(x_26, 4); - lean_ctor_release(x_26, 5); - lean_ctor_release(x_26, 6); - lean_ctor_release(x_26, 7); - lean_ctor_release(x_26, 8); - x_37 = x_26; +x_37 = lean_ctor_get(x_27, 8); +lean_inc(x_37); +x_38 = lean_ctor_get(x_27, 9); +lean_inc(x_38); +if (lean_is_exclusive(x_27)) { + lean_ctor_release(x_27, 0); + lean_ctor_release(x_27, 1); + lean_ctor_release(x_27, 2); + lean_ctor_release(x_27, 3); + lean_ctor_release(x_27, 4); + lean_ctor_release(x_27, 5); + lean_ctor_release(x_27, 6); + lean_ctor_release(x_27, 7); + lean_ctor_release(x_27, 8); + lean_ctor_release(x_27, 9); + x_39 = x_27; } else { - lean_dec_ref(x_26); - x_37 = lean_box(0); + lean_dec_ref(x_27); + x_39 = lean_box(0); } -x_38 = lean_local_ctx_mk_let_decl(x_28, x_25, x_1, x_2, x_3); -if (lean_is_scalar(x_37)) { - x_39 = lean_alloc_ctor(0, 9, 0); +x_40 = lean_local_ctx_mk_let_decl(x_30, x_26, x_1, x_2, x_3); +if (lean_is_scalar(x_39)) { + x_41 = lean_alloc_ctor(0, 10, 0); } else { - x_39 = x_37; + x_41 = x_39; } -lean_ctor_set(x_39, 0, x_38); -lean_ctor_set(x_39, 1, x_29); -lean_ctor_set(x_39, 2, x_30); -lean_ctor_set(x_39, 3, x_31); -lean_ctor_set(x_39, 4, x_32); -lean_ctor_set(x_39, 5, x_33); -lean_ctor_set(x_39, 6, x_34); -lean_ctor_set(x_39, 7, x_35); -lean_ctor_set(x_39, 8, x_36); -x_40 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_40, 0, x_27); -lean_ctor_set(x_40, 1, x_39); -return x_40; +lean_ctor_set(x_41, 0, x_29); +lean_ctor_set(x_41, 1, x_40); +lean_ctor_set(x_41, 2, x_31); +lean_ctor_set(x_41, 3, x_32); +lean_ctor_set(x_41, 4, x_33); +lean_ctor_set(x_41, 5, x_34); +lean_ctor_set(x_41, 6, x_35); +lean_ctor_set(x_41, 7, x_36); +lean_ctor_set(x_41, 8, x_37); +lean_ctor_set(x_41, 9, x_38); +x_42 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_42, 0, x_28); +lean_ctor_set(x_42, 1, x_41); +return x_42; } } } @@ -2813,54 +2796,54 @@ return x_36; lean_object* l_Lean_Closure_visitExpr(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { -lean_object* x_5; uint8_t x_49; -x_49 = l_Lean_Expr_hasLevelParam(x_2); -if (x_49 == 0) -{ -uint8_t x_50; -x_50 = l_Lean_Expr_hasFVar(x_2); -if (x_50 == 0) -{ -uint8_t x_51; -x_51 = l_Lean_Expr_hasMVar(x_2); +lean_object* x_5; uint8_t x_51; +x_51 = l_Lean_Expr_hasLevelParam(x_2); if (x_51 == 0) { -lean_object* x_52; -lean_dec(x_3); -lean_dec(x_1); -x_52 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_52, 0, x_2); -lean_ctor_set(x_52, 1, x_4); -return x_52; -} -else +uint8_t x_52; +x_52 = l_Lean_Expr_hasFVar(x_2); +if (x_52 == 0) { -lean_object* x_53; -x_53 = lean_box(0); -x_5 = x_53; -goto block_48; -} -} -else +uint8_t x_53; +x_53 = l_Lean_Expr_hasMVar(x_2); +if (x_53 == 0) { lean_object* x_54; -x_54 = lean_box(0); -x_5 = x_54; -goto block_48; -} +lean_dec(x_3); +lean_dec(x_1); +x_54 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_54, 0, x_2); +lean_ctor_set(x_54, 1, x_4); +return x_54; } else { lean_object* x_55; x_55 = lean_box(0); x_5 = x_55; -goto block_48; +goto block_50; } -block_48: +} +else +{ +lean_object* x_56; +x_56 = lean_box(0); +x_5 = x_56; +goto block_50; +} +} +else +{ +lean_object* x_57; +x_57 = lean_box(0); +x_5 = x_57; +goto block_50; +} +block_50: { lean_object* x_6; lean_object* x_7; lean_dec(x_5); -x_6 = lean_ctor_get(x_4, 3); +x_6 = lean_ctor_get(x_4, 4); lean_inc(x_6); x_7 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitExpr___spec__1(x_6, x_2); lean_dec(x_6); @@ -2882,15 +2865,15 @@ if (x_11 == 0) { lean_object* x_12; lean_object* x_13; lean_object* x_14; x_12 = lean_ctor_get(x_8, 0); -x_13 = lean_ctor_get(x_10, 3); +x_13 = lean_ctor_get(x_10, 4); lean_inc(x_12); x_14 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_13, x_2, x_12); -lean_ctor_set(x_10, 3, x_14); +lean_ctor_set(x_10, 4, x_14); return x_8; } else { -lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; 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_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; x_15 = lean_ctor_get(x_8, 0); x_16 = lean_ctor_get(x_10, 0); x_17 = lean_ctor_get(x_10, 1); @@ -2901,6 +2884,8 @@ x_21 = lean_ctor_get(x_10, 5); x_22 = lean_ctor_get(x_10, 6); x_23 = lean_ctor_get(x_10, 7); x_24 = lean_ctor_get(x_10, 8); +x_25 = lean_ctor_get(x_10, 9); +lean_inc(x_25); lean_inc(x_24); lean_inc(x_23); lean_inc(x_22); @@ -2912,121 +2897,126 @@ lean_inc(x_17); lean_inc(x_16); lean_dec(x_10); lean_inc(x_15); -x_25 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_19, x_2, x_15); -x_26 = lean_alloc_ctor(0, 9, 0); -lean_ctor_set(x_26, 0, x_16); -lean_ctor_set(x_26, 1, x_17); -lean_ctor_set(x_26, 2, x_18); -lean_ctor_set(x_26, 3, x_25); -lean_ctor_set(x_26, 4, x_20); -lean_ctor_set(x_26, 5, x_21); -lean_ctor_set(x_26, 6, x_22); -lean_ctor_set(x_26, 7, x_23); -lean_ctor_set(x_26, 8, x_24); -lean_ctor_set(x_8, 1, x_26); +x_26 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_20, x_2, x_15); +x_27 = lean_alloc_ctor(0, 10, 0); +lean_ctor_set(x_27, 0, x_16); +lean_ctor_set(x_27, 1, x_17); +lean_ctor_set(x_27, 2, x_18); +lean_ctor_set(x_27, 3, x_19); +lean_ctor_set(x_27, 4, x_26); +lean_ctor_set(x_27, 5, x_21); +lean_ctor_set(x_27, 6, x_22); +lean_ctor_set(x_27, 7, x_23); +lean_ctor_set(x_27, 8, x_24); +lean_ctor_set(x_27, 9, x_25); +lean_ctor_set(x_8, 1, x_27); return x_8; } } else { -lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; -x_27 = lean_ctor_get(x_8, 1); -x_28 = lean_ctor_get(x_8, 0); -lean_inc(x_27); +lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; +x_28 = lean_ctor_get(x_8, 1); +x_29 = lean_ctor_get(x_8, 0); lean_inc(x_28); -lean_dec(x_8); -x_29 = lean_ctor_get(x_27, 0); lean_inc(x_29); -x_30 = lean_ctor_get(x_27, 1); +lean_dec(x_8); +x_30 = lean_ctor_get(x_28, 0); lean_inc(x_30); -x_31 = lean_ctor_get(x_27, 2); +x_31 = lean_ctor_get(x_28, 1); lean_inc(x_31); -x_32 = lean_ctor_get(x_27, 3); +x_32 = lean_ctor_get(x_28, 2); lean_inc(x_32); -x_33 = lean_ctor_get(x_27, 4); +x_33 = lean_ctor_get(x_28, 3); lean_inc(x_33); -x_34 = lean_ctor_get(x_27, 5); +x_34 = lean_ctor_get(x_28, 4); lean_inc(x_34); -x_35 = lean_ctor_get(x_27, 6); +x_35 = lean_ctor_get(x_28, 5); lean_inc(x_35); -x_36 = lean_ctor_get(x_27, 7); +x_36 = lean_ctor_get(x_28, 6); lean_inc(x_36); -x_37 = lean_ctor_get(x_27, 8); +x_37 = lean_ctor_get(x_28, 7); lean_inc(x_37); -if (lean_is_exclusive(x_27)) { - lean_ctor_release(x_27, 0); - lean_ctor_release(x_27, 1); - lean_ctor_release(x_27, 2); - lean_ctor_release(x_27, 3); - lean_ctor_release(x_27, 4); - lean_ctor_release(x_27, 5); - lean_ctor_release(x_27, 6); - lean_ctor_release(x_27, 7); - lean_ctor_release(x_27, 8); - x_38 = x_27; +x_38 = lean_ctor_get(x_28, 8); +lean_inc(x_38); +x_39 = lean_ctor_get(x_28, 9); +lean_inc(x_39); +if (lean_is_exclusive(x_28)) { + lean_ctor_release(x_28, 0); + lean_ctor_release(x_28, 1); + lean_ctor_release(x_28, 2); + lean_ctor_release(x_28, 3); + lean_ctor_release(x_28, 4); + lean_ctor_release(x_28, 5); + lean_ctor_release(x_28, 6); + lean_ctor_release(x_28, 7); + lean_ctor_release(x_28, 8); + lean_ctor_release(x_28, 9); + x_40 = x_28; } else { - lean_dec_ref(x_27); - x_38 = lean_box(0); + lean_dec_ref(x_28); + x_40 = lean_box(0); } -lean_inc(x_28); -x_39 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_32, x_2, x_28); -if (lean_is_scalar(x_38)) { - x_40 = lean_alloc_ctor(0, 9, 0); +lean_inc(x_29); +x_41 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_34, x_2, x_29); +if (lean_is_scalar(x_40)) { + x_42 = lean_alloc_ctor(0, 10, 0); } else { - x_40 = x_38; + x_42 = x_40; } -lean_ctor_set(x_40, 0, x_29); -lean_ctor_set(x_40, 1, x_30); -lean_ctor_set(x_40, 2, x_31); -lean_ctor_set(x_40, 3, x_39); -lean_ctor_set(x_40, 4, x_33); -lean_ctor_set(x_40, 5, x_34); -lean_ctor_set(x_40, 6, x_35); -lean_ctor_set(x_40, 7, x_36); -lean_ctor_set(x_40, 8, x_37); -x_41 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_41, 0, x_28); -lean_ctor_set(x_41, 1, x_40); -return x_41; +lean_ctor_set(x_42, 0, x_30); +lean_ctor_set(x_42, 1, x_31); +lean_ctor_set(x_42, 2, x_32); +lean_ctor_set(x_42, 3, x_33); +lean_ctor_set(x_42, 4, x_41); +lean_ctor_set(x_42, 5, x_35); +lean_ctor_set(x_42, 6, x_36); +lean_ctor_set(x_42, 7, x_37); +lean_ctor_set(x_42, 8, x_38); +lean_ctor_set(x_42, 9, x_39); +x_43 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_43, 0, x_29); +lean_ctor_set(x_43, 1, x_42); +return x_43; } } else { -uint8_t x_42; +uint8_t x_44; lean_dec(x_2); -x_42 = !lean_is_exclusive(x_8); -if (x_42 == 0) +x_44 = !lean_is_exclusive(x_8); +if (x_44 == 0) { return x_8; } else { -lean_object* x_43; lean_object* x_44; lean_object* x_45; -x_43 = lean_ctor_get(x_8, 0); -x_44 = lean_ctor_get(x_8, 1); -lean_inc(x_44); -lean_inc(x_43); +lean_object* x_45; lean_object* x_46; lean_object* x_47; +x_45 = lean_ctor_get(x_8, 0); +x_46 = lean_ctor_get(x_8, 1); +lean_inc(x_46); +lean_inc(x_45); lean_dec(x_8); -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_47 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_47, 0, x_45); +lean_ctor_set(x_47, 1, x_46); +return x_47; } } } else { -lean_object* x_46; lean_object* x_47; +lean_object* x_48; lean_object* x_49; lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_46 = lean_ctor_get(x_7, 0); -lean_inc(x_46); +x_48 = lean_ctor_get(x_7, 0); +lean_inc(x_48); lean_dec(x_7); -x_47 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_47, 0, x_46); -lean_ctor_set(x_47, 1, x_4); -return x_47; +x_49 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_49, 0, x_48); +lean_ctor_set(x_49, 1, x_4); +return x_49; } } } @@ -3068,7 +3058,6 @@ _start: if (lean_obj_tag(x_1) == 0) { lean_object* x_4; lean_object* x_5; -lean_dec(x_2); x_4 = lean_box(0); x_5 = lean_alloc_ctor(0, 2, 0); lean_ctor_set(x_5, 0, x_4); @@ -3084,7 +3073,6 @@ if (x_6 == 0) lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; uint8_t x_13; x_7 = lean_ctor_get(x_1, 0); x_8 = lean_ctor_get(x_1, 1); -lean_inc(x_2); x_9 = l_Lean_Closure_collectLevel(x_7, x_2, x_3); x_10 = lean_ctor_get(x_9, 0); lean_inc(x_10); @@ -3126,7 +3114,6 @@ x_19 = lean_ctor_get(x_1, 1); lean_inc(x_19); lean_inc(x_18); lean_dec(x_1); -lean_inc(x_2); x_20 = l_Lean_Closure_collectLevel(x_18, x_2, x_3); x_21 = lean_ctor_get(x_20, 0); lean_inc(x_21); @@ -3171,7 +3158,7 @@ case 1: lean_object* x_22; lean_object* x_23; lean_object* x_24; x_22 = lean_ctor_get(x_1, 0); lean_inc(x_22); -x_23 = lean_ctor_get(x_2, 1); +x_23 = lean_ctor_get(x_2, 0); lean_inc(x_23); x_24 = lean_local_ctx_find(x_23, x_22); if (lean_obj_tag(x_24) == 0) @@ -3199,829 +3186,890 @@ if (lean_is_exclusive(x_24)) { } if (lean_obj_tag(x_27) == 0) { -lean_object* x_29; lean_object* x_30; uint8_t x_31; lean_object* x_32; lean_object* x_33; lean_object* x_68; uint8_t x_94; +lean_object* x_29; lean_object* x_30; uint8_t x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_73; uint8_t x_100; x_29 = lean_ctor_get(x_27, 2); lean_inc(x_29); x_30 = lean_ctor_get(x_27, 3); lean_inc(x_30); x_31 = lean_ctor_get_uint8(x_27, sizeof(void*)*4); lean_dec(x_27); -x_94 = l_Lean_Expr_hasLevelParam(x_30); -if (x_94 == 0) +x_32 = l_Lean_Closure_instantiateMVars(x_30, x_2, x_3); +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_100 = l_Lean_Expr_hasLevelParam(x_33); +if (x_100 == 0) { -uint8_t x_95; -x_95 = l_Lean_Expr_hasFVar(x_30); -if (x_95 == 0) +uint8_t x_101; +x_101 = l_Lean_Expr_hasFVar(x_33); +if (x_101 == 0) { -uint8_t x_96; -x_96 = l_Lean_Expr_hasMVar(x_30); -if (x_96 == 0) +uint8_t x_102; +x_102 = l_Lean_Expr_hasMVar(x_33); +if (x_102 == 0) { -x_32 = x_30; -x_33 = x_3; -goto block_67; +x_35 = x_33; +x_36 = x_34; +goto block_72; } else { -lean_object* x_97; -x_97 = lean_box(0); -x_68 = x_97; -goto block_93; +lean_object* x_103; +x_103 = lean_box(0); +x_73 = x_103; +goto block_99; } } else { -lean_object* x_98; -x_98 = lean_box(0); -x_68 = x_98; -goto block_93; +lean_object* x_104; +x_104 = lean_box(0); +x_73 = x_104; +goto block_99; } } else { -lean_object* x_99; -x_99 = lean_box(0); -x_68 = x_99; -goto block_93; +lean_object* x_105; +x_105 = lean_box(0); +x_73 = x_105; +goto block_99; } -block_67: +block_72: { -lean_object* x_34; lean_object* x_35; uint8_t x_36; +lean_object* x_37; lean_object* x_38; uint8_t x_39; if (lean_is_scalar(x_28)) { - x_34 = lean_alloc_ctor(1, 1, 0); + x_37 = lean_alloc_ctor(1, 1, 0); } else { - x_34 = x_28; + x_37 = x_28; } -lean_ctor_set(x_34, 0, x_29); -x_35 = l_Lean_Closure_mkLocalDecl(x_34, x_32, x_31, x_2, x_33); +lean_ctor_set(x_37, 0, x_29); +x_38 = l_Lean_Closure_mkLocalDecl(x_37, x_35, x_31, x_2, x_36); lean_dec(x_2); -lean_dec(x_34); -x_36 = !lean_is_exclusive(x_35); -if (x_36 == 0) +lean_dec(x_37); +x_39 = !lean_is_exclusive(x_38); +if (x_39 == 0) { -lean_object* x_37; uint8_t x_38; -x_37 = lean_ctor_get(x_35, 1); -x_38 = !lean_is_exclusive(x_37); -if (x_38 == 0) +lean_object* x_40; uint8_t x_41; +x_40 = lean_ctor_get(x_38, 1); +x_41 = !lean_is_exclusive(x_40); +if (x_41 == 0) { -lean_object* x_39; lean_object* x_40; -x_39 = lean_ctor_get(x_37, 8); -x_40 = lean_array_push(x_39, x_1); -lean_ctor_set(x_37, 8, x_40); -return x_35; +lean_object* x_42; lean_object* x_43; +x_42 = lean_ctor_get(x_40, 9); +x_43 = lean_array_push(x_42, x_1); +lean_ctor_set(x_40, 9, x_43); +return x_38; } else { -lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; -x_41 = lean_ctor_get(x_37, 0); -x_42 = lean_ctor_get(x_37, 1); -x_43 = lean_ctor_get(x_37, 2); -x_44 = lean_ctor_get(x_37, 3); -x_45 = lean_ctor_get(x_37, 4); -x_46 = lean_ctor_get(x_37, 5); -x_47 = lean_ctor_get(x_37, 6); -x_48 = lean_ctor_get(x_37, 7); -x_49 = lean_ctor_get(x_37, 8); +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; +x_44 = lean_ctor_get(x_40, 0); +x_45 = lean_ctor_get(x_40, 1); +x_46 = lean_ctor_get(x_40, 2); +x_47 = lean_ctor_get(x_40, 3); +x_48 = lean_ctor_get(x_40, 4); +x_49 = lean_ctor_get(x_40, 5); +x_50 = lean_ctor_get(x_40, 6); +x_51 = lean_ctor_get(x_40, 7); +x_52 = lean_ctor_get(x_40, 8); +x_53 = lean_ctor_get(x_40, 9); +lean_inc(x_53); +lean_inc(x_52); +lean_inc(x_51); +lean_inc(x_50); lean_inc(x_49); lean_inc(x_48); lean_inc(x_47); lean_inc(x_46); lean_inc(x_45); lean_inc(x_44); -lean_inc(x_43); -lean_inc(x_42); -lean_inc(x_41); -lean_dec(x_37); -x_50 = lean_array_push(x_49, x_1); -x_51 = lean_alloc_ctor(0, 9, 0); -lean_ctor_set(x_51, 0, x_41); -lean_ctor_set(x_51, 1, x_42); -lean_ctor_set(x_51, 2, x_43); -lean_ctor_set(x_51, 3, x_44); -lean_ctor_set(x_51, 4, x_45); -lean_ctor_set(x_51, 5, x_46); -lean_ctor_set(x_51, 6, x_47); -lean_ctor_set(x_51, 7, x_48); -lean_ctor_set(x_51, 8, x_50); -lean_ctor_set(x_35, 1, x_51); -return x_35; +lean_dec(x_40); +x_54 = lean_array_push(x_53, x_1); +x_55 = lean_alloc_ctor(0, 10, 0); +lean_ctor_set(x_55, 0, x_44); +lean_ctor_set(x_55, 1, x_45); +lean_ctor_set(x_55, 2, x_46); +lean_ctor_set(x_55, 3, x_47); +lean_ctor_set(x_55, 4, x_48); +lean_ctor_set(x_55, 5, x_49); +lean_ctor_set(x_55, 6, x_50); +lean_ctor_set(x_55, 7, x_51); +lean_ctor_set(x_55, 8, x_52); +lean_ctor_set(x_55, 9, x_54); +lean_ctor_set(x_38, 1, x_55); +return x_38; } } else { -lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; -x_52 = lean_ctor_get(x_35, 1); -x_53 = lean_ctor_get(x_35, 0); -lean_inc(x_52); -lean_inc(x_53); -lean_dec(x_35); -x_54 = lean_ctor_get(x_52, 0); -lean_inc(x_54); -x_55 = lean_ctor_get(x_52, 1); -lean_inc(x_55); -x_56 = lean_ctor_get(x_52, 2); +lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; +x_56 = lean_ctor_get(x_38, 1); +x_57 = lean_ctor_get(x_38, 0); lean_inc(x_56); -x_57 = lean_ctor_get(x_52, 3); lean_inc(x_57); -x_58 = lean_ctor_get(x_52, 4); +lean_dec(x_38); +x_58 = lean_ctor_get(x_56, 0); lean_inc(x_58); -x_59 = lean_ctor_get(x_52, 5); +x_59 = lean_ctor_get(x_56, 1); lean_inc(x_59); -x_60 = lean_ctor_get(x_52, 6); +x_60 = lean_ctor_get(x_56, 2); lean_inc(x_60); -x_61 = lean_ctor_get(x_52, 7); +x_61 = lean_ctor_get(x_56, 3); lean_inc(x_61); -x_62 = lean_ctor_get(x_52, 8); +x_62 = lean_ctor_get(x_56, 4); lean_inc(x_62); -if (lean_is_exclusive(x_52)) { - lean_ctor_release(x_52, 0); - lean_ctor_release(x_52, 1); - lean_ctor_release(x_52, 2); - lean_ctor_release(x_52, 3); - lean_ctor_release(x_52, 4); - lean_ctor_release(x_52, 5); - lean_ctor_release(x_52, 6); - lean_ctor_release(x_52, 7); - lean_ctor_release(x_52, 8); - x_63 = x_52; +x_63 = lean_ctor_get(x_56, 5); +lean_inc(x_63); +x_64 = lean_ctor_get(x_56, 6); +lean_inc(x_64); +x_65 = lean_ctor_get(x_56, 7); +lean_inc(x_65); +x_66 = lean_ctor_get(x_56, 8); +lean_inc(x_66); +x_67 = lean_ctor_get(x_56, 9); +lean_inc(x_67); +if (lean_is_exclusive(x_56)) { + lean_ctor_release(x_56, 0); + lean_ctor_release(x_56, 1); + lean_ctor_release(x_56, 2); + lean_ctor_release(x_56, 3); + lean_ctor_release(x_56, 4); + lean_ctor_release(x_56, 5); + lean_ctor_release(x_56, 6); + lean_ctor_release(x_56, 7); + lean_ctor_release(x_56, 8); + lean_ctor_release(x_56, 9); + x_68 = x_56; } else { - lean_dec_ref(x_52); - x_63 = lean_box(0); + lean_dec_ref(x_56); + x_68 = lean_box(0); } -x_64 = lean_array_push(x_62, x_1); -if (lean_is_scalar(x_63)) { - x_65 = lean_alloc_ctor(0, 9, 0); +x_69 = lean_array_push(x_67, x_1); +if (lean_is_scalar(x_68)) { + x_70 = lean_alloc_ctor(0, 10, 0); } else { - x_65 = x_63; + x_70 = x_68; } -lean_ctor_set(x_65, 0, x_54); -lean_ctor_set(x_65, 1, x_55); -lean_ctor_set(x_65, 2, x_56); -lean_ctor_set(x_65, 3, x_57); -lean_ctor_set(x_65, 4, x_58); -lean_ctor_set(x_65, 5, x_59); -lean_ctor_set(x_65, 6, x_60); -lean_ctor_set(x_65, 7, x_61); -lean_ctor_set(x_65, 8, x_64); -x_66 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_66, 0, x_53); -lean_ctor_set(x_66, 1, x_65); -return x_66; +lean_ctor_set(x_70, 0, x_58); +lean_ctor_set(x_70, 1, x_59); +lean_ctor_set(x_70, 2, x_60); +lean_ctor_set(x_70, 3, x_61); +lean_ctor_set(x_70, 4, x_62); +lean_ctor_set(x_70, 5, x_63); +lean_ctor_set(x_70, 6, x_64); +lean_ctor_set(x_70, 7, x_65); +lean_ctor_set(x_70, 8, x_66); +lean_ctor_set(x_70, 9, x_69); +x_71 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_71, 0, x_57); +lean_ctor_set(x_71, 1, x_70); +return x_71; } } -block_93: +block_99: { -lean_object* x_69; lean_object* x_70; -lean_dec(x_68); -x_69 = lean_ctor_get(x_3, 3); -lean_inc(x_69); -x_70 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitExpr___spec__1(x_69, x_30); -lean_dec(x_69); -if (lean_obj_tag(x_70) == 0) +lean_object* x_74; lean_object* x_75; +lean_dec(x_73); +x_74 = lean_ctor_get(x_34, 4); +lean_inc(x_74); +x_75 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitExpr___spec__1(x_74, x_33); +lean_dec(x_74); +if (lean_obj_tag(x_75) == 0) { -lean_object* x_71; +lean_object* x_76; lean_inc(x_2); -lean_inc(x_30); -x_71 = l_Lean_Closure_collectExprAux___main(x_30, x_2, x_3); -if (lean_obj_tag(x_71) == 0) +lean_inc(x_33); +x_76 = l_Lean_Closure_collectExprAux___main(x_33, x_2, x_34); +if (lean_obj_tag(x_76) == 0) { -lean_object* x_72; lean_object* x_73; uint8_t x_74; -x_72 = lean_ctor_get(x_71, 1); -lean_inc(x_72); -x_73 = lean_ctor_get(x_71, 0); -lean_inc(x_73); -lean_dec(x_71); -x_74 = !lean_is_exclusive(x_72); -if (x_74 == 0) +lean_object* x_77; lean_object* x_78; uint8_t x_79; +x_77 = lean_ctor_get(x_76, 1); +lean_inc(x_77); +x_78 = lean_ctor_get(x_76, 0); +lean_inc(x_78); +lean_dec(x_76); +x_79 = !lean_is_exclusive(x_77); +if (x_79 == 0) { -lean_object* x_75; lean_object* x_76; -x_75 = lean_ctor_get(x_72, 3); -lean_inc(x_73); -x_76 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_75, x_30, x_73); -lean_ctor_set(x_72, 3, x_76); -x_32 = x_73; -x_33 = x_72; -goto block_67; +lean_object* x_80; lean_object* x_81; +x_80 = lean_ctor_get(x_77, 4); +lean_inc(x_78); +x_81 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_80, x_33, x_78); +lean_ctor_set(x_77, 4, x_81); +x_35 = x_78; +x_36 = x_77; +goto block_72; } else { -lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; -x_77 = lean_ctor_get(x_72, 0); -x_78 = lean_ctor_get(x_72, 1); -x_79 = lean_ctor_get(x_72, 2); -x_80 = lean_ctor_get(x_72, 3); -x_81 = lean_ctor_get(x_72, 4); -x_82 = lean_ctor_get(x_72, 5); -x_83 = lean_ctor_get(x_72, 6); -x_84 = lean_ctor_get(x_72, 7); -x_85 = lean_ctor_get(x_72, 8); +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; +x_82 = lean_ctor_get(x_77, 0); +x_83 = lean_ctor_get(x_77, 1); +x_84 = lean_ctor_get(x_77, 2); +x_85 = lean_ctor_get(x_77, 3); +x_86 = lean_ctor_get(x_77, 4); +x_87 = lean_ctor_get(x_77, 5); +x_88 = lean_ctor_get(x_77, 6); +x_89 = lean_ctor_get(x_77, 7); +x_90 = lean_ctor_get(x_77, 8); +x_91 = lean_ctor_get(x_77, 9); +lean_inc(x_91); +lean_inc(x_90); +lean_inc(x_89); +lean_inc(x_88); +lean_inc(x_87); +lean_inc(x_86); lean_inc(x_85); lean_inc(x_84); lean_inc(x_83); lean_inc(x_82); -lean_inc(x_81); -lean_inc(x_80); -lean_inc(x_79); +lean_dec(x_77); lean_inc(x_78); -lean_inc(x_77); -lean_dec(x_72); -lean_inc(x_73); -x_86 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_80, x_30, x_73); -x_87 = lean_alloc_ctor(0, 9, 0); -lean_ctor_set(x_87, 0, x_77); -lean_ctor_set(x_87, 1, x_78); -lean_ctor_set(x_87, 2, x_79); -lean_ctor_set(x_87, 3, x_86); -lean_ctor_set(x_87, 4, x_81); -lean_ctor_set(x_87, 5, x_82); -lean_ctor_set(x_87, 6, x_83); -lean_ctor_set(x_87, 7, x_84); -lean_ctor_set(x_87, 8, x_85); -x_32 = x_73; -x_33 = x_87; -goto block_67; +x_92 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_86, x_33, x_78); +x_93 = lean_alloc_ctor(0, 10, 0); +lean_ctor_set(x_93, 0, x_82); +lean_ctor_set(x_93, 1, x_83); +lean_ctor_set(x_93, 2, x_84); +lean_ctor_set(x_93, 3, x_85); +lean_ctor_set(x_93, 4, x_92); +lean_ctor_set(x_93, 5, x_87); +lean_ctor_set(x_93, 6, x_88); +lean_ctor_set(x_93, 7, x_89); +lean_ctor_set(x_93, 8, x_90); +lean_ctor_set(x_93, 9, x_91); +x_35 = x_78; +x_36 = x_93; +goto block_72; } } else { -uint8_t x_88; -lean_dec(x_30); +uint8_t x_94; +lean_dec(x_33); lean_dec(x_29); lean_dec(x_28); lean_dec(x_2); lean_dec(x_1); -x_88 = !lean_is_exclusive(x_71); -if (x_88 == 0) +x_94 = !lean_is_exclusive(x_76); +if (x_94 == 0) { -return x_71; +return x_76; } else { -lean_object* x_89; lean_object* x_90; lean_object* x_91; -x_89 = lean_ctor_get(x_71, 0); -x_90 = lean_ctor_get(x_71, 1); -lean_inc(x_90); -lean_inc(x_89); -lean_dec(x_71); -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_95; lean_object* x_96; lean_object* x_97; +x_95 = lean_ctor_get(x_76, 0); +x_96 = lean_ctor_get(x_76, 1); +lean_inc(x_96); +lean_inc(x_95); +lean_dec(x_76); +x_97 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_97, 0, x_95); +lean_ctor_set(x_97, 1, x_96); +return x_97; } } } else { -lean_object* x_92; -lean_dec(x_30); -x_92 = lean_ctor_get(x_70, 0); -lean_inc(x_92); -lean_dec(x_70); -x_32 = x_92; -x_33 = x_3; -goto block_67; +lean_object* x_98; +lean_dec(x_33); +x_98 = lean_ctor_get(x_75, 0); +lean_inc(x_98); +lean_dec(x_75); +x_35 = x_98; +x_36 = x_34; +goto block_72; } } } else { -lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_142; uint8_t x_168; +uint8_t x_106; lean_dec(x_28); lean_dec(x_1); -x_100 = lean_ctor_get(x_27, 2); -lean_inc(x_100); -x_101 = lean_ctor_get(x_27, 3); -lean_inc(x_101); -x_102 = lean_ctor_get(x_27, 4); -lean_inc(x_102); -lean_dec(x_27); -x_168 = lean_ctor_get_uint8(x_2, sizeof(void*)*2); -if (x_168 == 0) +x_106 = lean_ctor_get_uint8(x_2, sizeof(void*)*1); +if (x_106 == 0) { -uint8_t x_169; -x_169 = l_Lean_Expr_hasLevelParam(x_101); -if (x_169 == 0) -{ -uint8_t x_170; -x_170 = l_Lean_Expr_hasFVar(x_101); -if (x_170 == 0) -{ -uint8_t x_171; -x_171 = l_Lean_Expr_hasMVar(x_101); -if (x_171 == 0) -{ -x_103 = x_101; -x_104 = x_3; -goto block_141; -} -else -{ -lean_object* x_172; -x_172 = lean_box(0); -x_142 = x_172; -goto block_167; -} -} -else -{ -lean_object* x_173; -x_173 = lean_box(0); -x_142 = x_173; -goto block_167; -} -} -else -{ -lean_object* x_174; -x_174 = lean_box(0); -x_142 = x_174; -goto block_167; -} -} -else -{ -lean_object* x_175; uint8_t x_219; -lean_dec(x_101); -lean_dec(x_100); -x_219 = l_Lean_Expr_hasLevelParam(x_102); -if (x_219 == 0) -{ -uint8_t x_220; -x_220 = l_Lean_Expr_hasFVar(x_102); -if (x_220 == 0) -{ -uint8_t x_221; -x_221 = l_Lean_Expr_hasMVar(x_102); -if (x_221 == 0) -{ -lean_object* x_222; -lean_dec(x_2); -x_222 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_222, 0, x_102); -lean_ctor_set(x_222, 1, x_3); -return x_222; -} -else -{ -lean_object* x_223; -x_223 = lean_box(0); -x_175 = x_223; -goto block_218; -} -} -else -{ -lean_object* x_224; -x_224 = lean_box(0); -x_175 = x_224; -goto block_218; -} -} -else -{ -lean_object* x_225; -x_225 = lean_box(0); -x_175 = x_225; -goto block_218; -} -block_218: -{ -lean_object* x_176; lean_object* x_177; -lean_dec(x_175); -x_176 = lean_ctor_get(x_3, 3); -lean_inc(x_176); -x_177 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitExpr___spec__1(x_176, x_102); -lean_dec(x_176); -if (lean_obj_tag(x_177) == 0) -{ -lean_object* x_178; -lean_inc(x_102); -x_178 = l_Lean_Closure_collectExprAux___main(x_102, x_2, x_3); -if (lean_obj_tag(x_178) == 0) -{ -uint8_t x_179; -x_179 = !lean_is_exclusive(x_178); -if (x_179 == 0) -{ -lean_object* x_180; uint8_t x_181; -x_180 = lean_ctor_get(x_178, 1); -x_181 = !lean_is_exclusive(x_180); -if (x_181 == 0) -{ -lean_object* x_182; lean_object* x_183; lean_object* x_184; -x_182 = lean_ctor_get(x_178, 0); -x_183 = lean_ctor_get(x_180, 3); -lean_inc(x_182); -x_184 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_183, x_102, x_182); -lean_ctor_set(x_180, 3, x_184); -return x_178; -} -else -{ -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; -x_185 = lean_ctor_get(x_178, 0); -x_186 = lean_ctor_get(x_180, 0); -x_187 = lean_ctor_get(x_180, 1); -x_188 = lean_ctor_get(x_180, 2); -x_189 = lean_ctor_get(x_180, 3); -x_190 = lean_ctor_get(x_180, 4); -x_191 = lean_ctor_get(x_180, 5); -x_192 = lean_ctor_get(x_180, 6); -x_193 = lean_ctor_get(x_180, 7); -x_194 = lean_ctor_get(x_180, 8); -lean_inc(x_194); -lean_inc(x_193); -lean_inc(x_192); -lean_inc(x_191); -lean_inc(x_190); -lean_inc(x_189); -lean_inc(x_188); -lean_inc(x_187); -lean_inc(x_186); -lean_dec(x_180); -lean_inc(x_185); -x_195 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_189, x_102, x_185); -x_196 = lean_alloc_ctor(0, 9, 0); -lean_ctor_set(x_196, 0, x_186); -lean_ctor_set(x_196, 1, x_187); -lean_ctor_set(x_196, 2, x_188); -lean_ctor_set(x_196, 3, x_195); -lean_ctor_set(x_196, 4, x_190); -lean_ctor_set(x_196, 5, x_191); -lean_ctor_set(x_196, 6, x_192); -lean_ctor_set(x_196, 7, x_193); -lean_ctor_set(x_196, 8, x_194); -lean_ctor_set(x_178, 1, x_196); -return x_178; -} -} -else -{ -lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; -x_197 = lean_ctor_get(x_178, 1); -x_198 = lean_ctor_get(x_178, 0); -lean_inc(x_197); -lean_inc(x_198); -lean_dec(x_178); -x_199 = lean_ctor_get(x_197, 0); -lean_inc(x_199); -x_200 = lean_ctor_get(x_197, 1); -lean_inc(x_200); -x_201 = lean_ctor_get(x_197, 2); -lean_inc(x_201); -x_202 = lean_ctor_get(x_197, 3); -lean_inc(x_202); -x_203 = lean_ctor_get(x_197, 4); -lean_inc(x_203); -x_204 = lean_ctor_get(x_197, 5); -lean_inc(x_204); -x_205 = lean_ctor_get(x_197, 6); -lean_inc(x_205); -x_206 = lean_ctor_get(x_197, 7); -lean_inc(x_206); -x_207 = lean_ctor_get(x_197, 8); -lean_inc(x_207); -if (lean_is_exclusive(x_197)) { - lean_ctor_release(x_197, 0); - lean_ctor_release(x_197, 1); - lean_ctor_release(x_197, 2); - lean_ctor_release(x_197, 3); - lean_ctor_release(x_197, 4); - lean_ctor_release(x_197, 5); - lean_ctor_release(x_197, 6); - lean_ctor_release(x_197, 7); - lean_ctor_release(x_197, 8); - x_208 = x_197; -} else { - lean_dec_ref(x_197); - x_208 = lean_box(0); -} -lean_inc(x_198); -x_209 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_202, x_102, x_198); -if (lean_is_scalar(x_208)) { - x_210 = lean_alloc_ctor(0, 9, 0); -} else { - x_210 = x_208; -} -lean_ctor_set(x_210, 0, x_199); -lean_ctor_set(x_210, 1, x_200); -lean_ctor_set(x_210, 2, x_201); -lean_ctor_set(x_210, 3, x_209); -lean_ctor_set(x_210, 4, x_203); -lean_ctor_set(x_210, 5, x_204); -lean_ctor_set(x_210, 6, x_205); -lean_ctor_set(x_210, 7, x_206); -lean_ctor_set(x_210, 8, x_207); -x_211 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_211, 0, x_198); -lean_ctor_set(x_211, 1, x_210); -return x_211; -} -} -else -{ -uint8_t x_212; -lean_dec(x_102); -x_212 = !lean_is_exclusive(x_178); -if (x_212 == 0) -{ -return x_178; -} -else -{ -lean_object* x_213; lean_object* x_214; lean_object* x_215; -x_213 = lean_ctor_get(x_178, 0); -x_214 = lean_ctor_get(x_178, 1); -lean_inc(x_214); -lean_inc(x_213); -lean_dec(x_178); -x_215 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_215, 0, x_213); -lean_ctor_set(x_215, 1, x_214); -return x_215; -} -} -} -else -{ -lean_object* x_216; lean_object* x_217; -lean_dec(x_102); -lean_dec(x_2); -x_216 = lean_ctor_get(x_177, 0); -lean_inc(x_216); -lean_dec(x_177); -x_217 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_217, 0, x_216); -lean_ctor_set(x_217, 1, x_3); -return x_217; -} -} -} -block_141: -{ -lean_object* x_105; uint8_t x_134; -x_134 = l_Lean_Expr_hasLevelParam(x_102); -if (x_134 == 0) -{ -uint8_t x_135; -x_135 = l_Lean_Expr_hasFVar(x_102); -if (x_135 == 0) -{ -uint8_t x_136; -x_136 = l_Lean_Expr_hasMVar(x_102); -if (x_136 == 0) -{ -lean_object* x_137; -x_137 = l_Lean_Closure_mkLetDecl(x_100, x_103, x_102, x_2, x_104); -lean_dec(x_2); -return x_137; -} -else -{ -lean_object* x_138; -x_138 = lean_box(0); -x_105 = x_138; -goto block_133; -} -} -else -{ -lean_object* x_139; -x_139 = lean_box(0); -x_105 = x_139; -goto block_133; -} -} -else -{ -lean_object* x_140; -x_140 = lean_box(0); -x_105 = x_140; -goto block_133; -} -block_133: -{ -lean_object* x_106; lean_object* x_107; -lean_dec(x_105); -x_106 = lean_ctor_get(x_104, 3); -lean_inc(x_106); -x_107 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitExpr___spec__1(x_106, x_102); -lean_dec(x_106); -if (lean_obj_tag(x_107) == 0) -{ -lean_object* x_108; -lean_inc(x_2); -lean_inc(x_102); -x_108 = l_Lean_Closure_collectExprAux___main(x_102, x_2, x_104); -if (lean_obj_tag(x_108) == 0) -{ -lean_object* x_109; lean_object* x_110; uint8_t x_111; -x_109 = lean_ctor_get(x_108, 1); +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_156; uint8_t x_183; +x_107 = lean_ctor_get(x_27, 2); +lean_inc(x_107); +x_108 = lean_ctor_get(x_27, 3); +lean_inc(x_108); +x_109 = lean_ctor_get(x_27, 4); lean_inc(x_109); -x_110 = lean_ctor_get(x_108, 0); -lean_inc(x_110); -lean_dec(x_108); -x_111 = !lean_is_exclusive(x_109); -if (x_111 == 0) +lean_dec(x_27); +x_110 = l_Lean_Closure_instantiateMVars(x_108, x_2, x_3); +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_183 = l_Lean_Expr_hasLevelParam(x_111); +if (x_183 == 0) { -lean_object* x_112; lean_object* x_113; lean_object* x_114; -x_112 = lean_ctor_get(x_109, 3); -lean_inc(x_110); -x_113 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_112, x_102, x_110); -lean_ctor_set(x_109, 3, x_113); -x_114 = l_Lean_Closure_mkLetDecl(x_100, x_103, x_110, x_2, x_109); -lean_dec(x_2); -return x_114; +uint8_t x_184; +x_184 = l_Lean_Expr_hasFVar(x_111); +if (x_184 == 0) +{ +uint8_t x_185; +x_185 = l_Lean_Expr_hasMVar(x_111); +if (x_185 == 0) +{ +x_113 = x_111; +x_114 = x_112; +goto block_155; } else { -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_115 = lean_ctor_get(x_109, 0); -x_116 = lean_ctor_get(x_109, 1); -x_117 = lean_ctor_get(x_109, 2); -x_118 = lean_ctor_get(x_109, 3); -x_119 = lean_ctor_get(x_109, 4); -x_120 = lean_ctor_get(x_109, 5); -x_121 = lean_ctor_get(x_109, 6); -x_122 = lean_ctor_get(x_109, 7); -x_123 = lean_ctor_get(x_109, 8); -lean_inc(x_123); -lean_inc(x_122); -lean_inc(x_121); -lean_inc(x_120); -lean_inc(x_119); -lean_inc(x_118); -lean_inc(x_117); +lean_object* x_186; +x_186 = lean_box(0); +x_156 = x_186; +goto block_182; +} +} +else +{ +lean_object* x_187; +x_187 = lean_box(0); +x_156 = x_187; +goto block_182; +} +} +else +{ +lean_object* x_188; +x_188 = lean_box(0); +x_156 = x_188; +goto block_182; +} +block_155: +{ +lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; uint8_t x_148; +x_115 = l_Lean_Closure_instantiateMVars(x_109, x_2, x_114); +x_116 = lean_ctor_get(x_115, 0); lean_inc(x_116); -lean_inc(x_115); -lean_dec(x_109); -lean_inc(x_110); -x_124 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_118, x_102, x_110); -x_125 = lean_alloc_ctor(0, 9, 0); -lean_ctor_set(x_125, 0, x_115); -lean_ctor_set(x_125, 1, x_116); -lean_ctor_set(x_125, 2, x_117); -lean_ctor_set(x_125, 3, x_124); -lean_ctor_set(x_125, 4, x_119); -lean_ctor_set(x_125, 5, x_120); -lean_ctor_set(x_125, 6, x_121); -lean_ctor_set(x_125, 7, x_122); -lean_ctor_set(x_125, 8, x_123); -x_126 = l_Lean_Closure_mkLetDecl(x_100, x_103, x_110, x_2, x_125); -lean_dec(x_2); -return x_126; -} -} -else -{ -uint8_t x_127; -lean_dec(x_103); -lean_dec(x_102); -lean_dec(x_100); -lean_dec(x_2); -x_127 = !lean_is_exclusive(x_108); -if (x_127 == 0) -{ -return x_108; -} -else -{ -lean_object* x_128; lean_object* x_129; lean_object* x_130; -x_128 = lean_ctor_get(x_108, 0); -x_129 = lean_ctor_get(x_108, 1); -lean_inc(x_129); -lean_inc(x_128); -lean_dec(x_108); -x_130 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_130, 0, x_128); -lean_ctor_set(x_130, 1, x_129); -return x_130; -} -} -} -else -{ -lean_object* x_131; lean_object* x_132; -lean_dec(x_102); -x_131 = lean_ctor_get(x_107, 0); -lean_inc(x_131); -lean_dec(x_107); -x_132 = l_Lean_Closure_mkLetDecl(x_100, x_103, x_131, x_2, x_104); -lean_dec(x_2); -return x_132; -} -} -} -block_167: -{ -lean_object* x_143; lean_object* x_144; -lean_dec(x_142); -x_143 = lean_ctor_get(x_3, 3); -lean_inc(x_143); -x_144 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitExpr___spec__1(x_143, x_101); -lean_dec(x_143); -if (lean_obj_tag(x_144) == 0) -{ -lean_object* x_145; -lean_inc(x_2); -lean_inc(x_101); -x_145 = l_Lean_Closure_collectExprAux___main(x_101, x_2, x_3); -if (lean_obj_tag(x_145) == 0) -{ -lean_object* x_146; lean_object* x_147; uint8_t x_148; -x_146 = lean_ctor_get(x_145, 1); -lean_inc(x_146); -x_147 = lean_ctor_get(x_145, 0); -lean_inc(x_147); -lean_dec(x_145); -x_148 = !lean_is_exclusive(x_146); +x_117 = lean_ctor_get(x_115, 1); +lean_inc(x_117); +lean_dec(x_115); +x_148 = l_Lean_Expr_hasLevelParam(x_116); if (x_148 == 0) { -lean_object* x_149; lean_object* x_150; -x_149 = lean_ctor_get(x_146, 3); -lean_inc(x_147); -x_150 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_149, x_101, x_147); -lean_ctor_set(x_146, 3, x_150); -x_103 = x_147; -x_104 = x_146; -goto block_141; -} -else +uint8_t x_149; +x_149 = l_Lean_Expr_hasFVar(x_116); +if (x_149 == 0) { -lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; -x_151 = lean_ctor_get(x_146, 0); -x_152 = lean_ctor_get(x_146, 1); -x_153 = lean_ctor_get(x_146, 2); -x_154 = lean_ctor_get(x_146, 3); -x_155 = lean_ctor_get(x_146, 4); -x_156 = lean_ctor_get(x_146, 5); -x_157 = lean_ctor_get(x_146, 6); -x_158 = lean_ctor_get(x_146, 7); -x_159 = lean_ctor_get(x_146, 8); -lean_inc(x_159); -lean_inc(x_158); -lean_inc(x_157); -lean_inc(x_156); -lean_inc(x_155); -lean_inc(x_154); -lean_inc(x_153); -lean_inc(x_152); -lean_inc(x_151); -lean_dec(x_146); -lean_inc(x_147); -x_160 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_154, x_101, x_147); -x_161 = lean_alloc_ctor(0, 9, 0); -lean_ctor_set(x_161, 0, x_151); -lean_ctor_set(x_161, 1, x_152); -lean_ctor_set(x_161, 2, x_153); -lean_ctor_set(x_161, 3, x_160); -lean_ctor_set(x_161, 4, x_155); -lean_ctor_set(x_161, 5, x_156); -lean_ctor_set(x_161, 6, x_157); -lean_ctor_set(x_161, 7, x_158); -lean_ctor_set(x_161, 8, x_159); -x_103 = x_147; -x_104 = x_161; -goto block_141; -} -} -else +uint8_t x_150; +x_150 = l_Lean_Expr_hasMVar(x_116); +if (x_150 == 0) { -uint8_t x_162; -lean_dec(x_102); -lean_dec(x_101); -lean_dec(x_100); +lean_object* x_151; +x_151 = l_Lean_Closure_mkLetDecl(x_107, x_113, x_116, x_2, x_117); lean_dec(x_2); -x_162 = !lean_is_exclusive(x_145); +return x_151; +} +else +{ +lean_object* x_152; +x_152 = lean_box(0); +x_118 = x_152; +goto block_147; +} +} +else +{ +lean_object* x_153; +x_153 = lean_box(0); +x_118 = x_153; +goto block_147; +} +} +else +{ +lean_object* x_154; +x_154 = lean_box(0); +x_118 = x_154; +goto block_147; +} +block_147: +{ +lean_object* x_119; lean_object* x_120; +lean_dec(x_118); +x_119 = lean_ctor_get(x_117, 4); +lean_inc(x_119); +x_120 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitExpr___spec__1(x_119, x_116); +lean_dec(x_119); +if (lean_obj_tag(x_120) == 0) +{ +lean_object* x_121; +lean_inc(x_2); +lean_inc(x_116); +x_121 = l_Lean_Closure_collectExprAux___main(x_116, x_2, x_117); +if (lean_obj_tag(x_121) == 0) +{ +lean_object* x_122; lean_object* x_123; uint8_t x_124; +x_122 = lean_ctor_get(x_121, 1); +lean_inc(x_122); +x_123 = lean_ctor_get(x_121, 0); +lean_inc(x_123); +lean_dec(x_121); +x_124 = !lean_is_exclusive(x_122); +if (x_124 == 0) +{ +lean_object* x_125; lean_object* x_126; lean_object* x_127; +x_125 = lean_ctor_get(x_122, 4); +lean_inc(x_123); +x_126 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_125, x_116, x_123); +lean_ctor_set(x_122, 4, x_126); +x_127 = l_Lean_Closure_mkLetDecl(x_107, x_113, x_123, x_2, x_122); +lean_dec(x_2); +return x_127; +} +else +{ +lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; +x_128 = lean_ctor_get(x_122, 0); +x_129 = lean_ctor_get(x_122, 1); +x_130 = lean_ctor_get(x_122, 2); +x_131 = lean_ctor_get(x_122, 3); +x_132 = lean_ctor_get(x_122, 4); +x_133 = lean_ctor_get(x_122, 5); +x_134 = lean_ctor_get(x_122, 6); +x_135 = lean_ctor_get(x_122, 7); +x_136 = lean_ctor_get(x_122, 8); +x_137 = lean_ctor_get(x_122, 9); +lean_inc(x_137); +lean_inc(x_136); +lean_inc(x_135); +lean_inc(x_134); +lean_inc(x_133); +lean_inc(x_132); +lean_inc(x_131); +lean_inc(x_130); +lean_inc(x_129); +lean_inc(x_128); +lean_dec(x_122); +lean_inc(x_123); +x_138 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_132, x_116, x_123); +x_139 = lean_alloc_ctor(0, 10, 0); +lean_ctor_set(x_139, 0, x_128); +lean_ctor_set(x_139, 1, x_129); +lean_ctor_set(x_139, 2, x_130); +lean_ctor_set(x_139, 3, x_131); +lean_ctor_set(x_139, 4, x_138); +lean_ctor_set(x_139, 5, x_133); +lean_ctor_set(x_139, 6, x_134); +lean_ctor_set(x_139, 7, x_135); +lean_ctor_set(x_139, 8, x_136); +lean_ctor_set(x_139, 9, x_137); +x_140 = l_Lean_Closure_mkLetDecl(x_107, x_113, x_123, x_2, x_139); +lean_dec(x_2); +return x_140; +} +} +else +{ +uint8_t x_141; +lean_dec(x_116); +lean_dec(x_113); +lean_dec(x_107); +lean_dec(x_2); +x_141 = !lean_is_exclusive(x_121); +if (x_141 == 0) +{ +return x_121; +} +else +{ +lean_object* x_142; lean_object* x_143; lean_object* x_144; +x_142 = lean_ctor_get(x_121, 0); +x_143 = lean_ctor_get(x_121, 1); +lean_inc(x_143); +lean_inc(x_142); +lean_dec(x_121); +x_144 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_144, 0, x_142); +lean_ctor_set(x_144, 1, x_143); +return x_144; +} +} +} +else +{ +lean_object* x_145; lean_object* x_146; +lean_dec(x_116); +x_145 = lean_ctor_get(x_120, 0); +lean_inc(x_145); +lean_dec(x_120); +x_146 = l_Lean_Closure_mkLetDecl(x_107, x_113, x_145, x_2, x_117); +lean_dec(x_2); +return x_146; +} +} +} +block_182: +{ +lean_object* x_157; lean_object* x_158; +lean_dec(x_156); +x_157 = lean_ctor_get(x_112, 4); +lean_inc(x_157); +x_158 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitExpr___spec__1(x_157, x_111); +lean_dec(x_157); +if (lean_obj_tag(x_158) == 0) +{ +lean_object* x_159; +lean_inc(x_2); +lean_inc(x_111); +x_159 = l_Lean_Closure_collectExprAux___main(x_111, x_2, x_112); +if (lean_obj_tag(x_159) == 0) +{ +lean_object* x_160; lean_object* x_161; uint8_t x_162; +x_160 = lean_ctor_get(x_159, 1); +lean_inc(x_160); +x_161 = lean_ctor_get(x_159, 0); +lean_inc(x_161); +lean_dec(x_159); +x_162 = !lean_is_exclusive(x_160); if (x_162 == 0) { -return x_145; +lean_object* x_163; lean_object* x_164; +x_163 = lean_ctor_get(x_160, 4); +lean_inc(x_161); +x_164 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_163, x_111, x_161); +lean_ctor_set(x_160, 4, x_164); +x_113 = x_161; +x_114 = x_160; +goto block_155; } else { -lean_object* x_163; lean_object* x_164; lean_object* x_165; -x_163 = lean_ctor_get(x_145, 0); -x_164 = lean_ctor_get(x_145, 1); -lean_inc(x_164); -lean_inc(x_163); -lean_dec(x_145); -x_165 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_165, 0, x_163); -lean_ctor_set(x_165, 1, x_164); -return x_165; -} -} -} -else -{ -lean_object* x_166; -lean_dec(x_101); -x_166 = lean_ctor_get(x_144, 0); +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; +x_165 = lean_ctor_get(x_160, 0); +x_166 = lean_ctor_get(x_160, 1); +x_167 = lean_ctor_get(x_160, 2); +x_168 = lean_ctor_get(x_160, 3); +x_169 = lean_ctor_get(x_160, 4); +x_170 = lean_ctor_get(x_160, 5); +x_171 = lean_ctor_get(x_160, 6); +x_172 = lean_ctor_get(x_160, 7); +x_173 = lean_ctor_get(x_160, 8); +x_174 = lean_ctor_get(x_160, 9); +lean_inc(x_174); +lean_inc(x_173); +lean_inc(x_172); +lean_inc(x_171); +lean_inc(x_170); +lean_inc(x_169); +lean_inc(x_168); +lean_inc(x_167); lean_inc(x_166); -lean_dec(x_144); -x_103 = x_166; -x_104 = x_3; -goto block_141; +lean_inc(x_165); +lean_dec(x_160); +lean_inc(x_161); +x_175 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_169, x_111, x_161); +x_176 = lean_alloc_ctor(0, 10, 0); +lean_ctor_set(x_176, 0, x_165); +lean_ctor_set(x_176, 1, x_166); +lean_ctor_set(x_176, 2, x_167); +lean_ctor_set(x_176, 3, x_168); +lean_ctor_set(x_176, 4, x_175); +lean_ctor_set(x_176, 5, x_170); +lean_ctor_set(x_176, 6, x_171); +lean_ctor_set(x_176, 7, x_172); +lean_ctor_set(x_176, 8, x_173); +lean_ctor_set(x_176, 9, x_174); +x_113 = x_161; +x_114 = x_176; +goto block_155; +} +} +else +{ +uint8_t x_177; +lean_dec(x_111); +lean_dec(x_109); +lean_dec(x_107); +lean_dec(x_2); +x_177 = !lean_is_exclusive(x_159); +if (x_177 == 0) +{ +return x_159; +} +else +{ +lean_object* x_178; lean_object* x_179; lean_object* x_180; +x_178 = lean_ctor_get(x_159, 0); +x_179 = lean_ctor_get(x_159, 1); +lean_inc(x_179); +lean_inc(x_178); +lean_dec(x_159); +x_180 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_180, 0, x_178); +lean_ctor_set(x_180, 1, x_179); +return x_180; +} +} +} +else +{ +lean_object* x_181; +lean_dec(x_111); +x_181 = lean_ctor_get(x_158, 0); +lean_inc(x_181); +lean_dec(x_158); +x_113 = x_181; +x_114 = x_112; +goto block_155; +} +} +} +else +{ +lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; uint8_t x_240; +x_189 = lean_ctor_get(x_27, 4); +lean_inc(x_189); +lean_dec(x_27); +x_190 = l_Lean_Closure_instantiateMVars(x_189, x_2, x_3); +x_191 = lean_ctor_get(x_190, 0); +lean_inc(x_191); +x_192 = lean_ctor_get(x_190, 1); +lean_inc(x_192); +if (lean_is_exclusive(x_190)) { + lean_ctor_release(x_190, 0); + lean_ctor_release(x_190, 1); + x_193 = x_190; +} else { + lean_dec_ref(x_190); + x_193 = lean_box(0); +} +x_240 = l_Lean_Expr_hasLevelParam(x_191); +if (x_240 == 0) +{ +uint8_t x_241; +x_241 = l_Lean_Expr_hasFVar(x_191); +if (x_241 == 0) +{ +uint8_t x_242; +x_242 = l_Lean_Expr_hasMVar(x_191); +if (x_242 == 0) +{ +lean_object* x_243; +lean_dec(x_193); +lean_dec(x_2); +x_243 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_243, 0, x_191); +lean_ctor_set(x_243, 1, x_192); +return x_243; +} +else +{ +lean_object* x_244; +x_244 = lean_box(0); +x_194 = x_244; +goto block_239; +} +} +else +{ +lean_object* x_245; +x_245 = lean_box(0); +x_194 = x_245; +goto block_239; +} +} +else +{ +lean_object* x_246; +x_246 = lean_box(0); +x_194 = x_246; +goto block_239; +} +block_239: +{ +lean_object* x_195; lean_object* x_196; +lean_dec(x_194); +x_195 = lean_ctor_get(x_192, 4); +lean_inc(x_195); +x_196 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitExpr___spec__1(x_195, x_191); +lean_dec(x_195); +if (lean_obj_tag(x_196) == 0) +{ +lean_object* x_197; +lean_dec(x_193); +lean_inc(x_191); +x_197 = l_Lean_Closure_collectExprAux___main(x_191, x_2, x_192); +if (lean_obj_tag(x_197) == 0) +{ +uint8_t x_198; +x_198 = !lean_is_exclusive(x_197); +if (x_198 == 0) +{ +lean_object* x_199; uint8_t x_200; +x_199 = lean_ctor_get(x_197, 1); +x_200 = !lean_is_exclusive(x_199); +if (x_200 == 0) +{ +lean_object* x_201; lean_object* x_202; lean_object* x_203; +x_201 = lean_ctor_get(x_197, 0); +x_202 = lean_ctor_get(x_199, 4); +lean_inc(x_201); +x_203 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_202, x_191, x_201); +lean_ctor_set(x_199, 4, x_203); +return x_197; +} +else +{ +lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; +x_204 = lean_ctor_get(x_197, 0); +x_205 = lean_ctor_get(x_199, 0); +x_206 = lean_ctor_get(x_199, 1); +x_207 = lean_ctor_get(x_199, 2); +x_208 = lean_ctor_get(x_199, 3); +x_209 = lean_ctor_get(x_199, 4); +x_210 = lean_ctor_get(x_199, 5); +x_211 = lean_ctor_get(x_199, 6); +x_212 = lean_ctor_get(x_199, 7); +x_213 = lean_ctor_get(x_199, 8); +x_214 = lean_ctor_get(x_199, 9); +lean_inc(x_214); +lean_inc(x_213); +lean_inc(x_212); +lean_inc(x_211); +lean_inc(x_210); +lean_inc(x_209); +lean_inc(x_208); +lean_inc(x_207); +lean_inc(x_206); +lean_inc(x_205); +lean_dec(x_199); +lean_inc(x_204); +x_215 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_209, x_191, x_204); +x_216 = lean_alloc_ctor(0, 10, 0); +lean_ctor_set(x_216, 0, x_205); +lean_ctor_set(x_216, 1, x_206); +lean_ctor_set(x_216, 2, x_207); +lean_ctor_set(x_216, 3, x_208); +lean_ctor_set(x_216, 4, x_215); +lean_ctor_set(x_216, 5, x_210); +lean_ctor_set(x_216, 6, x_211); +lean_ctor_set(x_216, 7, x_212); +lean_ctor_set(x_216, 8, x_213); +lean_ctor_set(x_216, 9, x_214); +lean_ctor_set(x_197, 1, x_216); +return x_197; +} +} +else +{ +lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; lean_object* x_224; lean_object* x_225; lean_object* x_226; lean_object* x_227; lean_object* x_228; lean_object* x_229; lean_object* x_230; lean_object* x_231; lean_object* x_232; +x_217 = lean_ctor_get(x_197, 1); +x_218 = lean_ctor_get(x_197, 0); +lean_inc(x_217); +lean_inc(x_218); +lean_dec(x_197); +x_219 = lean_ctor_get(x_217, 0); +lean_inc(x_219); +x_220 = lean_ctor_get(x_217, 1); +lean_inc(x_220); +x_221 = lean_ctor_get(x_217, 2); +lean_inc(x_221); +x_222 = lean_ctor_get(x_217, 3); +lean_inc(x_222); +x_223 = lean_ctor_get(x_217, 4); +lean_inc(x_223); +x_224 = lean_ctor_get(x_217, 5); +lean_inc(x_224); +x_225 = lean_ctor_get(x_217, 6); +lean_inc(x_225); +x_226 = lean_ctor_get(x_217, 7); +lean_inc(x_226); +x_227 = lean_ctor_get(x_217, 8); +lean_inc(x_227); +x_228 = lean_ctor_get(x_217, 9); +lean_inc(x_228); +if (lean_is_exclusive(x_217)) { + lean_ctor_release(x_217, 0); + lean_ctor_release(x_217, 1); + lean_ctor_release(x_217, 2); + lean_ctor_release(x_217, 3); + lean_ctor_release(x_217, 4); + lean_ctor_release(x_217, 5); + lean_ctor_release(x_217, 6); + lean_ctor_release(x_217, 7); + lean_ctor_release(x_217, 8); + lean_ctor_release(x_217, 9); + x_229 = x_217; +} else { + lean_dec_ref(x_217); + x_229 = lean_box(0); +} +lean_inc(x_218); +x_230 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_223, x_191, x_218); +if (lean_is_scalar(x_229)) { + x_231 = lean_alloc_ctor(0, 10, 0); +} else { + x_231 = x_229; +} +lean_ctor_set(x_231, 0, x_219); +lean_ctor_set(x_231, 1, x_220); +lean_ctor_set(x_231, 2, x_221); +lean_ctor_set(x_231, 3, x_222); +lean_ctor_set(x_231, 4, x_230); +lean_ctor_set(x_231, 5, x_224); +lean_ctor_set(x_231, 6, x_225); +lean_ctor_set(x_231, 7, x_226); +lean_ctor_set(x_231, 8, x_227); +lean_ctor_set(x_231, 9, x_228); +x_232 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_232, 0, x_218); +lean_ctor_set(x_232, 1, x_231); +return x_232; +} +} +else +{ +uint8_t x_233; +lean_dec(x_191); +x_233 = !lean_is_exclusive(x_197); +if (x_233 == 0) +{ +return x_197; +} +else +{ +lean_object* x_234; lean_object* x_235; lean_object* x_236; +x_234 = lean_ctor_get(x_197, 0); +x_235 = lean_ctor_get(x_197, 1); +lean_inc(x_235); +lean_inc(x_234); +lean_dec(x_197); +x_236 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_236, 0, x_234); +lean_ctor_set(x_236, 1, x_235); +return x_236; +} +} +} +else +{ +lean_object* x_237; lean_object* x_238; +lean_dec(x_191); +lean_dec(x_2); +x_237 = lean_ctor_get(x_196, 0); +lean_inc(x_237); +lean_dec(x_196); +if (lean_is_scalar(x_193)) { + x_238 = lean_alloc_ctor(0, 2, 0); +} else { + x_238 = x_193; +} +lean_ctor_set(x_238, 0, x_237); +lean_ctor_set(x_238, 1, x_192); +return x_238; +} } } } @@ -4029,1816 +4077,1628 @@ goto block_141; } case 2: { -lean_object* x_226; lean_object* x_227; lean_object* x_228; lean_object* x_264; lean_object* x_265; -x_226 = lean_ctor_get(x_1, 0); -lean_inc(x_226); -x_264 = lean_ctor_get(x_2, 0); -lean_inc(x_264); -lean_inc(x_226); -lean_inc(x_264); -x_265 = lean_metavar_ctx_find_decl(x_264, x_226); -if (lean_obj_tag(x_265) == 0) +lean_object* x_247; lean_object* x_248; uint8_t x_249; +x_247 = lean_ctor_get(x_1, 0); +lean_inc(x_247); +x_248 = l_Lean_Closure_getMCtx___rarg(x_3); +x_249 = !lean_is_exclusive(x_248); +if (x_249 == 0) { -lean_object* x_266; lean_object* x_267; -lean_dec(x_264); -lean_dec(x_226); +lean_object* x_250; lean_object* x_251; lean_object* x_252; +x_250 = lean_ctor_get(x_248, 0); +x_251 = lean_ctor_get(x_248, 1); +x_252 = lean_metavar_ctx_find_decl(x_250, x_247); +if (lean_obj_tag(x_252) == 0) +{ +lean_object* x_253; lean_dec(x_2); lean_dec(x_1); -x_266 = l_Lean_MetavarContext_getDecl___closed__2; -x_267 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_267, 0, x_266); -lean_ctor_set(x_267, 1, x_3); -return x_267; +x_253 = l_Lean_MetavarContext_getDecl___closed__2; +lean_ctor_set_tag(x_248, 1); +lean_ctor_set(x_248, 0, x_253); +return x_248; } else { -lean_object* x_268; lean_object* x_269; -x_268 = lean_ctor_get(x_265, 0); -lean_inc(x_268); -lean_dec(x_265); -x_269 = lean_metavar_ctx_get_expr_assignment(x_264, x_226); -if (lean_obj_tag(x_269) == 0) +lean_object* x_254; lean_object* x_255; lean_object* x_256; lean_object* x_257; lean_object* x_258; lean_object* x_259; lean_object* x_260; lean_object* x_298; uint8_t x_325; +lean_free_object(x_248); +x_254 = lean_ctor_get(x_252, 0); +lean_inc(x_254); +lean_dec(x_252); +x_255 = lean_ctor_get(x_254, 2); +lean_inc(x_255); +lean_dec(x_254); +x_256 = l_Lean_Closure_instantiateMVars(x_255, x_2, x_251); +x_257 = lean_ctor_get(x_256, 0); +lean_inc(x_257); +x_258 = lean_ctor_get(x_256, 1); +lean_inc(x_258); +lean_dec(x_256); +x_325 = l_Lean_Expr_hasLevelParam(x_257); +if (x_325 == 0) { -lean_object* x_270; lean_object* x_271; uint8_t x_297; -x_270 = lean_ctor_get(x_268, 2); +uint8_t x_326; +x_326 = l_Lean_Expr_hasFVar(x_257); +if (x_326 == 0) +{ +uint8_t x_327; +x_327 = l_Lean_Expr_hasMVar(x_257); +if (x_327 == 0) +{ +x_259 = x_257; +x_260 = x_258; +goto block_297; +} +else +{ +lean_object* x_328; +x_328 = lean_box(0); +x_298 = x_328; +goto block_324; +} +} +else +{ +lean_object* x_329; +x_329 = lean_box(0); +x_298 = x_329; +goto block_324; +} +} +else +{ +lean_object* x_330; +x_330 = lean_box(0); +x_298 = x_330; +goto block_324; +} +block_297: +{ +lean_object* x_261; uint8_t x_262; lean_object* x_263; uint8_t x_264; +x_261 = lean_box(0); +x_262 = 0; +x_263 = l_Lean_Closure_mkLocalDecl(x_261, x_259, x_262, x_2, x_260); +lean_dec(x_2); +x_264 = !lean_is_exclusive(x_263); +if (x_264 == 0) +{ +lean_object* x_265; uint8_t x_266; +x_265 = lean_ctor_get(x_263, 1); +x_266 = !lean_is_exclusive(x_265); +if (x_266 == 0) +{ +lean_object* x_267; lean_object* x_268; +x_267 = lean_ctor_get(x_265, 9); +x_268 = lean_array_push(x_267, x_1); +lean_ctor_set(x_265, 9, x_268); +return x_263; +} +else +{ +lean_object* x_269; lean_object* x_270; lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_object* x_276; lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; +x_269 = lean_ctor_get(x_265, 0); +x_270 = lean_ctor_get(x_265, 1); +x_271 = lean_ctor_get(x_265, 2); +x_272 = lean_ctor_get(x_265, 3); +x_273 = lean_ctor_get(x_265, 4); +x_274 = lean_ctor_get(x_265, 5); +x_275 = lean_ctor_get(x_265, 6); +x_276 = lean_ctor_get(x_265, 7); +x_277 = lean_ctor_get(x_265, 8); +x_278 = lean_ctor_get(x_265, 9); +lean_inc(x_278); +lean_inc(x_277); +lean_inc(x_276); +lean_inc(x_275); +lean_inc(x_274); +lean_inc(x_273); +lean_inc(x_272); +lean_inc(x_271); lean_inc(x_270); -lean_dec(x_268); -x_297 = l_Lean_Expr_hasLevelParam(x_270); -if (x_297 == 0) -{ -uint8_t x_298; -x_298 = l_Lean_Expr_hasFVar(x_270); -if (x_298 == 0) -{ -uint8_t x_299; -x_299 = l_Lean_Expr_hasMVar(x_270); -if (x_299 == 0) -{ -x_227 = x_270; -x_228 = x_3; -goto block_263; -} -else -{ -lean_object* x_300; -x_300 = lean_box(0); -x_271 = x_300; -goto block_296; +lean_inc(x_269); +lean_dec(x_265); +x_279 = lean_array_push(x_278, x_1); +x_280 = lean_alloc_ctor(0, 10, 0); +lean_ctor_set(x_280, 0, x_269); +lean_ctor_set(x_280, 1, x_270); +lean_ctor_set(x_280, 2, x_271); +lean_ctor_set(x_280, 3, x_272); +lean_ctor_set(x_280, 4, x_273); +lean_ctor_set(x_280, 5, x_274); +lean_ctor_set(x_280, 6, x_275); +lean_ctor_set(x_280, 7, x_276); +lean_ctor_set(x_280, 8, x_277); +lean_ctor_set(x_280, 9, x_279); +lean_ctor_set(x_263, 1, x_280); +return x_263; } } else { +lean_object* x_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; lean_object* x_289; lean_object* x_290; lean_object* x_291; lean_object* x_292; lean_object* x_293; lean_object* x_294; lean_object* x_295; lean_object* x_296; +x_281 = lean_ctor_get(x_263, 1); +x_282 = lean_ctor_get(x_263, 0); +lean_inc(x_281); +lean_inc(x_282); +lean_dec(x_263); +x_283 = lean_ctor_get(x_281, 0); +lean_inc(x_283); +x_284 = lean_ctor_get(x_281, 1); +lean_inc(x_284); +x_285 = lean_ctor_get(x_281, 2); +lean_inc(x_285); +x_286 = lean_ctor_get(x_281, 3); +lean_inc(x_286); +x_287 = lean_ctor_get(x_281, 4); +lean_inc(x_287); +x_288 = lean_ctor_get(x_281, 5); +lean_inc(x_288); +x_289 = lean_ctor_get(x_281, 6); +lean_inc(x_289); +x_290 = lean_ctor_get(x_281, 7); +lean_inc(x_290); +x_291 = lean_ctor_get(x_281, 8); +lean_inc(x_291); +x_292 = lean_ctor_get(x_281, 9); +lean_inc(x_292); +if (lean_is_exclusive(x_281)) { + lean_ctor_release(x_281, 0); + lean_ctor_release(x_281, 1); + lean_ctor_release(x_281, 2); + lean_ctor_release(x_281, 3); + lean_ctor_release(x_281, 4); + lean_ctor_release(x_281, 5); + lean_ctor_release(x_281, 6); + lean_ctor_release(x_281, 7); + lean_ctor_release(x_281, 8); + lean_ctor_release(x_281, 9); + x_293 = x_281; +} else { + lean_dec_ref(x_281); + x_293 = lean_box(0); +} +x_294 = lean_array_push(x_292, x_1); +if (lean_is_scalar(x_293)) { + x_295 = lean_alloc_ctor(0, 10, 0); +} else { + x_295 = x_293; +} +lean_ctor_set(x_295, 0, x_283); +lean_ctor_set(x_295, 1, x_284); +lean_ctor_set(x_295, 2, x_285); +lean_ctor_set(x_295, 3, x_286); +lean_ctor_set(x_295, 4, x_287); +lean_ctor_set(x_295, 5, x_288); +lean_ctor_set(x_295, 6, x_289); +lean_ctor_set(x_295, 7, x_290); +lean_ctor_set(x_295, 8, x_291); +lean_ctor_set(x_295, 9, x_294); +x_296 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_296, 0, x_282); +lean_ctor_set(x_296, 1, x_295); +return x_296; +} +} +block_324: +{ +lean_object* x_299; lean_object* x_300; +lean_dec(x_298); +x_299 = lean_ctor_get(x_258, 4); +lean_inc(x_299); +x_300 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitExpr___spec__1(x_299, x_257); +lean_dec(x_299); +if (lean_obj_tag(x_300) == 0) +{ lean_object* x_301; -x_301 = lean_box(0); -x_271 = x_301; -goto block_296; -} -} -else -{ -lean_object* x_302; -x_302 = lean_box(0); -x_271 = x_302; -goto block_296; -} -block_296: -{ -lean_object* x_272; lean_object* x_273; -lean_dec(x_271); -x_272 = lean_ctor_get(x_3, 3); -lean_inc(x_272); -x_273 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitExpr___spec__1(x_272, x_270); -lean_dec(x_272); -if (lean_obj_tag(x_273) == 0) -{ -lean_object* x_274; lean_inc(x_2); -lean_inc(x_270); -x_274 = l_Lean_Closure_collectExprAux___main(x_270, x_2, x_3); -if (lean_obj_tag(x_274) == 0) +lean_inc(x_257); +x_301 = l_Lean_Closure_collectExprAux___main(x_257, x_2, x_258); +if (lean_obj_tag(x_301) == 0) { -lean_object* x_275; lean_object* x_276; uint8_t x_277; -x_275 = lean_ctor_get(x_274, 1); -lean_inc(x_275); -x_276 = lean_ctor_get(x_274, 0); -lean_inc(x_276); -lean_dec(x_274); -x_277 = !lean_is_exclusive(x_275); -if (x_277 == 0) -{ -lean_object* x_278; lean_object* x_279; -x_278 = lean_ctor_get(x_275, 3); -lean_inc(x_276); -x_279 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_278, x_270, x_276); -lean_ctor_set(x_275, 3, x_279); -x_227 = x_276; -x_228 = x_275; -goto block_263; -} -else -{ -lean_object* x_280; lean_object* x_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; lean_object* x_289; lean_object* x_290; -x_280 = lean_ctor_get(x_275, 0); -x_281 = lean_ctor_get(x_275, 1); -x_282 = lean_ctor_get(x_275, 2); -x_283 = lean_ctor_get(x_275, 3); -x_284 = lean_ctor_get(x_275, 4); -x_285 = lean_ctor_get(x_275, 5); -x_286 = lean_ctor_get(x_275, 6); -x_287 = lean_ctor_get(x_275, 7); -x_288 = lean_ctor_get(x_275, 8); -lean_inc(x_288); -lean_inc(x_287); -lean_inc(x_286); -lean_inc(x_285); -lean_inc(x_284); -lean_inc(x_283); -lean_inc(x_282); -lean_inc(x_281); -lean_inc(x_280); -lean_dec(x_275); -lean_inc(x_276); -x_289 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_283, x_270, x_276); -x_290 = lean_alloc_ctor(0, 9, 0); -lean_ctor_set(x_290, 0, x_280); -lean_ctor_set(x_290, 1, x_281); -lean_ctor_set(x_290, 2, x_282); -lean_ctor_set(x_290, 3, x_289); -lean_ctor_set(x_290, 4, x_284); -lean_ctor_set(x_290, 5, x_285); -lean_ctor_set(x_290, 6, x_286); -lean_ctor_set(x_290, 7, x_287); -lean_ctor_set(x_290, 8, x_288); -x_227 = x_276; -x_228 = x_290; -goto block_263; -} -} -else -{ -uint8_t x_291; -lean_dec(x_270); -lean_dec(x_2); -lean_dec(x_1); -x_291 = !lean_is_exclusive(x_274); -if (x_291 == 0) -{ -return x_274; -} -else -{ -lean_object* x_292; lean_object* x_293; lean_object* x_294; -x_292 = lean_ctor_get(x_274, 0); -x_293 = lean_ctor_get(x_274, 1); -lean_inc(x_293); -lean_inc(x_292); -lean_dec(x_274); -x_294 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_294, 0, x_292); -lean_ctor_set(x_294, 1, x_293); -return x_294; -} -} -} -else -{ -lean_object* x_295; -lean_dec(x_270); -x_295 = lean_ctor_get(x_273, 0); -lean_inc(x_295); -lean_dec(x_273); -x_227 = x_295; -x_228 = x_3; -goto block_263; -} -} -} -else -{ -lean_object* x_303; lean_object* x_304; uint8_t x_348; -lean_dec(x_268); -lean_dec(x_1); -x_303 = lean_ctor_get(x_269, 0); +lean_object* x_302; lean_object* x_303; uint8_t x_304; +x_302 = lean_ctor_get(x_301, 1); +lean_inc(x_302); +x_303 = lean_ctor_get(x_301, 0); lean_inc(x_303); -lean_dec(x_269); -x_348 = l_Lean_Expr_hasLevelParam(x_303); -if (x_348 == 0) -{ -uint8_t x_349; -x_349 = l_Lean_Expr_hasFVar(x_303); -if (x_349 == 0) -{ -uint8_t x_350; -x_350 = l_Lean_Expr_hasMVar(x_303); -if (x_350 == 0) -{ -lean_object* x_351; -lean_dec(x_2); -x_351 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_351, 0, x_303); -lean_ctor_set(x_351, 1, x_3); -return x_351; -} -else -{ -lean_object* x_352; -x_352 = lean_box(0); -x_304 = x_352; -goto block_347; -} -} -else -{ -lean_object* x_353; -x_353 = lean_box(0); -x_304 = x_353; -goto block_347; -} -} -else -{ -lean_object* x_354; -x_354 = lean_box(0); -x_304 = x_354; -goto block_347; -} -block_347: +lean_dec(x_301); +x_304 = !lean_is_exclusive(x_302); +if (x_304 == 0) { lean_object* x_305; lean_object* x_306; -lean_dec(x_304); -x_305 = lean_ctor_get(x_3, 3); -lean_inc(x_305); -x_306 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitExpr___spec__1(x_305, x_303); -lean_dec(x_305); -if (lean_obj_tag(x_306) == 0) -{ -lean_object* x_307; +x_305 = lean_ctor_get(x_302, 4); lean_inc(x_303); -x_307 = l_Lean_Closure_collectExprAux___main(x_303, x_2, x_3); -if (lean_obj_tag(x_307) == 0) -{ -uint8_t x_308; -x_308 = !lean_is_exclusive(x_307); -if (x_308 == 0) -{ -lean_object* x_309; uint8_t x_310; -x_309 = lean_ctor_get(x_307, 1); -x_310 = !lean_is_exclusive(x_309); -if (x_310 == 0) -{ -lean_object* x_311; lean_object* x_312; lean_object* x_313; -x_311 = lean_ctor_get(x_307, 0); -x_312 = lean_ctor_get(x_309, 3); -lean_inc(x_311); -x_313 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_312, x_303, x_311); -lean_ctor_set(x_309, 3, x_313); -return x_307; +x_306 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_305, x_257, x_303); +lean_ctor_set(x_302, 4, x_306); +x_259 = x_303; +x_260 = x_302; +goto block_297; } else { -lean_object* x_314; lean_object* x_315; lean_object* x_316; lean_object* x_317; lean_object* x_318; lean_object* x_319; lean_object* x_320; lean_object* x_321; lean_object* x_322; lean_object* x_323; lean_object* x_324; lean_object* x_325; -x_314 = lean_ctor_get(x_307, 0); -x_315 = lean_ctor_get(x_309, 0); -x_316 = lean_ctor_get(x_309, 1); -x_317 = lean_ctor_get(x_309, 2); -x_318 = lean_ctor_get(x_309, 3); -x_319 = lean_ctor_get(x_309, 4); -x_320 = lean_ctor_get(x_309, 5); -x_321 = lean_ctor_get(x_309, 6); -x_322 = lean_ctor_get(x_309, 7); -x_323 = lean_ctor_get(x_309, 8); -lean_inc(x_323); -lean_inc(x_322); -lean_inc(x_321); -lean_inc(x_320); -lean_inc(x_319); -lean_inc(x_318); -lean_inc(x_317); +lean_object* x_307; lean_object* x_308; lean_object* x_309; lean_object* x_310; lean_object* x_311; lean_object* x_312; lean_object* x_313; lean_object* x_314; lean_object* x_315; lean_object* x_316; lean_object* x_317; lean_object* x_318; +x_307 = lean_ctor_get(x_302, 0); +x_308 = lean_ctor_get(x_302, 1); +x_309 = lean_ctor_get(x_302, 2); +x_310 = lean_ctor_get(x_302, 3); +x_311 = lean_ctor_get(x_302, 4); +x_312 = lean_ctor_get(x_302, 5); +x_313 = lean_ctor_get(x_302, 6); +x_314 = lean_ctor_get(x_302, 7); +x_315 = lean_ctor_get(x_302, 8); +x_316 = lean_ctor_get(x_302, 9); lean_inc(x_316); lean_inc(x_315); -lean_dec(x_309); lean_inc(x_314); -x_324 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_318, x_303, x_314); -x_325 = lean_alloc_ctor(0, 9, 0); -lean_ctor_set(x_325, 0, x_315); -lean_ctor_set(x_325, 1, x_316); -lean_ctor_set(x_325, 2, x_317); -lean_ctor_set(x_325, 3, x_324); -lean_ctor_set(x_325, 4, x_319); -lean_ctor_set(x_325, 5, x_320); -lean_ctor_set(x_325, 6, x_321); -lean_ctor_set(x_325, 7, x_322); -lean_ctor_set(x_325, 8, x_323); -lean_ctor_set(x_307, 1, x_325); -return x_307; +lean_inc(x_313); +lean_inc(x_312); +lean_inc(x_311); +lean_inc(x_310); +lean_inc(x_309); +lean_inc(x_308); +lean_inc(x_307); +lean_dec(x_302); +lean_inc(x_303); +x_317 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_311, x_257, x_303); +x_318 = lean_alloc_ctor(0, 10, 0); +lean_ctor_set(x_318, 0, x_307); +lean_ctor_set(x_318, 1, x_308); +lean_ctor_set(x_318, 2, x_309); +lean_ctor_set(x_318, 3, x_310); +lean_ctor_set(x_318, 4, x_317); +lean_ctor_set(x_318, 5, x_312); +lean_ctor_set(x_318, 6, x_313); +lean_ctor_set(x_318, 7, x_314); +lean_ctor_set(x_318, 8, x_315); +lean_ctor_set(x_318, 9, x_316); +x_259 = x_303; +x_260 = x_318; +goto block_297; } } else { -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; lean_object* x_339; lean_object* x_340; -x_326 = lean_ctor_get(x_307, 1); -x_327 = lean_ctor_get(x_307, 0); -lean_inc(x_326); -lean_inc(x_327); -lean_dec(x_307); -x_328 = lean_ctor_get(x_326, 0); -lean_inc(x_328); -x_329 = lean_ctor_get(x_326, 1); -lean_inc(x_329); -x_330 = lean_ctor_get(x_326, 2); -lean_inc(x_330); -x_331 = lean_ctor_get(x_326, 3); -lean_inc(x_331); -x_332 = lean_ctor_get(x_326, 4); +uint8_t x_319; +lean_dec(x_257); +lean_dec(x_2); +lean_dec(x_1); +x_319 = !lean_is_exclusive(x_301); +if (x_319 == 0) +{ +return x_301; +} +else +{ +lean_object* x_320; lean_object* x_321; lean_object* x_322; +x_320 = lean_ctor_get(x_301, 0); +x_321 = lean_ctor_get(x_301, 1); +lean_inc(x_321); +lean_inc(x_320); +lean_dec(x_301); +x_322 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_322, 0, x_320); +lean_ctor_set(x_322, 1, x_321); +return x_322; +} +} +} +else +{ +lean_object* x_323; +lean_dec(x_257); +x_323 = lean_ctor_get(x_300, 0); +lean_inc(x_323); +lean_dec(x_300); +x_259 = x_323; +x_260 = x_258; +goto block_297; +} +} +} +} +else +{ +lean_object* x_331; lean_object* x_332; lean_object* x_333; +x_331 = lean_ctor_get(x_248, 0); +x_332 = lean_ctor_get(x_248, 1); lean_inc(x_332); -x_333 = lean_ctor_get(x_326, 5); -lean_inc(x_333); -x_334 = lean_ctor_get(x_326, 6); -lean_inc(x_334); -x_335 = lean_ctor_get(x_326, 7); -lean_inc(x_335); -x_336 = lean_ctor_get(x_326, 8); +lean_inc(x_331); +lean_dec(x_248); +x_333 = lean_metavar_ctx_find_decl(x_331, x_247); +if (lean_obj_tag(x_333) == 0) +{ +lean_object* x_334; lean_object* x_335; +lean_dec(x_2); +lean_dec(x_1); +x_334 = l_Lean_MetavarContext_getDecl___closed__2; +x_335 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_335, 0, x_334); +lean_ctor_set(x_335, 1, x_332); +return x_335; +} +else +{ +lean_object* x_336; lean_object* x_337; lean_object* x_338; lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_364; uint8_t x_389; +x_336 = lean_ctor_get(x_333, 0); lean_inc(x_336); -if (lean_is_exclusive(x_326)) { - lean_ctor_release(x_326, 0); - lean_ctor_release(x_326, 1); - lean_ctor_release(x_326, 2); - lean_ctor_release(x_326, 3); - lean_ctor_release(x_326, 4); - lean_ctor_release(x_326, 5); - lean_ctor_release(x_326, 6); - lean_ctor_release(x_326, 7); - lean_ctor_release(x_326, 8); - x_337 = x_326; -} else { - lean_dec_ref(x_326); - x_337 = lean_box(0); +lean_dec(x_333); +x_337 = lean_ctor_get(x_336, 2); +lean_inc(x_337); +lean_dec(x_336); +x_338 = l_Lean_Closure_instantiateMVars(x_337, x_2, x_332); +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); +x_389 = l_Lean_Expr_hasLevelParam(x_339); +if (x_389 == 0) +{ +uint8_t x_390; +x_390 = l_Lean_Expr_hasFVar(x_339); +if (x_390 == 0) +{ +uint8_t x_391; +x_391 = l_Lean_Expr_hasMVar(x_339); +if (x_391 == 0) +{ +x_341 = x_339; +x_342 = x_340; +goto block_363; } -lean_inc(x_327); -x_338 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_331, x_303, x_327); -if (lean_is_scalar(x_337)) { - x_339 = lean_alloc_ctor(0, 9, 0); -} else { - x_339 = x_337; -} -lean_ctor_set(x_339, 0, x_328); -lean_ctor_set(x_339, 1, x_329); -lean_ctor_set(x_339, 2, x_330); -lean_ctor_set(x_339, 3, x_338); -lean_ctor_set(x_339, 4, x_332); -lean_ctor_set(x_339, 5, x_333); -lean_ctor_set(x_339, 6, x_334); -lean_ctor_set(x_339, 7, x_335); -lean_ctor_set(x_339, 8, x_336); -x_340 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_340, 0, x_327); -lean_ctor_set(x_340, 1, x_339); -return x_340; +else +{ +lean_object* x_392; +x_392 = lean_box(0); +x_364 = x_392; +goto block_388; } } else { -uint8_t x_341; -lean_dec(x_303); -x_341 = !lean_is_exclusive(x_307); -if (x_341 == 0) -{ -return x_307; -} -else -{ -lean_object* x_342; lean_object* x_343; lean_object* x_344; -x_342 = lean_ctor_get(x_307, 0); -x_343 = lean_ctor_get(x_307, 1); -lean_inc(x_343); -lean_inc(x_342); -lean_dec(x_307); -x_344 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_344, 0, x_342); -lean_ctor_set(x_344, 1, x_343); -return x_344; -} +lean_object* x_393; +x_393 = lean_box(0); +x_364 = x_393; +goto block_388; } } else { -lean_object* x_345; lean_object* x_346; -lean_dec(x_303); +lean_object* x_394; +x_394 = lean_box(0); +x_364 = x_394; +goto block_388; +} +block_363: +{ +lean_object* x_343; uint8_t x_344; lean_object* x_345; lean_object* x_346; lean_object* x_347; lean_object* x_348; lean_object* x_349; lean_object* x_350; lean_object* x_351; lean_object* x_352; lean_object* x_353; lean_object* x_354; lean_object* x_355; lean_object* x_356; lean_object* x_357; lean_object* x_358; lean_object* x_359; lean_object* x_360; lean_object* x_361; lean_object* x_362; +x_343 = lean_box(0); +x_344 = 0; +x_345 = l_Lean_Closure_mkLocalDecl(x_343, x_341, x_344, x_2, x_342); lean_dec(x_2); -x_345 = lean_ctor_get(x_306, 0); -lean_inc(x_345); -lean_dec(x_306); -x_346 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_346, 0, x_345); -lean_ctor_set(x_346, 1, x_3); -return x_346; +x_346 = lean_ctor_get(x_345, 1); +lean_inc(x_346); +x_347 = lean_ctor_get(x_345, 0); +lean_inc(x_347); +if (lean_is_exclusive(x_345)) { + lean_ctor_release(x_345, 0); + lean_ctor_release(x_345, 1); + x_348 = x_345; +} else { + lean_dec_ref(x_345); + x_348 = lean_box(0); } +x_349 = lean_ctor_get(x_346, 0); +lean_inc(x_349); +x_350 = lean_ctor_get(x_346, 1); +lean_inc(x_350); +x_351 = lean_ctor_get(x_346, 2); +lean_inc(x_351); +x_352 = lean_ctor_get(x_346, 3); +lean_inc(x_352); +x_353 = lean_ctor_get(x_346, 4); +lean_inc(x_353); +x_354 = lean_ctor_get(x_346, 5); +lean_inc(x_354); +x_355 = lean_ctor_get(x_346, 6); +lean_inc(x_355); +x_356 = lean_ctor_get(x_346, 7); +lean_inc(x_356); +x_357 = lean_ctor_get(x_346, 8); +lean_inc(x_357); +x_358 = lean_ctor_get(x_346, 9); +lean_inc(x_358); +if (lean_is_exclusive(x_346)) { + lean_ctor_release(x_346, 0); + lean_ctor_release(x_346, 1); + lean_ctor_release(x_346, 2); + lean_ctor_release(x_346, 3); + lean_ctor_release(x_346, 4); + lean_ctor_release(x_346, 5); + lean_ctor_release(x_346, 6); + lean_ctor_release(x_346, 7); + lean_ctor_release(x_346, 8); + lean_ctor_release(x_346, 9); + x_359 = x_346; +} else { + lean_dec_ref(x_346); + x_359 = lean_box(0); } +x_360 = lean_array_push(x_358, x_1); +if (lean_is_scalar(x_359)) { + x_361 = lean_alloc_ctor(0, 10, 0); +} else { + x_361 = x_359; } +lean_ctor_set(x_361, 0, x_349); +lean_ctor_set(x_361, 1, x_350); +lean_ctor_set(x_361, 2, x_351); +lean_ctor_set(x_361, 3, x_352); +lean_ctor_set(x_361, 4, x_353); +lean_ctor_set(x_361, 5, x_354); +lean_ctor_set(x_361, 6, x_355); +lean_ctor_set(x_361, 7, x_356); +lean_ctor_set(x_361, 8, x_357); +lean_ctor_set(x_361, 9, x_360); +if (lean_is_scalar(x_348)) { + x_362 = lean_alloc_ctor(0, 2, 0); +} else { + x_362 = x_348; } -block_263: +lean_ctor_set(x_362, 0, x_347); +lean_ctor_set(x_362, 1, x_361); +return x_362; +} +block_388: { -lean_object* x_229; uint8_t x_230; lean_object* x_231; uint8_t x_232; -x_229 = lean_box(0); -x_230 = 0; -x_231 = l_Lean_Closure_mkLocalDecl(x_229, x_227, x_230, x_2, x_228); +lean_object* x_365; lean_object* x_366; +lean_dec(x_364); +x_365 = lean_ctor_get(x_340, 4); +lean_inc(x_365); +x_366 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitExpr___spec__1(x_365, x_339); +lean_dec(x_365); +if (lean_obj_tag(x_366) == 0) +{ +lean_object* x_367; +lean_inc(x_2); +lean_inc(x_339); +x_367 = l_Lean_Closure_collectExprAux___main(x_339, x_2, x_340); +if (lean_obj_tag(x_367) == 0) +{ +lean_object* x_368; lean_object* x_369; lean_object* x_370; lean_object* x_371; lean_object* x_372; lean_object* x_373; lean_object* x_374; lean_object* x_375; 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; +x_368 = lean_ctor_get(x_367, 1); +lean_inc(x_368); +x_369 = lean_ctor_get(x_367, 0); +lean_inc(x_369); +lean_dec(x_367); +x_370 = lean_ctor_get(x_368, 0); +lean_inc(x_370); +x_371 = lean_ctor_get(x_368, 1); +lean_inc(x_371); +x_372 = lean_ctor_get(x_368, 2); +lean_inc(x_372); +x_373 = lean_ctor_get(x_368, 3); +lean_inc(x_373); +x_374 = lean_ctor_get(x_368, 4); +lean_inc(x_374); +x_375 = lean_ctor_get(x_368, 5); +lean_inc(x_375); +x_376 = lean_ctor_get(x_368, 6); +lean_inc(x_376); +x_377 = lean_ctor_get(x_368, 7); +lean_inc(x_377); +x_378 = lean_ctor_get(x_368, 8); +lean_inc(x_378); +x_379 = lean_ctor_get(x_368, 9); +lean_inc(x_379); +if (lean_is_exclusive(x_368)) { + lean_ctor_release(x_368, 0); + lean_ctor_release(x_368, 1); + lean_ctor_release(x_368, 2); + lean_ctor_release(x_368, 3); + lean_ctor_release(x_368, 4); + lean_ctor_release(x_368, 5); + lean_ctor_release(x_368, 6); + lean_ctor_release(x_368, 7); + lean_ctor_release(x_368, 8); + lean_ctor_release(x_368, 9); + x_380 = x_368; +} else { + lean_dec_ref(x_368); + x_380 = lean_box(0); +} +lean_inc(x_369); +x_381 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_374, x_339, x_369); +if (lean_is_scalar(x_380)) { + x_382 = lean_alloc_ctor(0, 10, 0); +} else { + x_382 = x_380; +} +lean_ctor_set(x_382, 0, x_370); +lean_ctor_set(x_382, 1, x_371); +lean_ctor_set(x_382, 2, x_372); +lean_ctor_set(x_382, 3, x_373); +lean_ctor_set(x_382, 4, x_381); +lean_ctor_set(x_382, 5, x_375); +lean_ctor_set(x_382, 6, x_376); +lean_ctor_set(x_382, 7, x_377); +lean_ctor_set(x_382, 8, x_378); +lean_ctor_set(x_382, 9, x_379); +x_341 = x_369; +x_342 = x_382; +goto block_363; +} +else +{ +lean_object* x_383; lean_object* x_384; lean_object* x_385; lean_object* x_386; +lean_dec(x_339); lean_dec(x_2); -x_232 = !lean_is_exclusive(x_231); -if (x_232 == 0) -{ -lean_object* x_233; uint8_t x_234; -x_233 = lean_ctor_get(x_231, 1); -x_234 = !lean_is_exclusive(x_233); -if (x_234 == 0) -{ -lean_object* x_235; lean_object* x_236; -x_235 = lean_ctor_get(x_233, 8); -x_236 = lean_array_push(x_235, x_1); -lean_ctor_set(x_233, 8, x_236); -return x_231; +lean_dec(x_1); +x_383 = lean_ctor_get(x_367, 0); +lean_inc(x_383); +x_384 = lean_ctor_get(x_367, 1); +lean_inc(x_384); +if (lean_is_exclusive(x_367)) { + lean_ctor_release(x_367, 0); + lean_ctor_release(x_367, 1); + x_385 = x_367; +} else { + lean_dec_ref(x_367); + x_385 = lean_box(0); } -else -{ -lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; lean_object* x_242; lean_object* x_243; lean_object* x_244; lean_object* x_245; lean_object* x_246; lean_object* x_247; -x_237 = lean_ctor_get(x_233, 0); -x_238 = lean_ctor_get(x_233, 1); -x_239 = lean_ctor_get(x_233, 2); -x_240 = lean_ctor_get(x_233, 3); -x_241 = lean_ctor_get(x_233, 4); -x_242 = lean_ctor_get(x_233, 5); -x_243 = lean_ctor_get(x_233, 6); -x_244 = lean_ctor_get(x_233, 7); -x_245 = lean_ctor_get(x_233, 8); -lean_inc(x_245); -lean_inc(x_244); -lean_inc(x_243); -lean_inc(x_242); -lean_inc(x_241); -lean_inc(x_240); -lean_inc(x_239); -lean_inc(x_238); -lean_inc(x_237); -lean_dec(x_233); -x_246 = lean_array_push(x_245, x_1); -x_247 = lean_alloc_ctor(0, 9, 0); -lean_ctor_set(x_247, 0, x_237); -lean_ctor_set(x_247, 1, x_238); -lean_ctor_set(x_247, 2, x_239); -lean_ctor_set(x_247, 3, x_240); -lean_ctor_set(x_247, 4, x_241); -lean_ctor_set(x_247, 5, x_242); -lean_ctor_set(x_247, 6, x_243); -lean_ctor_set(x_247, 7, x_244); -lean_ctor_set(x_247, 8, x_246); -lean_ctor_set(x_231, 1, x_247); -return x_231; +if (lean_is_scalar(x_385)) { + x_386 = lean_alloc_ctor(1, 2, 0); +} else { + x_386 = x_385; +} +lean_ctor_set(x_386, 0, x_383); +lean_ctor_set(x_386, 1, x_384); +return x_386; } } else { -lean_object* x_248; lean_object* x_249; lean_object* x_250; lean_object* x_251; lean_object* x_252; lean_object* x_253; lean_object* x_254; lean_object* x_255; lean_object* x_256; lean_object* x_257; lean_object* x_258; lean_object* x_259; lean_object* x_260; lean_object* x_261; lean_object* x_262; -x_248 = lean_ctor_get(x_231, 1); -x_249 = lean_ctor_get(x_231, 0); -lean_inc(x_248); -lean_inc(x_249); -lean_dec(x_231); -x_250 = lean_ctor_get(x_248, 0); -lean_inc(x_250); -x_251 = lean_ctor_get(x_248, 1); -lean_inc(x_251); -x_252 = lean_ctor_get(x_248, 2); -lean_inc(x_252); -x_253 = lean_ctor_get(x_248, 3); -lean_inc(x_253); -x_254 = lean_ctor_get(x_248, 4); -lean_inc(x_254); -x_255 = lean_ctor_get(x_248, 5); -lean_inc(x_255); -x_256 = lean_ctor_get(x_248, 6); -lean_inc(x_256); -x_257 = lean_ctor_get(x_248, 7); -lean_inc(x_257); -x_258 = lean_ctor_get(x_248, 8); -lean_inc(x_258); -if (lean_is_exclusive(x_248)) { - lean_ctor_release(x_248, 0); - lean_ctor_release(x_248, 1); - lean_ctor_release(x_248, 2); - lean_ctor_release(x_248, 3); - lean_ctor_release(x_248, 4); - lean_ctor_release(x_248, 5); - lean_ctor_release(x_248, 6); - lean_ctor_release(x_248, 7); - lean_ctor_release(x_248, 8); - x_259 = x_248; -} else { - lean_dec_ref(x_248); - x_259 = lean_box(0); +lean_object* x_387; +lean_dec(x_339); +x_387 = lean_ctor_get(x_366, 0); +lean_inc(x_387); +lean_dec(x_366); +x_341 = x_387; +x_342 = x_340; +goto block_363; } -x_260 = lean_array_push(x_258, x_1); -if (lean_is_scalar(x_259)) { - x_261 = lean_alloc_ctor(0, 9, 0); -} else { - x_261 = x_259; } -lean_ctor_set(x_261, 0, x_250); -lean_ctor_set(x_261, 1, x_251); -lean_ctor_set(x_261, 2, x_252); -lean_ctor_set(x_261, 3, x_253); -lean_ctor_set(x_261, 4, x_254); -lean_ctor_set(x_261, 5, x_255); -lean_ctor_set(x_261, 6, x_256); -lean_ctor_set(x_261, 7, x_257); -lean_ctor_set(x_261, 8, x_260); -x_262 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_262, 0, x_249); -lean_ctor_set(x_262, 1, x_261); -return x_262; } } } case 3: { -lean_object* x_355; lean_object* x_356; uint8_t x_357; -x_355 = lean_ctor_get(x_1, 0); -lean_inc(x_355); -x_356 = l_Lean_Closure_collectLevel(x_355, x_2, x_3); -x_357 = !lean_is_exclusive(x_356); -if (x_357 == 0) +lean_object* x_395; lean_object* x_396; uint8_t x_397; +x_395 = lean_ctor_get(x_1, 0); +lean_inc(x_395); +x_396 = l_Lean_Closure_collectLevel(x_395, x_2, x_3); +lean_dec(x_2); +x_397 = !lean_is_exclusive(x_396); +if (x_397 == 0) { -lean_object* x_358; lean_object* x_359; -x_358 = lean_ctor_get(x_356, 0); -x_359 = lean_expr_update_sort(x_1, x_358); -lean_ctor_set(x_356, 0, x_359); -return x_356; +lean_object* x_398; lean_object* x_399; +x_398 = lean_ctor_get(x_396, 0); +x_399 = lean_expr_update_sort(x_1, x_398); +lean_ctor_set(x_396, 0, x_399); +return x_396; } else { -lean_object* x_360; lean_object* x_361; lean_object* x_362; lean_object* x_363; -x_360 = lean_ctor_get(x_356, 0); -x_361 = lean_ctor_get(x_356, 1); -lean_inc(x_361); -lean_inc(x_360); -lean_dec(x_356); -x_362 = lean_expr_update_sort(x_1, x_360); -x_363 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_363, 0, x_362); -lean_ctor_set(x_363, 1, x_361); -return x_363; +lean_object* x_400; lean_object* x_401; lean_object* x_402; lean_object* x_403; +x_400 = lean_ctor_get(x_396, 0); +x_401 = lean_ctor_get(x_396, 1); +lean_inc(x_401); +lean_inc(x_400); +lean_dec(x_396); +x_402 = lean_expr_update_sort(x_1, x_400); +x_403 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_403, 0, x_402); +lean_ctor_set(x_403, 1, x_401); +return x_403; } } case 4: { -lean_object* x_364; lean_object* x_365; uint8_t x_366; -x_364 = lean_ctor_get(x_1, 1); -lean_inc(x_364); -x_365 = l_List_mapM___main___at_Lean_Closure_collectExprAux___main___spec__1(x_364, x_2, x_3); -x_366 = !lean_is_exclusive(x_365); -if (x_366 == 0) +lean_object* x_404; lean_object* x_405; uint8_t x_406; +x_404 = lean_ctor_get(x_1, 1); +lean_inc(x_404); +x_405 = l_List_mapM___main___at_Lean_Closure_collectExprAux___main___spec__1(x_404, x_2, x_3); +lean_dec(x_2); +x_406 = !lean_is_exclusive(x_405); +if (x_406 == 0) { -lean_object* x_367; lean_object* x_368; -x_367 = lean_ctor_get(x_365, 0); -x_368 = lean_expr_update_const(x_1, x_367); -lean_ctor_set(x_365, 0, x_368); -return x_365; +lean_object* x_407; lean_object* x_408; +x_407 = lean_ctor_get(x_405, 0); +x_408 = lean_expr_update_const(x_1, x_407); +lean_ctor_set(x_405, 0, x_408); +return x_405; } else { -lean_object* x_369; lean_object* x_370; lean_object* x_371; lean_object* x_372; -x_369 = lean_ctor_get(x_365, 0); -x_370 = lean_ctor_get(x_365, 1); -lean_inc(x_370); -lean_inc(x_369); -lean_dec(x_365); -x_371 = lean_expr_update_const(x_1, x_369); -x_372 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_372, 0, x_371); -lean_ctor_set(x_372, 1, x_370); -return x_372; +lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_object* x_412; +x_409 = lean_ctor_get(x_405, 0); +x_410 = lean_ctor_get(x_405, 1); +lean_inc(x_410); +lean_inc(x_409); +lean_dec(x_405); +x_411 = lean_expr_update_const(x_1, x_409); +x_412 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_412, 0, x_411); +lean_ctor_set(x_412, 1, x_410); +return x_412; } } case 5: { -lean_object* x_373; lean_object* x_374; lean_object* x_375; lean_object* x_376; lean_object* x_419; uint8_t x_445; -x_373 = lean_ctor_get(x_1, 0); -lean_inc(x_373); -x_374 = lean_ctor_get(x_1, 1); -lean_inc(x_374); -x_445 = l_Lean_Expr_hasLevelParam(x_373); -if (x_445 == 0) +lean_object* x_413; lean_object* x_414; lean_object* x_415; lean_object* x_416; lean_object* x_460; uint8_t x_487; +x_413 = lean_ctor_get(x_1, 0); +lean_inc(x_413); +x_414 = lean_ctor_get(x_1, 1); +lean_inc(x_414); +x_487 = l_Lean_Expr_hasLevelParam(x_413); +if (x_487 == 0) { -uint8_t x_446; -x_446 = l_Lean_Expr_hasFVar(x_373); -if (x_446 == 0) +uint8_t x_488; +x_488 = l_Lean_Expr_hasFVar(x_413); +if (x_488 == 0) { -uint8_t x_447; -x_447 = l_Lean_Expr_hasMVar(x_373); -if (x_447 == 0) +uint8_t x_489; +x_489 = l_Lean_Expr_hasMVar(x_413); +if (x_489 == 0) { -x_375 = x_373; -x_376 = x_3; -goto block_418; +x_415 = x_413; +x_416 = x_3; +goto block_459; } else { -lean_object* x_448; -x_448 = lean_box(0); -x_419 = x_448; -goto block_444; +lean_object* x_490; +x_490 = lean_box(0); +x_460 = x_490; +goto block_486; } } else { -lean_object* x_449; -x_449 = lean_box(0); -x_419 = x_449; -goto block_444; +lean_object* x_491; +x_491 = lean_box(0); +x_460 = x_491; +goto block_486; } } else { -lean_object* x_450; -x_450 = lean_box(0); -x_419 = x_450; -goto block_444; +lean_object* x_492; +x_492 = lean_box(0); +x_460 = x_492; +goto block_486; } -block_418: +block_459: { -lean_object* x_377; lean_object* x_378; lean_object* x_386; uint8_t x_412; -x_412 = l_Lean_Expr_hasLevelParam(x_374); -if (x_412 == 0) +lean_object* x_417; lean_object* x_418; lean_object* x_426; uint8_t x_453; +x_453 = l_Lean_Expr_hasLevelParam(x_414); +if (x_453 == 0) { -uint8_t x_413; -x_413 = l_Lean_Expr_hasFVar(x_374); -if (x_413 == 0) +uint8_t x_454; +x_454 = l_Lean_Expr_hasFVar(x_414); +if (x_454 == 0) { -uint8_t x_414; -x_414 = l_Lean_Expr_hasMVar(x_374); -if (x_414 == 0) +uint8_t x_455; +x_455 = l_Lean_Expr_hasMVar(x_414); +if (x_455 == 0) { lean_dec(x_2); -x_377 = x_374; -x_378 = x_376; -goto block_385; +x_417 = x_414; +x_418 = x_416; +goto block_425; } else { -lean_object* x_415; -x_415 = lean_box(0); -x_386 = x_415; -goto block_411; +lean_object* x_456; +x_456 = lean_box(0); +x_426 = x_456; +goto block_452; } } else { -lean_object* x_416; -x_416 = lean_box(0); -x_386 = x_416; -goto block_411; +lean_object* x_457; +x_457 = lean_box(0); +x_426 = x_457; +goto block_452; } } else { -lean_object* x_417; -x_417 = lean_box(0); -x_386 = x_417; -goto block_411; +lean_object* x_458; +x_458 = lean_box(0); +x_426 = x_458; +goto block_452; } -block_385: +block_425: { if (lean_obj_tag(x_1) == 5) { -lean_object* x_379; lean_object* x_380; -x_379 = lean_expr_update_app(x_1, x_375, x_377); -x_380 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_380, 0, x_379); -lean_ctor_set(x_380, 1, x_378); -return x_380; +lean_object* x_419; lean_object* x_420; +x_419 = lean_expr_update_app(x_1, x_415, x_417); +x_420 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_420, 0, x_419); +lean_ctor_set(x_420, 1, x_418); +return x_420; } else { -lean_object* x_381; lean_object* x_382; lean_object* x_383; lean_object* x_384; -lean_dec(x_377); -lean_dec(x_375); +lean_object* x_421; lean_object* x_422; lean_object* x_423; lean_object* x_424; +lean_dec(x_417); +lean_dec(x_415); lean_dec(x_1); -x_381 = l_Lean_Expr_Inhabited; -x_382 = l_Lean_Expr_updateApp_x21___closed__1; -x_383 = lean_panic_fn(x_381, x_382); -x_384 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_384, 0, x_383); -lean_ctor_set(x_384, 1, x_378); -return x_384; +x_421 = l_Lean_Expr_Inhabited; +x_422 = l_Lean_Expr_updateApp_x21___closed__1; +x_423 = lean_panic_fn(x_421, x_422); +x_424 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_424, 0, x_423); +lean_ctor_set(x_424, 1, x_418); +return x_424; } } -block_411: +block_452: { -lean_object* x_387; lean_object* x_388; -lean_dec(x_386); -x_387 = lean_ctor_get(x_376, 3); -lean_inc(x_387); -x_388 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitExpr___spec__1(x_387, x_374); -lean_dec(x_387); -if (lean_obj_tag(x_388) == 0) +lean_object* x_427; lean_object* x_428; +lean_dec(x_426); +x_427 = lean_ctor_get(x_416, 4); +lean_inc(x_427); +x_428 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitExpr___spec__1(x_427, x_414); +lean_dec(x_427); +if (lean_obj_tag(x_428) == 0) { -lean_object* x_389; -lean_inc(x_374); -x_389 = l_Lean_Closure_collectExprAux___main(x_374, x_2, x_376); -if (lean_obj_tag(x_389) == 0) +lean_object* x_429; +lean_inc(x_414); +x_429 = l_Lean_Closure_collectExprAux___main(x_414, x_2, x_416); +if (lean_obj_tag(x_429) == 0) { -lean_object* x_390; lean_object* x_391; uint8_t x_392; -x_390 = lean_ctor_get(x_389, 1); -lean_inc(x_390); -x_391 = lean_ctor_get(x_389, 0); -lean_inc(x_391); -lean_dec(x_389); -x_392 = !lean_is_exclusive(x_390); -if (x_392 == 0) -{ -lean_object* x_393; lean_object* x_394; -x_393 = lean_ctor_get(x_390, 3); -lean_inc(x_391); -x_394 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_393, x_374, x_391); -lean_ctor_set(x_390, 3, x_394); -x_377 = x_391; -x_378 = x_390; -goto block_385; -} -else -{ -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; -x_395 = lean_ctor_get(x_390, 0); -x_396 = lean_ctor_get(x_390, 1); -x_397 = lean_ctor_get(x_390, 2); -x_398 = lean_ctor_get(x_390, 3); -x_399 = lean_ctor_get(x_390, 4); -x_400 = lean_ctor_get(x_390, 5); -x_401 = lean_ctor_get(x_390, 6); -x_402 = lean_ctor_get(x_390, 7); -x_403 = lean_ctor_get(x_390, 8); -lean_inc(x_403); -lean_inc(x_402); -lean_inc(x_401); -lean_inc(x_400); -lean_inc(x_399); -lean_inc(x_398); -lean_inc(x_397); -lean_inc(x_396); -lean_inc(x_395); -lean_dec(x_390); -lean_inc(x_391); -x_404 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_398, x_374, x_391); -x_405 = lean_alloc_ctor(0, 9, 0); -lean_ctor_set(x_405, 0, x_395); -lean_ctor_set(x_405, 1, x_396); -lean_ctor_set(x_405, 2, x_397); -lean_ctor_set(x_405, 3, x_404); -lean_ctor_set(x_405, 4, x_399); -lean_ctor_set(x_405, 5, x_400); -lean_ctor_set(x_405, 6, x_401); -lean_ctor_set(x_405, 7, x_402); -lean_ctor_set(x_405, 8, x_403); -x_377 = x_391; -x_378 = x_405; -goto block_385; -} -} -else -{ -uint8_t x_406; -lean_dec(x_375); -lean_dec(x_374); -lean_dec(x_1); -x_406 = !lean_is_exclusive(x_389); -if (x_406 == 0) -{ -return x_389; -} -else -{ -lean_object* x_407; lean_object* x_408; lean_object* x_409; -x_407 = lean_ctor_get(x_389, 0); -x_408 = lean_ctor_get(x_389, 1); -lean_inc(x_408); -lean_inc(x_407); -lean_dec(x_389); -x_409 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_409, 0, x_407); -lean_ctor_set(x_409, 1, x_408); -return x_409; -} -} -} -else -{ -lean_object* x_410; -lean_dec(x_374); -lean_dec(x_2); -x_410 = lean_ctor_get(x_388, 0); -lean_inc(x_410); -lean_dec(x_388); -x_377 = x_410; -x_378 = x_376; -goto block_385; -} -} -} -block_444: -{ -lean_object* x_420; lean_object* x_421; -lean_dec(x_419); -x_420 = lean_ctor_get(x_3, 3); -lean_inc(x_420); -x_421 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitExpr___spec__1(x_420, x_373); -lean_dec(x_420); -if (lean_obj_tag(x_421) == 0) -{ -lean_object* x_422; -lean_inc(x_2); -lean_inc(x_373); -x_422 = l_Lean_Closure_collectExprAux___main(x_373, x_2, x_3); -if (lean_obj_tag(x_422) == 0) -{ -lean_object* x_423; lean_object* x_424; uint8_t x_425; -x_423 = lean_ctor_get(x_422, 1); -lean_inc(x_423); -x_424 = lean_ctor_get(x_422, 0); -lean_inc(x_424); -lean_dec(x_422); -x_425 = !lean_is_exclusive(x_423); -if (x_425 == 0) -{ -lean_object* x_426; lean_object* x_427; -x_426 = lean_ctor_get(x_423, 3); -lean_inc(x_424); -x_427 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_426, x_373, x_424); -lean_ctor_set(x_423, 3, x_427); -x_375 = x_424; -x_376 = x_423; -goto block_418; -} -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; -x_428 = lean_ctor_get(x_423, 0); -x_429 = lean_ctor_get(x_423, 1); -x_430 = lean_ctor_get(x_423, 2); -x_431 = lean_ctor_get(x_423, 3); -x_432 = lean_ctor_get(x_423, 4); -x_433 = lean_ctor_get(x_423, 5); -x_434 = lean_ctor_get(x_423, 6); -x_435 = lean_ctor_get(x_423, 7); -x_436 = lean_ctor_get(x_423, 8); -lean_inc(x_436); -lean_inc(x_435); -lean_inc(x_434); -lean_inc(x_433); -lean_inc(x_432); -lean_inc(x_431); +lean_object* x_430; lean_object* x_431; uint8_t x_432; +x_430 = lean_ctor_get(x_429, 1); lean_inc(x_430); -lean_inc(x_429); -lean_inc(x_428); -lean_dec(x_423); -lean_inc(x_424); -x_437 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_431, x_373, x_424); -x_438 = lean_alloc_ctor(0, 9, 0); -lean_ctor_set(x_438, 0, x_428); -lean_ctor_set(x_438, 1, x_429); -lean_ctor_set(x_438, 2, x_430); -lean_ctor_set(x_438, 3, x_437); -lean_ctor_set(x_438, 4, x_432); -lean_ctor_set(x_438, 5, x_433); -lean_ctor_set(x_438, 6, x_434); -lean_ctor_set(x_438, 7, x_435); -lean_ctor_set(x_438, 8, x_436); -x_375 = x_424; -x_376 = x_438; -goto block_418; -} +x_431 = lean_ctor_get(x_429, 0); +lean_inc(x_431); +lean_dec(x_429); +x_432 = !lean_is_exclusive(x_430); +if (x_432 == 0) +{ +lean_object* x_433; lean_object* x_434; +x_433 = lean_ctor_get(x_430, 4); +lean_inc(x_431); +x_434 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_433, x_414, x_431); +lean_ctor_set(x_430, 4, x_434); +x_417 = x_431; +x_418 = x_430; +goto block_425; } else { -uint8_t x_439; -lean_dec(x_374); -lean_dec(x_373); -lean_dec(x_2); -lean_dec(x_1); -x_439 = !lean_is_exclusive(x_422); -if (x_439 == 0) -{ -return x_422; -} -else -{ -lean_object* x_440; lean_object* x_441; lean_object* x_442; -x_440 = lean_ctor_get(x_422, 0); -x_441 = lean_ctor_get(x_422, 1); +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; lean_object* x_445; lean_object* x_446; +x_435 = lean_ctor_get(x_430, 0); +x_436 = lean_ctor_get(x_430, 1); +x_437 = lean_ctor_get(x_430, 2); +x_438 = lean_ctor_get(x_430, 3); +x_439 = lean_ctor_get(x_430, 4); +x_440 = lean_ctor_get(x_430, 5); +x_441 = lean_ctor_get(x_430, 6); +x_442 = lean_ctor_get(x_430, 7); +x_443 = lean_ctor_get(x_430, 8); +x_444 = lean_ctor_get(x_430, 9); +lean_inc(x_444); +lean_inc(x_443); +lean_inc(x_442); lean_inc(x_441); lean_inc(x_440); -lean_dec(x_422); -x_442 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_442, 0, x_440); -lean_ctor_set(x_442, 1, x_441); -return x_442; +lean_inc(x_439); +lean_inc(x_438); +lean_inc(x_437); +lean_inc(x_436); +lean_inc(x_435); +lean_dec(x_430); +lean_inc(x_431); +x_445 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_439, x_414, x_431); +x_446 = lean_alloc_ctor(0, 10, 0); +lean_ctor_set(x_446, 0, x_435); +lean_ctor_set(x_446, 1, x_436); +lean_ctor_set(x_446, 2, x_437); +lean_ctor_set(x_446, 3, x_438); +lean_ctor_set(x_446, 4, x_445); +lean_ctor_set(x_446, 5, x_440); +lean_ctor_set(x_446, 6, x_441); +lean_ctor_set(x_446, 7, x_442); +lean_ctor_set(x_446, 8, x_443); +lean_ctor_set(x_446, 9, x_444); +x_417 = x_431; +x_418 = x_446; +goto block_425; +} +} +else +{ +uint8_t x_447; +lean_dec(x_415); +lean_dec(x_414); +lean_dec(x_1); +x_447 = !lean_is_exclusive(x_429); +if (x_447 == 0) +{ +return x_429; +} +else +{ +lean_object* x_448; lean_object* x_449; lean_object* x_450; +x_448 = lean_ctor_get(x_429, 0); +x_449 = lean_ctor_get(x_429, 1); +lean_inc(x_449); +lean_inc(x_448); +lean_dec(x_429); +x_450 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_450, 0, x_448); +lean_ctor_set(x_450, 1, x_449); +return x_450; } } } else { -lean_object* x_443; -lean_dec(x_373); -x_443 = lean_ctor_get(x_421, 0); -lean_inc(x_443); -lean_dec(x_421); -x_375 = x_443; -x_376 = x_3; -goto block_418; +lean_object* x_451; +lean_dec(x_414); +lean_dec(x_2); +x_451 = lean_ctor_get(x_428, 0); +lean_inc(x_451); +lean_dec(x_428); +x_417 = x_451; +x_418 = x_416; +goto block_425; +} +} +} +block_486: +{ +lean_object* x_461; lean_object* x_462; +lean_dec(x_460); +x_461 = lean_ctor_get(x_3, 4); +lean_inc(x_461); +x_462 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitExpr___spec__1(x_461, x_413); +lean_dec(x_461); +if (lean_obj_tag(x_462) == 0) +{ +lean_object* x_463; +lean_inc(x_2); +lean_inc(x_413); +x_463 = l_Lean_Closure_collectExprAux___main(x_413, x_2, x_3); +if (lean_obj_tag(x_463) == 0) +{ +lean_object* x_464; lean_object* x_465; uint8_t x_466; +x_464 = lean_ctor_get(x_463, 1); +lean_inc(x_464); +x_465 = lean_ctor_get(x_463, 0); +lean_inc(x_465); +lean_dec(x_463); +x_466 = !lean_is_exclusive(x_464); +if (x_466 == 0) +{ +lean_object* x_467; lean_object* x_468; +x_467 = lean_ctor_get(x_464, 4); +lean_inc(x_465); +x_468 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_467, x_413, x_465); +lean_ctor_set(x_464, 4, x_468); +x_415 = x_465; +x_416 = x_464; +goto block_459; +} +else +{ +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_469 = lean_ctor_get(x_464, 0); +x_470 = lean_ctor_get(x_464, 1); +x_471 = lean_ctor_get(x_464, 2); +x_472 = lean_ctor_get(x_464, 3); +x_473 = lean_ctor_get(x_464, 4); +x_474 = lean_ctor_get(x_464, 5); +x_475 = lean_ctor_get(x_464, 6); +x_476 = lean_ctor_get(x_464, 7); +x_477 = lean_ctor_get(x_464, 8); +x_478 = lean_ctor_get(x_464, 9); +lean_inc(x_478); +lean_inc(x_477); +lean_inc(x_476); +lean_inc(x_475); +lean_inc(x_474); +lean_inc(x_473); +lean_inc(x_472); +lean_inc(x_471); +lean_inc(x_470); +lean_inc(x_469); +lean_dec(x_464); +lean_inc(x_465); +x_479 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_473, x_413, x_465); +x_480 = lean_alloc_ctor(0, 10, 0); +lean_ctor_set(x_480, 0, x_469); +lean_ctor_set(x_480, 1, x_470); +lean_ctor_set(x_480, 2, x_471); +lean_ctor_set(x_480, 3, x_472); +lean_ctor_set(x_480, 4, x_479); +lean_ctor_set(x_480, 5, x_474); +lean_ctor_set(x_480, 6, x_475); +lean_ctor_set(x_480, 7, x_476); +lean_ctor_set(x_480, 8, x_477); +lean_ctor_set(x_480, 9, x_478); +x_415 = x_465; +x_416 = x_480; +goto block_459; +} +} +else +{ +uint8_t x_481; +lean_dec(x_414); +lean_dec(x_413); +lean_dec(x_2); +lean_dec(x_1); +x_481 = !lean_is_exclusive(x_463); +if (x_481 == 0) +{ +return x_463; +} +else +{ +lean_object* x_482; lean_object* x_483; lean_object* x_484; +x_482 = lean_ctor_get(x_463, 0); +x_483 = lean_ctor_get(x_463, 1); +lean_inc(x_483); +lean_inc(x_482); +lean_dec(x_463); +x_484 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_484, 0, x_482); +lean_ctor_set(x_484, 1, x_483); +return x_484; +} +} +} +else +{ +lean_object* x_485; +lean_dec(x_413); +x_485 = lean_ctor_get(x_462, 0); +lean_inc(x_485); +lean_dec(x_462); +x_415 = x_485; +x_416 = x_3; +goto block_459; } } } case 6: { -lean_object* x_451; lean_object* x_452; lean_object* x_453; lean_object* x_454; lean_object* x_499; uint8_t x_525; -x_451 = lean_ctor_get(x_1, 1); -lean_inc(x_451); -x_452 = lean_ctor_get(x_1, 2); -lean_inc(x_452); -x_525 = l_Lean_Expr_hasLevelParam(x_451); -if (x_525 == 0) +lean_object* x_493; lean_object* x_494; lean_object* x_495; lean_object* x_496; lean_object* x_542; uint8_t x_569; +x_493 = lean_ctor_get(x_1, 1); +lean_inc(x_493); +x_494 = lean_ctor_get(x_1, 2); +lean_inc(x_494); +x_569 = l_Lean_Expr_hasLevelParam(x_493); +if (x_569 == 0) { -uint8_t x_526; -x_526 = l_Lean_Expr_hasFVar(x_451); -if (x_526 == 0) +uint8_t x_570; +x_570 = l_Lean_Expr_hasFVar(x_493); +if (x_570 == 0) { -uint8_t x_527; -x_527 = l_Lean_Expr_hasMVar(x_451); -if (x_527 == 0) +uint8_t x_571; +x_571 = l_Lean_Expr_hasMVar(x_493); +if (x_571 == 0) { -x_453 = x_451; -x_454 = x_3; -goto block_498; +x_495 = x_493; +x_496 = x_3; +goto block_541; } else { -lean_object* x_528; -x_528 = lean_box(0); -x_499 = x_528; -goto block_524; +lean_object* x_572; +x_572 = lean_box(0); +x_542 = x_572; +goto block_568; } } else { -lean_object* x_529; -x_529 = lean_box(0); -x_499 = x_529; -goto block_524; +lean_object* x_573; +x_573 = lean_box(0); +x_542 = x_573; +goto block_568; } } else { -lean_object* x_530; -x_530 = lean_box(0); -x_499 = x_530; -goto block_524; +lean_object* x_574; +x_574 = lean_box(0); +x_542 = x_574; +goto block_568; } -block_498: +block_541: { -lean_object* x_455; lean_object* x_456; lean_object* x_466; uint8_t x_492; -x_492 = l_Lean_Expr_hasLevelParam(x_452); -if (x_492 == 0) +lean_object* x_497; lean_object* x_498; lean_object* x_508; uint8_t x_535; +x_535 = l_Lean_Expr_hasLevelParam(x_494); +if (x_535 == 0) { -uint8_t x_493; -x_493 = l_Lean_Expr_hasFVar(x_452); -if (x_493 == 0) +uint8_t x_536; +x_536 = l_Lean_Expr_hasFVar(x_494); +if (x_536 == 0) { -uint8_t x_494; -x_494 = l_Lean_Expr_hasMVar(x_452); -if (x_494 == 0) +uint8_t x_537; +x_537 = l_Lean_Expr_hasMVar(x_494); +if (x_537 == 0) { lean_dec(x_2); -x_455 = x_452; -x_456 = x_454; -goto block_465; +x_497 = x_494; +x_498 = x_496; +goto block_507; } else { -lean_object* x_495; -x_495 = lean_box(0); -x_466 = x_495; -goto block_491; +lean_object* x_538; +x_538 = lean_box(0); +x_508 = x_538; +goto block_534; } } else { -lean_object* x_496; -x_496 = lean_box(0); -x_466 = x_496; -goto block_491; +lean_object* x_539; +x_539 = lean_box(0); +x_508 = x_539; +goto block_534; } } else { -lean_object* x_497; -x_497 = lean_box(0); -x_466 = x_497; -goto block_491; +lean_object* x_540; +x_540 = lean_box(0); +x_508 = x_540; +goto block_534; } -block_465: +block_507: { if (lean_obj_tag(x_1) == 6) { -uint64_t x_457; uint8_t x_458; lean_object* x_459; lean_object* x_460; -x_457 = lean_ctor_get_uint64(x_1, sizeof(void*)*3); -x_458 = (uint8_t)((x_457 << 24) >> 61); -x_459 = lean_expr_update_lambda(x_1, x_458, x_453, x_455); -x_460 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_460, 0, x_459); -lean_ctor_set(x_460, 1, x_456); -return x_460; -} -else -{ -lean_object* x_461; lean_object* x_462; lean_object* x_463; lean_object* x_464; -lean_dec(x_455); -lean_dec(x_453); -lean_dec(x_1); -x_461 = l_Lean_Expr_Inhabited; -x_462 = l_Lean_Expr_updateLambdaE_x21___closed__1; -x_463 = lean_panic_fn(x_461, x_462); -x_464 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_464, 0, x_463); -lean_ctor_set(x_464, 1, x_456); -return x_464; -} -} -block_491: -{ -lean_object* x_467; lean_object* x_468; -lean_dec(x_466); -x_467 = lean_ctor_get(x_454, 3); -lean_inc(x_467); -x_468 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitExpr___spec__1(x_467, x_452); -lean_dec(x_467); -if (lean_obj_tag(x_468) == 0) -{ -lean_object* x_469; -lean_inc(x_452); -x_469 = l_Lean_Closure_collectExprAux___main(x_452, x_2, x_454); -if (lean_obj_tag(x_469) == 0) -{ -lean_object* x_470; lean_object* x_471; uint8_t x_472; -x_470 = lean_ctor_get(x_469, 1); -lean_inc(x_470); -x_471 = lean_ctor_get(x_469, 0); -lean_inc(x_471); -lean_dec(x_469); -x_472 = !lean_is_exclusive(x_470); -if (x_472 == 0) -{ -lean_object* x_473; lean_object* x_474; -x_473 = lean_ctor_get(x_470, 3); -lean_inc(x_471); -x_474 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_473, x_452, x_471); -lean_ctor_set(x_470, 3, x_474); -x_455 = x_471; -x_456 = x_470; -goto block_465; -} -else -{ -lean_object* x_475; lean_object* x_476; lean_object* x_477; lean_object* x_478; lean_object* x_479; lean_object* x_480; lean_object* x_481; lean_object* x_482; lean_object* x_483; lean_object* x_484; lean_object* x_485; -x_475 = lean_ctor_get(x_470, 0); -x_476 = lean_ctor_get(x_470, 1); -x_477 = lean_ctor_get(x_470, 2); -x_478 = lean_ctor_get(x_470, 3); -x_479 = lean_ctor_get(x_470, 4); -x_480 = lean_ctor_get(x_470, 5); -x_481 = lean_ctor_get(x_470, 6); -x_482 = lean_ctor_get(x_470, 7); -x_483 = lean_ctor_get(x_470, 8); -lean_inc(x_483); -lean_inc(x_482); -lean_inc(x_481); -lean_inc(x_480); -lean_inc(x_479); -lean_inc(x_478); -lean_inc(x_477); -lean_inc(x_476); -lean_inc(x_475); -lean_dec(x_470); -lean_inc(x_471); -x_484 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_478, x_452, x_471); -x_485 = lean_alloc_ctor(0, 9, 0); -lean_ctor_set(x_485, 0, x_475); -lean_ctor_set(x_485, 1, x_476); -lean_ctor_set(x_485, 2, x_477); -lean_ctor_set(x_485, 3, x_484); -lean_ctor_set(x_485, 4, x_479); -lean_ctor_set(x_485, 5, x_480); -lean_ctor_set(x_485, 6, x_481); -lean_ctor_set(x_485, 7, x_482); -lean_ctor_set(x_485, 8, x_483); -x_455 = x_471; -x_456 = x_485; -goto block_465; -} -} -else -{ -uint8_t x_486; -lean_dec(x_453); -lean_dec(x_452); -lean_dec(x_1); -x_486 = !lean_is_exclusive(x_469); -if (x_486 == 0) -{ -return x_469; -} -else -{ -lean_object* x_487; lean_object* x_488; lean_object* x_489; -x_487 = lean_ctor_get(x_469, 0); -x_488 = lean_ctor_get(x_469, 1); -lean_inc(x_488); -lean_inc(x_487); -lean_dec(x_469); -x_489 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_489, 0, x_487); -lean_ctor_set(x_489, 1, x_488); -return x_489; -} -} -} -else -{ -lean_object* x_490; -lean_dec(x_452); -lean_dec(x_2); -x_490 = lean_ctor_get(x_468, 0); -lean_inc(x_490); -lean_dec(x_468); -x_455 = x_490; -x_456 = x_454; -goto block_465; -} -} -} -block_524: -{ -lean_object* x_500; lean_object* x_501; -lean_dec(x_499); -x_500 = lean_ctor_get(x_3, 3); -lean_inc(x_500); -x_501 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitExpr___spec__1(x_500, x_451); -lean_dec(x_500); -if (lean_obj_tag(x_501) == 0) -{ -lean_object* x_502; -lean_inc(x_2); -lean_inc(x_451); -x_502 = l_Lean_Closure_collectExprAux___main(x_451, x_2, x_3); -if (lean_obj_tag(x_502) == 0) -{ -lean_object* x_503; lean_object* x_504; uint8_t x_505; -x_503 = lean_ctor_get(x_502, 1); -lean_inc(x_503); -x_504 = lean_ctor_get(x_502, 0); -lean_inc(x_504); -lean_dec(x_502); -x_505 = !lean_is_exclusive(x_503); -if (x_505 == 0) -{ -lean_object* x_506; lean_object* x_507; -x_506 = lean_ctor_get(x_503, 3); -lean_inc(x_504); -x_507 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_506, x_451, x_504); -lean_ctor_set(x_503, 3, x_507); -x_453 = x_504; -x_454 = x_503; -goto block_498; -} -else -{ -lean_object* x_508; lean_object* x_509; lean_object* x_510; lean_object* x_511; lean_object* x_512; lean_object* x_513; lean_object* x_514; lean_object* x_515; lean_object* x_516; lean_object* x_517; lean_object* x_518; -x_508 = lean_ctor_get(x_503, 0); -x_509 = lean_ctor_get(x_503, 1); -x_510 = lean_ctor_get(x_503, 2); -x_511 = lean_ctor_get(x_503, 3); -x_512 = lean_ctor_get(x_503, 4); -x_513 = lean_ctor_get(x_503, 5); -x_514 = lean_ctor_get(x_503, 6); -x_515 = lean_ctor_get(x_503, 7); -x_516 = lean_ctor_get(x_503, 8); -lean_inc(x_516); -lean_inc(x_515); -lean_inc(x_514); -lean_inc(x_513); -lean_inc(x_512); -lean_inc(x_511); -lean_inc(x_510); -lean_inc(x_509); -lean_inc(x_508); -lean_dec(x_503); -lean_inc(x_504); -x_517 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_511, x_451, x_504); -x_518 = lean_alloc_ctor(0, 9, 0); -lean_ctor_set(x_518, 0, x_508); -lean_ctor_set(x_518, 1, x_509); -lean_ctor_set(x_518, 2, x_510); -lean_ctor_set(x_518, 3, x_517); -lean_ctor_set(x_518, 4, x_512); -lean_ctor_set(x_518, 5, x_513); -lean_ctor_set(x_518, 6, x_514); -lean_ctor_set(x_518, 7, x_515); -lean_ctor_set(x_518, 8, x_516); -x_453 = x_504; -x_454 = x_518; -goto block_498; -} -} -else -{ -uint8_t x_519; -lean_dec(x_452); -lean_dec(x_451); -lean_dec(x_2); -lean_dec(x_1); -x_519 = !lean_is_exclusive(x_502); -if (x_519 == 0) -{ +uint64_t x_499; uint8_t x_500; lean_object* x_501; lean_object* x_502; +x_499 = lean_ctor_get_uint64(x_1, sizeof(void*)*3); +x_500 = (uint8_t)((x_499 << 24) >> 61); +x_501 = lean_expr_update_lambda(x_1, x_500, x_495, x_497); +x_502 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_502, 0, x_501); +lean_ctor_set(x_502, 1, x_498); return x_502; } else { -lean_object* x_520; lean_object* x_521; lean_object* x_522; -x_520 = lean_ctor_get(x_502, 0); -x_521 = lean_ctor_get(x_502, 1); +lean_object* x_503; lean_object* x_504; lean_object* x_505; lean_object* x_506; +lean_dec(x_497); +lean_dec(x_495); +lean_dec(x_1); +x_503 = l_Lean_Expr_Inhabited; +x_504 = l_Lean_Expr_updateLambdaE_x21___closed__1; +x_505 = lean_panic_fn(x_503, x_504); +x_506 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_506, 0, x_505); +lean_ctor_set(x_506, 1, x_498); +return x_506; +} +} +block_534: +{ +lean_object* x_509; lean_object* x_510; +lean_dec(x_508); +x_509 = lean_ctor_get(x_496, 4); +lean_inc(x_509); +x_510 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitExpr___spec__1(x_509, x_494); +lean_dec(x_509); +if (lean_obj_tag(x_510) == 0) +{ +lean_object* x_511; +lean_inc(x_494); +x_511 = l_Lean_Closure_collectExprAux___main(x_494, x_2, x_496); +if (lean_obj_tag(x_511) == 0) +{ +lean_object* x_512; lean_object* x_513; uint8_t x_514; +x_512 = lean_ctor_get(x_511, 1); +lean_inc(x_512); +x_513 = lean_ctor_get(x_511, 0); +lean_inc(x_513); +lean_dec(x_511); +x_514 = !lean_is_exclusive(x_512); +if (x_514 == 0) +{ +lean_object* x_515; lean_object* x_516; +x_515 = lean_ctor_get(x_512, 4); +lean_inc(x_513); +x_516 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_515, x_494, x_513); +lean_ctor_set(x_512, 4, x_516); +x_497 = x_513; +x_498 = x_512; +goto block_507; +} +else +{ +lean_object* x_517; lean_object* x_518; lean_object* x_519; lean_object* x_520; lean_object* x_521; lean_object* x_522; lean_object* x_523; lean_object* x_524; lean_object* x_525; lean_object* x_526; lean_object* x_527; lean_object* x_528; +x_517 = lean_ctor_get(x_512, 0); +x_518 = lean_ctor_get(x_512, 1); +x_519 = lean_ctor_get(x_512, 2); +x_520 = lean_ctor_get(x_512, 3); +x_521 = lean_ctor_get(x_512, 4); +x_522 = lean_ctor_get(x_512, 5); +x_523 = lean_ctor_get(x_512, 6); +x_524 = lean_ctor_get(x_512, 7); +x_525 = lean_ctor_get(x_512, 8); +x_526 = lean_ctor_get(x_512, 9); +lean_inc(x_526); +lean_inc(x_525); +lean_inc(x_524); +lean_inc(x_523); +lean_inc(x_522); lean_inc(x_521); lean_inc(x_520); -lean_dec(x_502); -x_522 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_522, 0, x_520); -lean_ctor_set(x_522, 1, x_521); -return x_522; -} -} -} -else -{ -lean_object* x_523; -lean_dec(x_451); -x_523 = lean_ctor_get(x_501, 0); -lean_inc(x_523); -lean_dec(x_501); -x_453 = x_523; -x_454 = x_3; -goto block_498; -} -} -} -case 7: -{ -lean_object* x_531; lean_object* x_532; lean_object* x_533; lean_object* x_534; lean_object* x_579; uint8_t x_605; -x_531 = lean_ctor_get(x_1, 1); -lean_inc(x_531); -x_532 = lean_ctor_get(x_1, 2); -lean_inc(x_532); -x_605 = l_Lean_Expr_hasLevelParam(x_531); -if (x_605 == 0) -{ -uint8_t x_606; -x_606 = l_Lean_Expr_hasFVar(x_531); -if (x_606 == 0) -{ -uint8_t x_607; -x_607 = l_Lean_Expr_hasMVar(x_531); -if (x_607 == 0) -{ -x_533 = x_531; -x_534 = x_3; -goto block_578; -} -else -{ -lean_object* x_608; -x_608 = lean_box(0); -x_579 = x_608; -goto block_604; +lean_inc(x_519); +lean_inc(x_518); +lean_inc(x_517); +lean_dec(x_512); +lean_inc(x_513); +x_527 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_521, x_494, x_513); +x_528 = lean_alloc_ctor(0, 10, 0); +lean_ctor_set(x_528, 0, x_517); +lean_ctor_set(x_528, 1, x_518); +lean_ctor_set(x_528, 2, x_519); +lean_ctor_set(x_528, 3, x_520); +lean_ctor_set(x_528, 4, x_527); +lean_ctor_set(x_528, 5, x_522); +lean_ctor_set(x_528, 6, x_523); +lean_ctor_set(x_528, 7, x_524); +lean_ctor_set(x_528, 8, x_525); +lean_ctor_set(x_528, 9, x_526); +x_497 = x_513; +x_498 = x_528; +goto block_507; } } else { -lean_object* x_609; -x_609 = lean_box(0); -x_579 = x_609; -goto block_604; -} -} -else -{ -lean_object* x_610; -x_610 = lean_box(0); -x_579 = x_610; -goto block_604; -} -block_578: -{ -lean_object* x_535; lean_object* x_536; lean_object* x_546; uint8_t x_572; -x_572 = l_Lean_Expr_hasLevelParam(x_532); -if (x_572 == 0) -{ -uint8_t x_573; -x_573 = l_Lean_Expr_hasFVar(x_532); -if (x_573 == 0) -{ -uint8_t x_574; -x_574 = l_Lean_Expr_hasMVar(x_532); -if (x_574 == 0) -{ -lean_dec(x_2); -x_535 = x_532; -x_536 = x_534; -goto block_545; -} -else -{ -lean_object* x_575; -x_575 = lean_box(0); -x_546 = x_575; -goto block_571; -} -} -else -{ -lean_object* x_576; -x_576 = lean_box(0); -x_546 = x_576; -goto block_571; -} -} -else -{ -lean_object* x_577; -x_577 = lean_box(0); -x_546 = x_577; -goto block_571; -} -block_545: -{ -if (lean_obj_tag(x_1) == 7) -{ -uint64_t x_537; uint8_t x_538; lean_object* x_539; lean_object* x_540; -x_537 = lean_ctor_get_uint64(x_1, sizeof(void*)*3); -x_538 = (uint8_t)((x_537 << 24) >> 61); -x_539 = lean_expr_update_forall(x_1, x_538, x_533, x_535); -x_540 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_540, 0, x_539); -lean_ctor_set(x_540, 1, x_536); -return x_540; -} -else -{ -lean_object* x_541; lean_object* x_542; lean_object* x_543; lean_object* x_544; -lean_dec(x_535); -lean_dec(x_533); +uint8_t x_529; +lean_dec(x_495); +lean_dec(x_494); lean_dec(x_1); -x_541 = l_Lean_Expr_Inhabited; -x_542 = l_Lean_Expr_updateForallE_x21___closed__1; -x_543 = lean_panic_fn(x_541, x_542); -x_544 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_544, 0, x_543); -lean_ctor_set(x_544, 1, x_536); -return x_544; -} -} -block_571: +x_529 = !lean_is_exclusive(x_511); +if (x_529 == 0) { -lean_object* x_547; lean_object* x_548; -lean_dec(x_546); -x_547 = lean_ctor_get(x_534, 3); -lean_inc(x_547); -x_548 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitExpr___spec__1(x_547, x_532); -lean_dec(x_547); -if (lean_obj_tag(x_548) == 0) -{ -lean_object* x_549; -lean_inc(x_532); -x_549 = l_Lean_Closure_collectExprAux___main(x_532, x_2, x_534); -if (lean_obj_tag(x_549) == 0) -{ -lean_object* x_550; lean_object* x_551; uint8_t x_552; -x_550 = lean_ctor_get(x_549, 1); -lean_inc(x_550); -x_551 = lean_ctor_get(x_549, 0); -lean_inc(x_551); -lean_dec(x_549); -x_552 = !lean_is_exclusive(x_550); -if (x_552 == 0) -{ -lean_object* x_553; lean_object* x_554; -x_553 = lean_ctor_get(x_550, 3); -lean_inc(x_551); -x_554 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_553, x_532, x_551); -lean_ctor_set(x_550, 3, x_554); -x_535 = x_551; -x_536 = x_550; -goto block_545; +return x_511; } else { -lean_object* x_555; lean_object* x_556; lean_object* x_557; lean_object* x_558; lean_object* x_559; lean_object* x_560; lean_object* x_561; lean_object* x_562; lean_object* x_563; lean_object* x_564; lean_object* x_565; -x_555 = lean_ctor_get(x_550, 0); -x_556 = lean_ctor_get(x_550, 1); -x_557 = lean_ctor_get(x_550, 2); -x_558 = lean_ctor_get(x_550, 3); -x_559 = lean_ctor_get(x_550, 4); -x_560 = lean_ctor_get(x_550, 5); -x_561 = lean_ctor_get(x_550, 6); -x_562 = lean_ctor_get(x_550, 7); -x_563 = lean_ctor_get(x_550, 8); -lean_inc(x_563); -lean_inc(x_562); -lean_inc(x_561); +lean_object* x_530; lean_object* x_531; lean_object* x_532; +x_530 = lean_ctor_get(x_511, 0); +x_531 = lean_ctor_get(x_511, 1); +lean_inc(x_531); +lean_inc(x_530); +lean_dec(x_511); +x_532 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_532, 0, x_530); +lean_ctor_set(x_532, 1, x_531); +return x_532; +} +} +} +else +{ +lean_object* x_533; +lean_dec(x_494); +lean_dec(x_2); +x_533 = lean_ctor_get(x_510, 0); +lean_inc(x_533); +lean_dec(x_510); +x_497 = x_533; +x_498 = x_496; +goto block_507; +} +} +} +block_568: +{ +lean_object* x_543; lean_object* x_544; +lean_dec(x_542); +x_543 = lean_ctor_get(x_3, 4); +lean_inc(x_543); +x_544 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitExpr___spec__1(x_543, x_493); +lean_dec(x_543); +if (lean_obj_tag(x_544) == 0) +{ +lean_object* x_545; +lean_inc(x_2); +lean_inc(x_493); +x_545 = l_Lean_Closure_collectExprAux___main(x_493, x_2, x_3); +if (lean_obj_tag(x_545) == 0) +{ +lean_object* x_546; lean_object* x_547; uint8_t x_548; +x_546 = lean_ctor_get(x_545, 1); +lean_inc(x_546); +x_547 = lean_ctor_get(x_545, 0); +lean_inc(x_547); +lean_dec(x_545); +x_548 = !lean_is_exclusive(x_546); +if (x_548 == 0) +{ +lean_object* x_549; lean_object* x_550; +x_549 = lean_ctor_get(x_546, 4); +lean_inc(x_547); +x_550 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_549, x_493, x_547); +lean_ctor_set(x_546, 4, x_550); +x_495 = x_547; +x_496 = x_546; +goto block_541; +} +else +{ +lean_object* x_551; lean_object* x_552; lean_object* x_553; lean_object* x_554; lean_object* x_555; lean_object* x_556; lean_object* x_557; lean_object* x_558; lean_object* x_559; lean_object* x_560; lean_object* x_561; lean_object* x_562; +x_551 = lean_ctor_get(x_546, 0); +x_552 = lean_ctor_get(x_546, 1); +x_553 = lean_ctor_get(x_546, 2); +x_554 = lean_ctor_get(x_546, 3); +x_555 = lean_ctor_get(x_546, 4); +x_556 = lean_ctor_get(x_546, 5); +x_557 = lean_ctor_get(x_546, 6); +x_558 = lean_ctor_get(x_546, 7); +x_559 = lean_ctor_get(x_546, 8); +x_560 = lean_ctor_get(x_546, 9); lean_inc(x_560); lean_inc(x_559); lean_inc(x_558); lean_inc(x_557); lean_inc(x_556); lean_inc(x_555); -lean_dec(x_550); +lean_inc(x_554); +lean_inc(x_553); +lean_inc(x_552); lean_inc(x_551); -x_564 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_558, x_532, x_551); -x_565 = lean_alloc_ctor(0, 9, 0); -lean_ctor_set(x_565, 0, x_555); -lean_ctor_set(x_565, 1, x_556); -lean_ctor_set(x_565, 2, x_557); -lean_ctor_set(x_565, 3, x_564); -lean_ctor_set(x_565, 4, x_559); -lean_ctor_set(x_565, 5, x_560); -lean_ctor_set(x_565, 6, x_561); -lean_ctor_set(x_565, 7, x_562); -lean_ctor_set(x_565, 8, x_563); -x_535 = x_551; -x_536 = x_565; -goto block_545; +lean_dec(x_546); +lean_inc(x_547); +x_561 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_555, x_493, x_547); +x_562 = lean_alloc_ctor(0, 10, 0); +lean_ctor_set(x_562, 0, x_551); +lean_ctor_set(x_562, 1, x_552); +lean_ctor_set(x_562, 2, x_553); +lean_ctor_set(x_562, 3, x_554); +lean_ctor_set(x_562, 4, x_561); +lean_ctor_set(x_562, 5, x_556); +lean_ctor_set(x_562, 6, x_557); +lean_ctor_set(x_562, 7, x_558); +lean_ctor_set(x_562, 8, x_559); +lean_ctor_set(x_562, 9, x_560); +x_495 = x_547; +x_496 = x_562; +goto block_541; } } else { -uint8_t x_566; -lean_dec(x_533); -lean_dec(x_532); +uint8_t x_563; +lean_dec(x_494); +lean_dec(x_493); +lean_dec(x_2); lean_dec(x_1); -x_566 = !lean_is_exclusive(x_549); -if (x_566 == 0) +x_563 = !lean_is_exclusive(x_545); +if (x_563 == 0) { -return x_549; +return x_545; } else { -lean_object* x_567; lean_object* x_568; lean_object* x_569; -x_567 = lean_ctor_get(x_549, 0); -x_568 = lean_ctor_get(x_549, 1); -lean_inc(x_568); +lean_object* x_564; lean_object* x_565; lean_object* x_566; +x_564 = lean_ctor_get(x_545, 0); +x_565 = lean_ctor_get(x_545, 1); +lean_inc(x_565); +lean_inc(x_564); +lean_dec(x_545); +x_566 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_566, 0, x_564); +lean_ctor_set(x_566, 1, x_565); +return x_566; +} +} +} +else +{ +lean_object* x_567; +lean_dec(x_493); +x_567 = lean_ctor_get(x_544, 0); lean_inc(x_567); -lean_dec(x_549); -x_569 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_569, 0, x_567); -lean_ctor_set(x_569, 1, x_568); -return x_569; +lean_dec(x_544); +x_495 = x_567; +x_496 = x_3; +goto block_541; } } } -else +case 7: { -lean_object* x_570; -lean_dec(x_532); -lean_dec(x_2); -x_570 = lean_ctor_get(x_548, 0); -lean_inc(x_570); -lean_dec(x_548); -x_535 = x_570; -x_536 = x_534; -goto block_545; -} -} -} -block_604: +lean_object* x_575; lean_object* x_576; lean_object* x_577; lean_object* x_578; lean_object* x_624; uint8_t x_651; +x_575 = lean_ctor_get(x_1, 1); +lean_inc(x_575); +x_576 = lean_ctor_get(x_1, 2); +lean_inc(x_576); +x_651 = l_Lean_Expr_hasLevelParam(x_575); +if (x_651 == 0) { -lean_object* x_580; lean_object* x_581; -lean_dec(x_579); -x_580 = lean_ctor_get(x_3, 3); -lean_inc(x_580); -x_581 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitExpr___spec__1(x_580, x_531); -lean_dec(x_580); -if (lean_obj_tag(x_581) == 0) +uint8_t x_652; +x_652 = l_Lean_Expr_hasFVar(x_575); +if (x_652 == 0) { -lean_object* x_582; -lean_inc(x_2); -lean_inc(x_531); -x_582 = l_Lean_Closure_collectExprAux___main(x_531, x_2, x_3); -if (lean_obj_tag(x_582) == 0) -{ -lean_object* x_583; lean_object* x_584; uint8_t x_585; -x_583 = lean_ctor_get(x_582, 1); -lean_inc(x_583); -x_584 = lean_ctor_get(x_582, 0); -lean_inc(x_584); -lean_dec(x_582); -x_585 = !lean_is_exclusive(x_583); -if (x_585 == 0) -{ -lean_object* x_586; lean_object* x_587; -x_586 = lean_ctor_get(x_583, 3); -lean_inc(x_584); -x_587 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_586, x_531, x_584); -lean_ctor_set(x_583, 3, x_587); -x_533 = x_584; -x_534 = x_583; -goto block_578; -} -else -{ -lean_object* x_588; lean_object* x_589; lean_object* x_590; lean_object* x_591; lean_object* x_592; lean_object* x_593; lean_object* x_594; lean_object* x_595; lean_object* x_596; lean_object* x_597; lean_object* x_598; -x_588 = lean_ctor_get(x_583, 0); -x_589 = lean_ctor_get(x_583, 1); -x_590 = lean_ctor_get(x_583, 2); -x_591 = lean_ctor_get(x_583, 3); -x_592 = lean_ctor_get(x_583, 4); -x_593 = lean_ctor_get(x_583, 5); -x_594 = lean_ctor_get(x_583, 6); -x_595 = lean_ctor_get(x_583, 7); -x_596 = lean_ctor_get(x_583, 8); -lean_inc(x_596); -lean_inc(x_595); -lean_inc(x_594); -lean_inc(x_593); -lean_inc(x_592); -lean_inc(x_591); -lean_inc(x_590); -lean_inc(x_589); -lean_inc(x_588); -lean_dec(x_583); -lean_inc(x_584); -x_597 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_591, x_531, x_584); -x_598 = lean_alloc_ctor(0, 9, 0); -lean_ctor_set(x_598, 0, x_588); -lean_ctor_set(x_598, 1, x_589); -lean_ctor_set(x_598, 2, x_590); -lean_ctor_set(x_598, 3, x_597); -lean_ctor_set(x_598, 4, x_592); -lean_ctor_set(x_598, 5, x_593); -lean_ctor_set(x_598, 6, x_594); -lean_ctor_set(x_598, 7, x_595); -lean_ctor_set(x_598, 8, x_596); -x_533 = x_584; -x_534 = x_598; -goto block_578; -} -} -else -{ -uint8_t x_599; -lean_dec(x_532); -lean_dec(x_531); -lean_dec(x_2); -lean_dec(x_1); -x_599 = !lean_is_exclusive(x_582); -if (x_599 == 0) -{ -return x_582; -} -else -{ -lean_object* x_600; lean_object* x_601; lean_object* x_602; -x_600 = lean_ctor_get(x_582, 0); -x_601 = lean_ctor_get(x_582, 1); -lean_inc(x_601); -lean_inc(x_600); -lean_dec(x_582); -x_602 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_602, 0, x_600); -lean_ctor_set(x_602, 1, x_601); -return x_602; -} -} -} -else -{ -lean_object* x_603; -lean_dec(x_531); -x_603 = lean_ctor_get(x_581, 0); -lean_inc(x_603); -lean_dec(x_581); -x_533 = x_603; -x_534 = x_3; -goto block_578; -} -} -} -case 8: -{ -lean_object* x_611; lean_object* x_612; lean_object* x_613; lean_object* x_614; lean_object* x_615; lean_object* x_693; uint8_t x_719; -x_611 = lean_ctor_get(x_1, 1); -lean_inc(x_611); -x_612 = lean_ctor_get(x_1, 2); -lean_inc(x_612); -x_613 = lean_ctor_get(x_1, 3); -lean_inc(x_613); -x_719 = l_Lean_Expr_hasLevelParam(x_611); -if (x_719 == 0) -{ -uint8_t x_720; -x_720 = l_Lean_Expr_hasFVar(x_611); -if (x_720 == 0) -{ -uint8_t x_721; -x_721 = l_Lean_Expr_hasMVar(x_611); -if (x_721 == 0) -{ -x_614 = x_611; -x_615 = x_3; -goto block_692; -} -else -{ -lean_object* x_722; -x_722 = lean_box(0); -x_693 = x_722; -goto block_718; -} -} -else -{ -lean_object* x_723; -x_723 = lean_box(0); -x_693 = x_723; -goto block_718; -} -} -else -{ -lean_object* x_724; -x_724 = lean_box(0); -x_693 = x_724; -goto block_718; -} -block_692: -{ -lean_object* x_616; lean_object* x_617; lean_object* x_660; uint8_t x_686; -x_686 = l_Lean_Expr_hasLevelParam(x_612); -if (x_686 == 0) -{ -uint8_t x_687; -x_687 = l_Lean_Expr_hasFVar(x_612); -if (x_687 == 0) -{ -uint8_t x_688; -x_688 = l_Lean_Expr_hasMVar(x_612); -if (x_688 == 0) -{ -x_616 = x_612; -x_617 = x_615; -goto block_659; -} -else -{ -lean_object* x_689; -x_689 = lean_box(0); -x_660 = x_689; -goto block_685; -} -} -else -{ -lean_object* x_690; -x_690 = lean_box(0); -x_660 = x_690; -goto block_685; -} -} -else -{ -lean_object* x_691; -x_691 = lean_box(0); -x_660 = x_691; -goto block_685; -} -block_659: -{ -lean_object* x_618; lean_object* x_619; lean_object* x_627; uint8_t x_653; -x_653 = l_Lean_Expr_hasLevelParam(x_613); +uint8_t x_653; +x_653 = l_Lean_Expr_hasMVar(x_575); if (x_653 == 0) { -uint8_t x_654; -x_654 = l_Lean_Expr_hasFVar(x_613); -if (x_654 == 0) +x_577 = x_575; +x_578 = x_3; +goto block_623; +} +else { -uint8_t x_655; -x_655 = l_Lean_Expr_hasMVar(x_613); -if (x_655 == 0) +lean_object* x_654; +x_654 = lean_box(0); +x_624 = x_654; +goto block_650; +} +} +else { -lean_dec(x_2); -x_618 = x_613; -x_619 = x_617; -goto block_626; +lean_object* x_655; +x_655 = lean_box(0); +x_624 = x_655; +goto block_650; +} } else { lean_object* x_656; x_656 = lean_box(0); -x_627 = x_656; -goto block_652; +x_624 = x_656; +goto block_650; +} +block_623: +{ +lean_object* x_579; lean_object* x_580; lean_object* x_590; uint8_t x_617; +x_617 = l_Lean_Expr_hasLevelParam(x_576); +if (x_617 == 0) +{ +uint8_t x_618; +x_618 = l_Lean_Expr_hasFVar(x_576); +if (x_618 == 0) +{ +uint8_t x_619; +x_619 = l_Lean_Expr_hasMVar(x_576); +if (x_619 == 0) +{ +lean_dec(x_2); +x_579 = x_576; +x_580 = x_578; +goto block_589; +} +else +{ +lean_object* x_620; +x_620 = lean_box(0); +x_590 = x_620; +goto block_616; } } else { -lean_object* x_657; -x_657 = lean_box(0); -x_627 = x_657; -goto block_652; +lean_object* x_621; +x_621 = lean_box(0); +x_590 = x_621; +goto block_616; } } else { -lean_object* x_658; -x_658 = lean_box(0); -x_627 = x_658; -goto block_652; +lean_object* x_622; +x_622 = lean_box(0); +x_590 = x_622; +goto block_616; } -block_626: +block_589: { -if (lean_obj_tag(x_1) == 8) +if (lean_obj_tag(x_1) == 7) { -lean_object* x_620; lean_object* x_621; -x_620 = lean_expr_update_let(x_1, x_614, x_616, x_618); -x_621 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_621, 0, x_620); -lean_ctor_set(x_621, 1, x_619); -return x_621; +uint64_t x_581; uint8_t x_582; lean_object* x_583; lean_object* x_584; +x_581 = lean_ctor_get_uint64(x_1, sizeof(void*)*3); +x_582 = (uint8_t)((x_581 << 24) >> 61); +x_583 = lean_expr_update_forall(x_1, x_582, x_577, x_579); +x_584 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_584, 0, x_583); +lean_ctor_set(x_584, 1, x_580); +return x_584; } else { -lean_object* x_622; lean_object* x_623; lean_object* x_624; lean_object* x_625; -lean_dec(x_618); -lean_dec(x_616); -lean_dec(x_614); +lean_object* x_585; lean_object* x_586; lean_object* x_587; lean_object* x_588; +lean_dec(x_579); +lean_dec(x_577); lean_dec(x_1); -x_622 = l_Lean_Expr_Inhabited; -x_623 = l_Lean_Expr_updateLet_x21___closed__1; -x_624 = lean_panic_fn(x_622, x_623); -x_625 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_625, 0, x_624); -lean_ctor_set(x_625, 1, x_619); -return x_625; +x_585 = l_Lean_Expr_Inhabited; +x_586 = l_Lean_Expr_updateForallE_x21___closed__1; +x_587 = lean_panic_fn(x_585, x_586); +x_588 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_588, 0, x_587); +lean_ctor_set(x_588, 1, x_580); +return x_588; } } -block_652: +block_616: { -lean_object* x_628; lean_object* x_629; -lean_dec(x_627); -x_628 = lean_ctor_get(x_617, 3); -lean_inc(x_628); -x_629 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitExpr___spec__1(x_628, x_613); -lean_dec(x_628); -if (lean_obj_tag(x_629) == 0) +lean_object* x_591; lean_object* x_592; +lean_dec(x_590); +x_591 = lean_ctor_get(x_578, 4); +lean_inc(x_591); +x_592 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitExpr___spec__1(x_591, x_576); +lean_dec(x_591); +if (lean_obj_tag(x_592) == 0) { -lean_object* x_630; -lean_inc(x_613); -x_630 = l_Lean_Closure_collectExprAux___main(x_613, x_2, x_617); -if (lean_obj_tag(x_630) == 0) +lean_object* x_593; +lean_inc(x_576); +x_593 = l_Lean_Closure_collectExprAux___main(x_576, x_2, x_578); +if (lean_obj_tag(x_593) == 0) { -lean_object* x_631; lean_object* x_632; uint8_t x_633; -x_631 = lean_ctor_get(x_630, 1); -lean_inc(x_631); -x_632 = lean_ctor_get(x_630, 0); -lean_inc(x_632); -lean_dec(x_630); -x_633 = !lean_is_exclusive(x_631); -if (x_633 == 0) +lean_object* x_594; lean_object* x_595; uint8_t x_596; +x_594 = lean_ctor_get(x_593, 1); +lean_inc(x_594); +x_595 = lean_ctor_get(x_593, 0); +lean_inc(x_595); +lean_dec(x_593); +x_596 = !lean_is_exclusive(x_594); +if (x_596 == 0) { -lean_object* x_634; lean_object* x_635; -x_634 = lean_ctor_get(x_631, 3); -lean_inc(x_632); -x_635 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_634, x_613, x_632); -lean_ctor_set(x_631, 3, x_635); -x_618 = x_632; -x_619 = x_631; -goto block_626; +lean_object* x_597; lean_object* x_598; +x_597 = lean_ctor_get(x_594, 4); +lean_inc(x_595); +x_598 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_597, x_576, x_595); +lean_ctor_set(x_594, 4, x_598); +x_579 = x_595; +x_580 = x_594; +goto block_589; } else { -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; lean_object* x_645; lean_object* x_646; -x_636 = lean_ctor_get(x_631, 0); -x_637 = lean_ctor_get(x_631, 1); -x_638 = lean_ctor_get(x_631, 2); -x_639 = lean_ctor_get(x_631, 3); -x_640 = lean_ctor_get(x_631, 4); -x_641 = lean_ctor_get(x_631, 5); -x_642 = lean_ctor_get(x_631, 6); -x_643 = lean_ctor_get(x_631, 7); -x_644 = lean_ctor_get(x_631, 8); -lean_inc(x_644); -lean_inc(x_643); +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_599 = lean_ctor_get(x_594, 0); +x_600 = lean_ctor_get(x_594, 1); +x_601 = lean_ctor_get(x_594, 2); +x_602 = lean_ctor_get(x_594, 3); +x_603 = lean_ctor_get(x_594, 4); +x_604 = lean_ctor_get(x_594, 5); +x_605 = lean_ctor_get(x_594, 6); +x_606 = lean_ctor_get(x_594, 7); +x_607 = lean_ctor_get(x_594, 8); +x_608 = lean_ctor_get(x_594, 9); +lean_inc(x_608); +lean_inc(x_607); +lean_inc(x_606); +lean_inc(x_605); +lean_inc(x_604); +lean_inc(x_603); +lean_inc(x_602); +lean_inc(x_601); +lean_inc(x_600); +lean_inc(x_599); +lean_dec(x_594); +lean_inc(x_595); +x_609 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_603, x_576, x_595); +x_610 = lean_alloc_ctor(0, 10, 0); +lean_ctor_set(x_610, 0, x_599); +lean_ctor_set(x_610, 1, x_600); +lean_ctor_set(x_610, 2, x_601); +lean_ctor_set(x_610, 3, x_602); +lean_ctor_set(x_610, 4, x_609); +lean_ctor_set(x_610, 5, x_604); +lean_ctor_set(x_610, 6, x_605); +lean_ctor_set(x_610, 7, x_606); +lean_ctor_set(x_610, 8, x_607); +lean_ctor_set(x_610, 9, x_608); +x_579 = x_595; +x_580 = x_610; +goto block_589; +} +} +else +{ +uint8_t x_611; +lean_dec(x_577); +lean_dec(x_576); +lean_dec(x_1); +x_611 = !lean_is_exclusive(x_593); +if (x_611 == 0) +{ +return x_593; +} +else +{ +lean_object* x_612; lean_object* x_613; lean_object* x_614; +x_612 = lean_ctor_get(x_593, 0); +x_613 = lean_ctor_get(x_593, 1); +lean_inc(x_613); +lean_inc(x_612); +lean_dec(x_593); +x_614 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_614, 0, x_612); +lean_ctor_set(x_614, 1, x_613); +return x_614; +} +} +} +else +{ +lean_object* x_615; +lean_dec(x_576); +lean_dec(x_2); +x_615 = lean_ctor_get(x_592, 0); +lean_inc(x_615); +lean_dec(x_592); +x_579 = x_615; +x_580 = x_578; +goto block_589; +} +} +} +block_650: +{ +lean_object* x_625; lean_object* x_626; +lean_dec(x_624); +x_625 = lean_ctor_get(x_3, 4); +lean_inc(x_625); +x_626 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitExpr___spec__1(x_625, x_575); +lean_dec(x_625); +if (lean_obj_tag(x_626) == 0) +{ +lean_object* x_627; +lean_inc(x_2); +lean_inc(x_575); +x_627 = l_Lean_Closure_collectExprAux___main(x_575, x_2, x_3); +if (lean_obj_tag(x_627) == 0) +{ +lean_object* x_628; lean_object* x_629; uint8_t x_630; +x_628 = lean_ctor_get(x_627, 1); +lean_inc(x_628); +x_629 = lean_ctor_get(x_627, 0); +lean_inc(x_629); +lean_dec(x_627); +x_630 = !lean_is_exclusive(x_628); +if (x_630 == 0) +{ +lean_object* x_631; lean_object* x_632; +x_631 = lean_ctor_get(x_628, 4); +lean_inc(x_629); +x_632 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_631, x_575, x_629); +lean_ctor_set(x_628, 4, x_632); +x_577 = x_629; +x_578 = x_628; +goto block_623; +} +else +{ +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; +x_633 = lean_ctor_get(x_628, 0); +x_634 = lean_ctor_get(x_628, 1); +x_635 = lean_ctor_get(x_628, 2); +x_636 = lean_ctor_get(x_628, 3); +x_637 = lean_ctor_get(x_628, 4); +x_638 = lean_ctor_get(x_628, 5); +x_639 = lean_ctor_get(x_628, 6); +x_640 = lean_ctor_get(x_628, 7); +x_641 = lean_ctor_get(x_628, 8); +x_642 = lean_ctor_get(x_628, 9); lean_inc(x_642); lean_inc(x_641); lean_inc(x_640); @@ -5846,443 +5706,728 @@ lean_inc(x_639); lean_inc(x_638); lean_inc(x_637); lean_inc(x_636); -lean_dec(x_631); -lean_inc(x_632); -x_645 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_639, x_613, x_632); -x_646 = lean_alloc_ctor(0, 9, 0); -lean_ctor_set(x_646, 0, x_636); -lean_ctor_set(x_646, 1, x_637); -lean_ctor_set(x_646, 2, x_638); -lean_ctor_set(x_646, 3, x_645); -lean_ctor_set(x_646, 4, x_640); -lean_ctor_set(x_646, 5, x_641); -lean_ctor_set(x_646, 6, x_642); -lean_ctor_set(x_646, 7, x_643); -lean_ctor_set(x_646, 8, x_644); -x_618 = x_632; -x_619 = x_646; -goto block_626; +lean_inc(x_635); +lean_inc(x_634); +lean_inc(x_633); +lean_dec(x_628); +lean_inc(x_629); +x_643 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_637, x_575, x_629); +x_644 = lean_alloc_ctor(0, 10, 0); +lean_ctor_set(x_644, 0, x_633); +lean_ctor_set(x_644, 1, x_634); +lean_ctor_set(x_644, 2, x_635); +lean_ctor_set(x_644, 3, x_636); +lean_ctor_set(x_644, 4, x_643); +lean_ctor_set(x_644, 5, x_638); +lean_ctor_set(x_644, 6, x_639); +lean_ctor_set(x_644, 7, x_640); +lean_ctor_set(x_644, 8, x_641); +lean_ctor_set(x_644, 9, x_642); +x_577 = x_629; +x_578 = x_644; +goto block_623; } } else { -uint8_t x_647; -lean_dec(x_616); -lean_dec(x_614); -lean_dec(x_613); +uint8_t x_645; +lean_dec(x_576); +lean_dec(x_575); +lean_dec(x_2); lean_dec(x_1); -x_647 = !lean_is_exclusive(x_630); -if (x_647 == 0) +x_645 = !lean_is_exclusive(x_627); +if (x_645 == 0) { -return x_630; +return x_627; } else { -lean_object* x_648; lean_object* x_649; lean_object* x_650; -x_648 = lean_ctor_get(x_630, 0); -x_649 = lean_ctor_get(x_630, 1); +lean_object* x_646; lean_object* x_647; lean_object* x_648; +x_646 = lean_ctor_get(x_627, 0); +x_647 = lean_ctor_get(x_627, 1); +lean_inc(x_647); +lean_inc(x_646); +lean_dec(x_627); +x_648 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_648, 0, x_646); +lean_ctor_set(x_648, 1, x_647); +return x_648; +} +} +} +else +{ +lean_object* x_649; +lean_dec(x_575); +x_649 = lean_ctor_get(x_626, 0); lean_inc(x_649); -lean_inc(x_648); -lean_dec(x_630); -x_650 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_650, 0, x_648); -lean_ctor_set(x_650, 1, x_649); -return x_650; +lean_dec(x_626); +x_577 = x_649; +x_578 = x_3; +goto block_623; } } } +case 8: +{ +lean_object* x_657; lean_object* x_658; lean_object* x_659; lean_object* x_660; lean_object* x_661; lean_object* x_741; uint8_t x_768; +x_657 = lean_ctor_get(x_1, 1); +lean_inc(x_657); +x_658 = lean_ctor_get(x_1, 2); +lean_inc(x_658); +x_659 = lean_ctor_get(x_1, 3); +lean_inc(x_659); +x_768 = l_Lean_Expr_hasLevelParam(x_657); +if (x_768 == 0) +{ +uint8_t x_769; +x_769 = l_Lean_Expr_hasFVar(x_657); +if (x_769 == 0) +{ +uint8_t x_770; +x_770 = l_Lean_Expr_hasMVar(x_657); +if (x_770 == 0) +{ +x_660 = x_657; +x_661 = x_3; +goto block_740; +} +else +{ +lean_object* x_771; +x_771 = lean_box(0); +x_741 = x_771; +goto block_767; +} +} else { -lean_object* x_651; -lean_dec(x_613); +lean_object* x_772; +x_772 = lean_box(0); +x_741 = x_772; +goto block_767; +} +} +else +{ +lean_object* x_773; +x_773 = lean_box(0); +x_741 = x_773; +goto block_767; +} +block_740: +{ +lean_object* x_662; lean_object* x_663; lean_object* x_707; uint8_t x_734; +x_734 = l_Lean_Expr_hasLevelParam(x_658); +if (x_734 == 0) +{ +uint8_t x_735; +x_735 = l_Lean_Expr_hasFVar(x_658); +if (x_735 == 0) +{ +uint8_t x_736; +x_736 = l_Lean_Expr_hasMVar(x_658); +if (x_736 == 0) +{ +x_662 = x_658; +x_663 = x_661; +goto block_706; +} +else +{ +lean_object* x_737; +x_737 = lean_box(0); +x_707 = x_737; +goto block_733; +} +} +else +{ +lean_object* x_738; +x_738 = lean_box(0); +x_707 = x_738; +goto block_733; +} +} +else +{ +lean_object* x_739; +x_739 = lean_box(0); +x_707 = x_739; +goto block_733; +} +block_706: +{ +lean_object* x_664; lean_object* x_665; lean_object* x_673; uint8_t x_700; +x_700 = l_Lean_Expr_hasLevelParam(x_659); +if (x_700 == 0) +{ +uint8_t x_701; +x_701 = l_Lean_Expr_hasFVar(x_659); +if (x_701 == 0) +{ +uint8_t x_702; +x_702 = l_Lean_Expr_hasMVar(x_659); +if (x_702 == 0) +{ lean_dec(x_2); -x_651 = lean_ctor_get(x_629, 0); -lean_inc(x_651); -lean_dec(x_629); -x_618 = x_651; -x_619 = x_617; -goto block_626; -} -} -} -block_685: -{ -lean_object* x_661; lean_object* x_662; -lean_dec(x_660); -x_661 = lean_ctor_get(x_615, 3); -lean_inc(x_661); -x_662 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitExpr___spec__1(x_661, x_612); -lean_dec(x_661); -if (lean_obj_tag(x_662) == 0) -{ -lean_object* x_663; -lean_inc(x_2); -lean_inc(x_612); -x_663 = l_Lean_Closure_collectExprAux___main(x_612, x_2, x_615); -if (lean_obj_tag(x_663) == 0) -{ -lean_object* x_664; lean_object* x_665; uint8_t x_666; -x_664 = lean_ctor_get(x_663, 1); -lean_inc(x_664); -x_665 = lean_ctor_get(x_663, 0); -lean_inc(x_665); -lean_dec(x_663); -x_666 = !lean_is_exclusive(x_664); -if (x_666 == 0) -{ -lean_object* x_667; lean_object* x_668; -x_667 = lean_ctor_get(x_664, 3); -lean_inc(x_665); -x_668 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_667, x_612, x_665); -lean_ctor_set(x_664, 3, x_668); -x_616 = x_665; -x_617 = x_664; -goto block_659; +x_664 = x_659; +x_665 = x_663; +goto block_672; } else { -lean_object* x_669; lean_object* x_670; lean_object* x_671; lean_object* x_672; lean_object* x_673; lean_object* x_674; lean_object* x_675; lean_object* x_676; lean_object* x_677; lean_object* x_678; lean_object* x_679; -x_669 = lean_ctor_get(x_664, 0); -x_670 = lean_ctor_get(x_664, 1); -x_671 = lean_ctor_get(x_664, 2); -x_672 = lean_ctor_get(x_664, 3); -x_673 = lean_ctor_get(x_664, 4); -x_674 = lean_ctor_get(x_664, 5); -x_675 = lean_ctor_get(x_664, 6); -x_676 = lean_ctor_get(x_664, 7); -x_677 = lean_ctor_get(x_664, 8); -lean_inc(x_677); -lean_inc(x_676); -lean_inc(x_675); -lean_inc(x_674); -lean_inc(x_673); -lean_inc(x_672); -lean_inc(x_671); -lean_inc(x_670); -lean_inc(x_669); +lean_object* x_703; +x_703 = lean_box(0); +x_673 = x_703; +goto block_699; +} +} +else +{ +lean_object* x_704; +x_704 = lean_box(0); +x_673 = x_704; +goto block_699; +} +} +else +{ +lean_object* x_705; +x_705 = lean_box(0); +x_673 = x_705; +goto block_699; +} +block_672: +{ +if (lean_obj_tag(x_1) == 8) +{ +lean_object* x_666; lean_object* x_667; +x_666 = lean_expr_update_let(x_1, x_660, x_662, x_664); +x_667 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_667, 0, x_666); +lean_ctor_set(x_667, 1, x_665); +return x_667; +} +else +{ +lean_object* x_668; lean_object* x_669; lean_object* x_670; lean_object* x_671; lean_dec(x_664); -lean_inc(x_665); -x_678 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_672, x_612, x_665); -x_679 = lean_alloc_ctor(0, 9, 0); -lean_ctor_set(x_679, 0, x_669); -lean_ctor_set(x_679, 1, x_670); -lean_ctor_set(x_679, 2, x_671); -lean_ctor_set(x_679, 3, x_678); -lean_ctor_set(x_679, 4, x_673); -lean_ctor_set(x_679, 5, x_674); -lean_ctor_set(x_679, 6, x_675); -lean_ctor_set(x_679, 7, x_676); -lean_ctor_set(x_679, 8, x_677); -x_616 = x_665; -x_617 = x_679; -goto block_659; -} -} -else -{ -uint8_t x_680; -lean_dec(x_614); -lean_dec(x_613); -lean_dec(x_612); -lean_dec(x_2); -lean_dec(x_1); -x_680 = !lean_is_exclusive(x_663); -if (x_680 == 0) -{ -return x_663; -} -else -{ -lean_object* x_681; lean_object* x_682; lean_object* x_683; -x_681 = lean_ctor_get(x_663, 0); -x_682 = lean_ctor_get(x_663, 1); -lean_inc(x_682); -lean_inc(x_681); -lean_dec(x_663); -x_683 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_683, 0, x_681); -lean_ctor_set(x_683, 1, x_682); -return x_683; -} -} -} -else -{ -lean_object* x_684; -lean_dec(x_612); -x_684 = lean_ctor_get(x_662, 0); -lean_inc(x_684); lean_dec(x_662); -x_616 = x_684; -x_617 = x_615; -goto block_659; -} -} -} -block_718: -{ -lean_object* x_694; lean_object* x_695; -lean_dec(x_693); -x_694 = lean_ctor_get(x_3, 3); -lean_inc(x_694); -x_695 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitExpr___spec__1(x_694, x_611); -lean_dec(x_694); -if (lean_obj_tag(x_695) == 0) -{ -lean_object* x_696; -lean_inc(x_2); -lean_inc(x_611); -x_696 = l_Lean_Closure_collectExprAux___main(x_611, x_2, x_3); -if (lean_obj_tag(x_696) == 0) -{ -lean_object* x_697; lean_object* x_698; uint8_t x_699; -x_697 = lean_ctor_get(x_696, 1); -lean_inc(x_697); -x_698 = lean_ctor_get(x_696, 0); -lean_inc(x_698); -lean_dec(x_696); -x_699 = !lean_is_exclusive(x_697); -if (x_699 == 0) -{ -lean_object* x_700; lean_object* x_701; -x_700 = lean_ctor_get(x_697, 3); -lean_inc(x_698); -x_701 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_700, x_611, x_698); -lean_ctor_set(x_697, 3, x_701); -x_614 = x_698; -x_615 = x_697; -goto block_692; -} -else -{ -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; -x_702 = lean_ctor_get(x_697, 0); -x_703 = lean_ctor_get(x_697, 1); -x_704 = lean_ctor_get(x_697, 2); -x_705 = lean_ctor_get(x_697, 3); -x_706 = lean_ctor_get(x_697, 4); -x_707 = lean_ctor_get(x_697, 5); -x_708 = lean_ctor_get(x_697, 6); -x_709 = lean_ctor_get(x_697, 7); -x_710 = lean_ctor_get(x_697, 8); -lean_inc(x_710); -lean_inc(x_709); -lean_inc(x_708); -lean_inc(x_707); -lean_inc(x_706); -lean_inc(x_705); -lean_inc(x_704); -lean_inc(x_703); -lean_inc(x_702); -lean_dec(x_697); -lean_inc(x_698); -x_711 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_705, x_611, x_698); -x_712 = lean_alloc_ctor(0, 9, 0); -lean_ctor_set(x_712, 0, x_702); -lean_ctor_set(x_712, 1, x_703); -lean_ctor_set(x_712, 2, x_704); -lean_ctor_set(x_712, 3, x_711); -lean_ctor_set(x_712, 4, x_706); -lean_ctor_set(x_712, 5, x_707); -lean_ctor_set(x_712, 6, x_708); -lean_ctor_set(x_712, 7, x_709); -lean_ctor_set(x_712, 8, x_710); -x_614 = x_698; -x_615 = x_712; -goto block_692; -} -} -else -{ -uint8_t x_713; -lean_dec(x_613); -lean_dec(x_612); -lean_dec(x_611); -lean_dec(x_2); +lean_dec(x_660); lean_dec(x_1); -x_713 = !lean_is_exclusive(x_696); +x_668 = l_Lean_Expr_Inhabited; +x_669 = l_Lean_Expr_updateLet_x21___closed__1; +x_670 = lean_panic_fn(x_668, x_669); +x_671 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_671, 0, x_670); +lean_ctor_set(x_671, 1, x_665); +return x_671; +} +} +block_699: +{ +lean_object* x_674; lean_object* x_675; +lean_dec(x_673); +x_674 = lean_ctor_get(x_663, 4); +lean_inc(x_674); +x_675 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitExpr___spec__1(x_674, x_659); +lean_dec(x_674); +if (lean_obj_tag(x_675) == 0) +{ +lean_object* x_676; +lean_inc(x_659); +x_676 = l_Lean_Closure_collectExprAux___main(x_659, x_2, x_663); +if (lean_obj_tag(x_676) == 0) +{ +lean_object* x_677; lean_object* x_678; uint8_t x_679; +x_677 = lean_ctor_get(x_676, 1); +lean_inc(x_677); +x_678 = lean_ctor_get(x_676, 0); +lean_inc(x_678); +lean_dec(x_676); +x_679 = !lean_is_exclusive(x_677); +if (x_679 == 0) +{ +lean_object* x_680; lean_object* x_681; +x_680 = lean_ctor_get(x_677, 4); +lean_inc(x_678); +x_681 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_680, x_659, x_678); +lean_ctor_set(x_677, 4, x_681); +x_664 = x_678; +x_665 = x_677; +goto block_672; +} +else +{ +lean_object* x_682; lean_object* x_683; lean_object* x_684; lean_object* x_685; lean_object* x_686; lean_object* x_687; lean_object* x_688; lean_object* x_689; lean_object* x_690; lean_object* x_691; lean_object* x_692; lean_object* x_693; +x_682 = lean_ctor_get(x_677, 0); +x_683 = lean_ctor_get(x_677, 1); +x_684 = lean_ctor_get(x_677, 2); +x_685 = lean_ctor_get(x_677, 3); +x_686 = lean_ctor_get(x_677, 4); +x_687 = lean_ctor_get(x_677, 5); +x_688 = lean_ctor_get(x_677, 6); +x_689 = lean_ctor_get(x_677, 7); +x_690 = lean_ctor_get(x_677, 8); +x_691 = lean_ctor_get(x_677, 9); +lean_inc(x_691); +lean_inc(x_690); +lean_inc(x_689); +lean_inc(x_688); +lean_inc(x_687); +lean_inc(x_686); +lean_inc(x_685); +lean_inc(x_684); +lean_inc(x_683); +lean_inc(x_682); +lean_dec(x_677); +lean_inc(x_678); +x_692 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_686, x_659, x_678); +x_693 = lean_alloc_ctor(0, 10, 0); +lean_ctor_set(x_693, 0, x_682); +lean_ctor_set(x_693, 1, x_683); +lean_ctor_set(x_693, 2, x_684); +lean_ctor_set(x_693, 3, x_685); +lean_ctor_set(x_693, 4, x_692); +lean_ctor_set(x_693, 5, x_687); +lean_ctor_set(x_693, 6, x_688); +lean_ctor_set(x_693, 7, x_689); +lean_ctor_set(x_693, 8, x_690); +lean_ctor_set(x_693, 9, x_691); +x_664 = x_678; +x_665 = x_693; +goto block_672; +} +} +else +{ +uint8_t x_694; +lean_dec(x_662); +lean_dec(x_660); +lean_dec(x_659); +lean_dec(x_1); +x_694 = !lean_is_exclusive(x_676); +if (x_694 == 0) +{ +return x_676; +} +else +{ +lean_object* x_695; lean_object* x_696; lean_object* x_697; +x_695 = lean_ctor_get(x_676, 0); +x_696 = lean_ctor_get(x_676, 1); +lean_inc(x_696); +lean_inc(x_695); +lean_dec(x_676); +x_697 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_697, 0, x_695); +lean_ctor_set(x_697, 1, x_696); +return x_697; +} +} +} +else +{ +lean_object* x_698; +lean_dec(x_659); +lean_dec(x_2); +x_698 = lean_ctor_get(x_675, 0); +lean_inc(x_698); +lean_dec(x_675); +x_664 = x_698; +x_665 = x_663; +goto block_672; +} +} +} +block_733: +{ +lean_object* x_708; lean_object* x_709; +lean_dec(x_707); +x_708 = lean_ctor_get(x_661, 4); +lean_inc(x_708); +x_709 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitExpr___spec__1(x_708, x_658); +lean_dec(x_708); +if (lean_obj_tag(x_709) == 0) +{ +lean_object* x_710; +lean_inc(x_2); +lean_inc(x_658); +x_710 = l_Lean_Closure_collectExprAux___main(x_658, x_2, x_661); +if (lean_obj_tag(x_710) == 0) +{ +lean_object* x_711; lean_object* x_712; uint8_t x_713; +x_711 = lean_ctor_get(x_710, 1); +lean_inc(x_711); +x_712 = lean_ctor_get(x_710, 0); +lean_inc(x_712); +lean_dec(x_710); +x_713 = !lean_is_exclusive(x_711); if (x_713 == 0) { -return x_696; +lean_object* x_714; lean_object* x_715; +x_714 = lean_ctor_get(x_711, 4); +lean_inc(x_712); +x_715 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_714, x_658, x_712); +lean_ctor_set(x_711, 4, x_715); +x_662 = x_712; +x_663 = x_711; +goto block_706; } else { -lean_object* x_714; lean_object* x_715; lean_object* x_716; -x_714 = lean_ctor_get(x_696, 0); -x_715 = lean_ctor_get(x_696, 1); -lean_inc(x_715); -lean_inc(x_714); -lean_dec(x_696); -x_716 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_716, 0, x_714); -lean_ctor_set(x_716, 1, x_715); -return x_716; -} -} -} -else -{ -lean_object* x_717; -lean_dec(x_611); -x_717 = lean_ctor_get(x_695, 0); +lean_object* x_716; lean_object* x_717; lean_object* x_718; lean_object* x_719; lean_object* x_720; lean_object* x_721; lean_object* x_722; lean_object* x_723; lean_object* x_724; lean_object* x_725; lean_object* x_726; lean_object* x_727; +x_716 = lean_ctor_get(x_711, 0); +x_717 = lean_ctor_get(x_711, 1); +x_718 = lean_ctor_get(x_711, 2); +x_719 = lean_ctor_get(x_711, 3); +x_720 = lean_ctor_get(x_711, 4); +x_721 = lean_ctor_get(x_711, 5); +x_722 = lean_ctor_get(x_711, 6); +x_723 = lean_ctor_get(x_711, 7); +x_724 = lean_ctor_get(x_711, 8); +x_725 = lean_ctor_get(x_711, 9); +lean_inc(x_725); +lean_inc(x_724); +lean_inc(x_723); +lean_inc(x_722); +lean_inc(x_721); +lean_inc(x_720); +lean_inc(x_719); +lean_inc(x_718); lean_inc(x_717); -lean_dec(x_695); -x_614 = x_717; -x_615 = x_3; -goto block_692; +lean_inc(x_716); +lean_dec(x_711); +lean_inc(x_712); +x_726 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_720, x_658, x_712); +x_727 = lean_alloc_ctor(0, 10, 0); +lean_ctor_set(x_727, 0, x_716); +lean_ctor_set(x_727, 1, x_717); +lean_ctor_set(x_727, 2, x_718); +lean_ctor_set(x_727, 3, x_719); +lean_ctor_set(x_727, 4, x_726); +lean_ctor_set(x_727, 5, x_721); +lean_ctor_set(x_727, 6, x_722); +lean_ctor_set(x_727, 7, x_723); +lean_ctor_set(x_727, 8, x_724); +lean_ctor_set(x_727, 9, x_725); +x_662 = x_712; +x_663 = x_727; +goto block_706; +} +} +else +{ +uint8_t x_728; +lean_dec(x_660); +lean_dec(x_659); +lean_dec(x_658); +lean_dec(x_2); +lean_dec(x_1); +x_728 = !lean_is_exclusive(x_710); +if (x_728 == 0) +{ +return x_710; +} +else +{ +lean_object* x_729; lean_object* x_730; lean_object* x_731; +x_729 = lean_ctor_get(x_710, 0); +x_730 = lean_ctor_get(x_710, 1); +lean_inc(x_730); +lean_inc(x_729); +lean_dec(x_710); +x_731 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_731, 0, x_729); +lean_ctor_set(x_731, 1, x_730); +return x_731; +} +} +} +else +{ +lean_object* x_732; +lean_dec(x_658); +x_732 = lean_ctor_get(x_709, 0); +lean_inc(x_732); +lean_dec(x_709); +x_662 = x_732; +x_663 = x_661; +goto block_706; +} +} +} +block_767: +{ +lean_object* x_742; lean_object* x_743; +lean_dec(x_741); +x_742 = lean_ctor_get(x_3, 4); +lean_inc(x_742); +x_743 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitExpr___spec__1(x_742, x_657); +lean_dec(x_742); +if (lean_obj_tag(x_743) == 0) +{ +lean_object* x_744; +lean_inc(x_2); +lean_inc(x_657); +x_744 = l_Lean_Closure_collectExprAux___main(x_657, x_2, x_3); +if (lean_obj_tag(x_744) == 0) +{ +lean_object* x_745; lean_object* x_746; uint8_t x_747; +x_745 = lean_ctor_get(x_744, 1); +lean_inc(x_745); +x_746 = lean_ctor_get(x_744, 0); +lean_inc(x_746); +lean_dec(x_744); +x_747 = !lean_is_exclusive(x_745); +if (x_747 == 0) +{ +lean_object* x_748; lean_object* x_749; +x_748 = lean_ctor_get(x_745, 4); +lean_inc(x_746); +x_749 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_748, x_657, x_746); +lean_ctor_set(x_745, 4, x_749); +x_660 = x_746; +x_661 = x_745; +goto block_740; +} +else +{ +lean_object* x_750; lean_object* x_751; lean_object* x_752; lean_object* x_753; lean_object* x_754; lean_object* x_755; lean_object* x_756; lean_object* x_757; lean_object* x_758; lean_object* x_759; lean_object* x_760; lean_object* x_761; +x_750 = lean_ctor_get(x_745, 0); +x_751 = lean_ctor_get(x_745, 1); +x_752 = lean_ctor_get(x_745, 2); +x_753 = lean_ctor_get(x_745, 3); +x_754 = lean_ctor_get(x_745, 4); +x_755 = lean_ctor_get(x_745, 5); +x_756 = lean_ctor_get(x_745, 6); +x_757 = lean_ctor_get(x_745, 7); +x_758 = lean_ctor_get(x_745, 8); +x_759 = lean_ctor_get(x_745, 9); +lean_inc(x_759); +lean_inc(x_758); +lean_inc(x_757); +lean_inc(x_756); +lean_inc(x_755); +lean_inc(x_754); +lean_inc(x_753); +lean_inc(x_752); +lean_inc(x_751); +lean_inc(x_750); +lean_dec(x_745); +lean_inc(x_746); +x_760 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_754, x_657, x_746); +x_761 = lean_alloc_ctor(0, 10, 0); +lean_ctor_set(x_761, 0, x_750); +lean_ctor_set(x_761, 1, x_751); +lean_ctor_set(x_761, 2, x_752); +lean_ctor_set(x_761, 3, x_753); +lean_ctor_set(x_761, 4, x_760); +lean_ctor_set(x_761, 5, x_755); +lean_ctor_set(x_761, 6, x_756); +lean_ctor_set(x_761, 7, x_757); +lean_ctor_set(x_761, 8, x_758); +lean_ctor_set(x_761, 9, x_759); +x_660 = x_746; +x_661 = x_761; +goto block_740; +} +} +else +{ +uint8_t x_762; +lean_dec(x_659); +lean_dec(x_658); +lean_dec(x_657); +lean_dec(x_2); +lean_dec(x_1); +x_762 = !lean_is_exclusive(x_744); +if (x_762 == 0) +{ +return x_744; +} +else +{ +lean_object* x_763; lean_object* x_764; lean_object* x_765; +x_763 = lean_ctor_get(x_744, 0); +x_764 = lean_ctor_get(x_744, 1); +lean_inc(x_764); +lean_inc(x_763); +lean_dec(x_744); +x_765 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_765, 0, x_763); +lean_ctor_set(x_765, 1, x_764); +return x_765; +} +} +} +else +{ +lean_object* x_766; +lean_dec(x_657); +x_766 = lean_ctor_get(x_743, 0); +lean_inc(x_766); +lean_dec(x_743); +x_660 = x_766; +x_661 = x_3; +goto block_740; } } } case 10: { -lean_object* x_725; lean_object* x_726; uint8_t x_752; -x_725 = lean_ctor_get(x_1, 1); -lean_inc(x_725); -x_752 = l_Lean_Expr_hasLevelParam(x_725); -if (x_752 == 0) +lean_object* x_774; lean_object* x_775; uint8_t x_802; +x_774 = lean_ctor_get(x_1, 1); +lean_inc(x_774); +x_802 = l_Lean_Expr_hasLevelParam(x_774); +if (x_802 == 0) { -uint8_t x_753; -x_753 = l_Lean_Expr_hasFVar(x_725); -if (x_753 == 0) +uint8_t x_803; +x_803 = l_Lean_Expr_hasFVar(x_774); +if (x_803 == 0) { -uint8_t x_754; -x_754 = l_Lean_Expr_hasMVar(x_725); -if (x_754 == 0) +uint8_t x_804; +x_804 = l_Lean_Expr_hasMVar(x_774); +if (x_804 == 0) { lean_dec(x_2); -x_4 = x_725; +x_4 = x_774; x_5 = x_3; goto block_12; } else { -lean_object* x_755; -x_755 = lean_box(0); -x_726 = x_755; -goto block_751; +lean_object* x_805; +x_805 = lean_box(0); +x_775 = x_805; +goto block_801; } } else { -lean_object* x_756; -x_756 = lean_box(0); -x_726 = x_756; -goto block_751; +lean_object* x_806; +x_806 = lean_box(0); +x_775 = x_806; +goto block_801; } } else { -lean_object* x_757; -x_757 = lean_box(0); -x_726 = x_757; -goto block_751; +lean_object* x_807; +x_807 = lean_box(0); +x_775 = x_807; +goto block_801; } -block_751: +block_801: { -lean_object* x_727; lean_object* x_728; -lean_dec(x_726); -x_727 = lean_ctor_get(x_3, 3); -lean_inc(x_727); -x_728 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitExpr___spec__1(x_727, x_725); -lean_dec(x_727); -if (lean_obj_tag(x_728) == 0) +lean_object* x_776; lean_object* x_777; +lean_dec(x_775); +x_776 = lean_ctor_get(x_3, 4); +lean_inc(x_776); +x_777 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitExpr___spec__1(x_776, x_774); +lean_dec(x_776); +if (lean_obj_tag(x_777) == 0) { -lean_object* x_729; -lean_inc(x_725); -x_729 = l_Lean_Closure_collectExprAux___main(x_725, x_2, x_3); -if (lean_obj_tag(x_729) == 0) +lean_object* x_778; +lean_inc(x_774); +x_778 = l_Lean_Closure_collectExprAux___main(x_774, x_2, x_3); +if (lean_obj_tag(x_778) == 0) { -lean_object* x_730; lean_object* x_731; uint8_t x_732; -x_730 = lean_ctor_get(x_729, 1); -lean_inc(x_730); -x_731 = lean_ctor_get(x_729, 0); -lean_inc(x_731); -lean_dec(x_729); -x_732 = !lean_is_exclusive(x_730); -if (x_732 == 0) +lean_object* x_779; lean_object* x_780; uint8_t x_781; +x_779 = lean_ctor_get(x_778, 1); +lean_inc(x_779); +x_780 = lean_ctor_get(x_778, 0); +lean_inc(x_780); +lean_dec(x_778); +x_781 = !lean_is_exclusive(x_779); +if (x_781 == 0) { -lean_object* x_733; lean_object* x_734; -x_733 = lean_ctor_get(x_730, 3); -lean_inc(x_731); -x_734 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_733, x_725, x_731); -lean_ctor_set(x_730, 3, x_734); -x_4 = x_731; -x_5 = x_730; +lean_object* x_782; lean_object* x_783; +x_782 = lean_ctor_get(x_779, 4); +lean_inc(x_780); +x_783 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_782, x_774, x_780); +lean_ctor_set(x_779, 4, x_783); +x_4 = x_780; +x_5 = x_779; goto block_12; } else { -lean_object* x_735; lean_object* x_736; lean_object* x_737; lean_object* x_738; lean_object* x_739; lean_object* x_740; lean_object* x_741; lean_object* x_742; lean_object* x_743; lean_object* x_744; lean_object* x_745; -x_735 = lean_ctor_get(x_730, 0); -x_736 = lean_ctor_get(x_730, 1); -x_737 = lean_ctor_get(x_730, 2); -x_738 = lean_ctor_get(x_730, 3); -x_739 = lean_ctor_get(x_730, 4); -x_740 = lean_ctor_get(x_730, 5); -x_741 = lean_ctor_get(x_730, 6); -x_742 = lean_ctor_get(x_730, 7); -x_743 = lean_ctor_get(x_730, 8); -lean_inc(x_743); -lean_inc(x_742); -lean_inc(x_741); -lean_inc(x_740); -lean_inc(x_739); -lean_inc(x_738); -lean_inc(x_737); -lean_inc(x_736); -lean_inc(x_735); -lean_dec(x_730); -lean_inc(x_731); -x_744 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_738, x_725, x_731); -x_745 = lean_alloc_ctor(0, 9, 0); -lean_ctor_set(x_745, 0, x_735); -lean_ctor_set(x_745, 1, x_736); -lean_ctor_set(x_745, 2, x_737); -lean_ctor_set(x_745, 3, x_744); -lean_ctor_set(x_745, 4, x_739); -lean_ctor_set(x_745, 5, x_740); -lean_ctor_set(x_745, 6, x_741); -lean_ctor_set(x_745, 7, x_742); -lean_ctor_set(x_745, 8, x_743); -x_4 = x_731; -x_5 = x_745; +lean_object* x_784; lean_object* x_785; lean_object* x_786; lean_object* x_787; lean_object* x_788; lean_object* x_789; lean_object* x_790; lean_object* x_791; lean_object* x_792; lean_object* x_793; lean_object* x_794; lean_object* x_795; +x_784 = lean_ctor_get(x_779, 0); +x_785 = lean_ctor_get(x_779, 1); +x_786 = lean_ctor_get(x_779, 2); +x_787 = lean_ctor_get(x_779, 3); +x_788 = lean_ctor_get(x_779, 4); +x_789 = lean_ctor_get(x_779, 5); +x_790 = lean_ctor_get(x_779, 6); +x_791 = lean_ctor_get(x_779, 7); +x_792 = lean_ctor_get(x_779, 8); +x_793 = lean_ctor_get(x_779, 9); +lean_inc(x_793); +lean_inc(x_792); +lean_inc(x_791); +lean_inc(x_790); +lean_inc(x_789); +lean_inc(x_788); +lean_inc(x_787); +lean_inc(x_786); +lean_inc(x_785); +lean_inc(x_784); +lean_dec(x_779); +lean_inc(x_780); +x_794 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_788, x_774, x_780); +x_795 = lean_alloc_ctor(0, 10, 0); +lean_ctor_set(x_795, 0, x_784); +lean_ctor_set(x_795, 1, x_785); +lean_ctor_set(x_795, 2, x_786); +lean_ctor_set(x_795, 3, x_787); +lean_ctor_set(x_795, 4, x_794); +lean_ctor_set(x_795, 5, x_789); +lean_ctor_set(x_795, 6, x_790); +lean_ctor_set(x_795, 7, x_791); +lean_ctor_set(x_795, 8, x_792); +lean_ctor_set(x_795, 9, x_793); +x_4 = x_780; +x_5 = x_795; goto block_12; } } else { -uint8_t x_746; -lean_dec(x_725); +uint8_t x_796; +lean_dec(x_774); lean_dec(x_1); -x_746 = !lean_is_exclusive(x_729); -if (x_746 == 0) +x_796 = !lean_is_exclusive(x_778); +if (x_796 == 0) { -return x_729; +return x_778; } else { -lean_object* x_747; lean_object* x_748; lean_object* x_749; -x_747 = lean_ctor_get(x_729, 0); -x_748 = lean_ctor_get(x_729, 1); -lean_inc(x_748); -lean_inc(x_747); -lean_dec(x_729); -x_749 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_749, 0, x_747); -lean_ctor_set(x_749, 1, x_748); -return x_749; +lean_object* x_797; lean_object* x_798; lean_object* x_799; +x_797 = lean_ctor_get(x_778, 0); +x_798 = lean_ctor_get(x_778, 1); +lean_inc(x_798); +lean_inc(x_797); +lean_dec(x_778); +x_799 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_799, 0, x_797); +lean_ctor_set(x_799, 1, x_798); +return x_799; } } } else { -lean_object* x_750; -lean_dec(x_725); +lean_object* x_800; +lean_dec(x_774); lean_dec(x_2); -x_750 = lean_ctor_get(x_728, 0); -lean_inc(x_750); -lean_dec(x_728); -x_4 = x_750; +x_800 = lean_ctor_get(x_777, 0); +lean_inc(x_800); +lean_dec(x_777); +x_4 = x_800; x_5 = x_3; goto block_12; } @@ -6290,154 +6435,157 @@ goto block_12; } case 11: { -lean_object* x_758; lean_object* x_759; uint8_t x_785; -x_758 = lean_ctor_get(x_1, 2); -lean_inc(x_758); -x_785 = l_Lean_Expr_hasLevelParam(x_758); -if (x_785 == 0) +lean_object* x_808; lean_object* x_809; uint8_t x_836; +x_808 = lean_ctor_get(x_1, 2); +lean_inc(x_808); +x_836 = l_Lean_Expr_hasLevelParam(x_808); +if (x_836 == 0) { -uint8_t x_786; -x_786 = l_Lean_Expr_hasFVar(x_758); -if (x_786 == 0) +uint8_t x_837; +x_837 = l_Lean_Expr_hasFVar(x_808); +if (x_837 == 0) { -uint8_t x_787; -x_787 = l_Lean_Expr_hasMVar(x_758); -if (x_787 == 0) +uint8_t x_838; +x_838 = l_Lean_Expr_hasMVar(x_808); +if (x_838 == 0) { lean_dec(x_2); -x_13 = x_758; +x_13 = x_808; x_14 = x_3; goto block_21; } else { -lean_object* x_788; -x_788 = lean_box(0); -x_759 = x_788; -goto block_784; +lean_object* x_839; +x_839 = lean_box(0); +x_809 = x_839; +goto block_835; } } else { -lean_object* x_789; -x_789 = lean_box(0); -x_759 = x_789; -goto block_784; +lean_object* x_840; +x_840 = lean_box(0); +x_809 = x_840; +goto block_835; } } else { -lean_object* x_790; -x_790 = lean_box(0); -x_759 = x_790; -goto block_784; +lean_object* x_841; +x_841 = lean_box(0); +x_809 = x_841; +goto block_835; } -block_784: +block_835: { -lean_object* x_760; lean_object* x_761; -lean_dec(x_759); -x_760 = lean_ctor_get(x_3, 3); -lean_inc(x_760); -x_761 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitExpr___spec__1(x_760, x_758); -lean_dec(x_760); -if (lean_obj_tag(x_761) == 0) +lean_object* x_810; lean_object* x_811; +lean_dec(x_809); +x_810 = lean_ctor_get(x_3, 4); +lean_inc(x_810); +x_811 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitExpr___spec__1(x_810, x_808); +lean_dec(x_810); +if (lean_obj_tag(x_811) == 0) { -lean_object* x_762; -lean_inc(x_758); -x_762 = l_Lean_Closure_collectExprAux___main(x_758, x_2, x_3); -if (lean_obj_tag(x_762) == 0) +lean_object* x_812; +lean_inc(x_808); +x_812 = l_Lean_Closure_collectExprAux___main(x_808, x_2, x_3); +if (lean_obj_tag(x_812) == 0) { -lean_object* x_763; lean_object* x_764; uint8_t x_765; -x_763 = lean_ctor_get(x_762, 1); -lean_inc(x_763); -x_764 = lean_ctor_get(x_762, 0); -lean_inc(x_764); -lean_dec(x_762); -x_765 = !lean_is_exclusive(x_763); -if (x_765 == 0) +lean_object* x_813; lean_object* x_814; uint8_t x_815; +x_813 = lean_ctor_get(x_812, 1); +lean_inc(x_813); +x_814 = lean_ctor_get(x_812, 0); +lean_inc(x_814); +lean_dec(x_812); +x_815 = !lean_is_exclusive(x_813); +if (x_815 == 0) { -lean_object* x_766; lean_object* x_767; -x_766 = lean_ctor_get(x_763, 3); -lean_inc(x_764); -x_767 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_766, x_758, x_764); -lean_ctor_set(x_763, 3, x_767); -x_13 = x_764; -x_14 = x_763; +lean_object* x_816; lean_object* x_817; +x_816 = lean_ctor_get(x_813, 4); +lean_inc(x_814); +x_817 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_816, x_808, x_814); +lean_ctor_set(x_813, 4, x_817); +x_13 = x_814; +x_14 = x_813; goto block_21; } else { -lean_object* x_768; lean_object* x_769; lean_object* x_770; lean_object* x_771; lean_object* x_772; lean_object* x_773; lean_object* x_774; lean_object* x_775; lean_object* x_776; lean_object* x_777; lean_object* x_778; -x_768 = lean_ctor_get(x_763, 0); -x_769 = lean_ctor_get(x_763, 1); -x_770 = lean_ctor_get(x_763, 2); -x_771 = lean_ctor_get(x_763, 3); -x_772 = lean_ctor_get(x_763, 4); -x_773 = lean_ctor_get(x_763, 5); -x_774 = lean_ctor_get(x_763, 6); -x_775 = lean_ctor_get(x_763, 7); -x_776 = lean_ctor_get(x_763, 8); -lean_inc(x_776); -lean_inc(x_775); -lean_inc(x_774); -lean_inc(x_773); -lean_inc(x_772); -lean_inc(x_771); -lean_inc(x_770); -lean_inc(x_769); -lean_inc(x_768); -lean_dec(x_763); -lean_inc(x_764); -x_777 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_771, x_758, x_764); -x_778 = lean_alloc_ctor(0, 9, 0); -lean_ctor_set(x_778, 0, x_768); -lean_ctor_set(x_778, 1, x_769); -lean_ctor_set(x_778, 2, x_770); -lean_ctor_set(x_778, 3, x_777); -lean_ctor_set(x_778, 4, x_772); -lean_ctor_set(x_778, 5, x_773); -lean_ctor_set(x_778, 6, x_774); -lean_ctor_set(x_778, 7, x_775); -lean_ctor_set(x_778, 8, x_776); -x_13 = x_764; -x_14 = x_778; +lean_object* x_818; lean_object* x_819; lean_object* x_820; lean_object* x_821; lean_object* x_822; lean_object* x_823; lean_object* x_824; lean_object* x_825; lean_object* x_826; lean_object* x_827; lean_object* x_828; lean_object* x_829; +x_818 = lean_ctor_get(x_813, 0); +x_819 = lean_ctor_get(x_813, 1); +x_820 = lean_ctor_get(x_813, 2); +x_821 = lean_ctor_get(x_813, 3); +x_822 = lean_ctor_get(x_813, 4); +x_823 = lean_ctor_get(x_813, 5); +x_824 = lean_ctor_get(x_813, 6); +x_825 = lean_ctor_get(x_813, 7); +x_826 = lean_ctor_get(x_813, 8); +x_827 = lean_ctor_get(x_813, 9); +lean_inc(x_827); +lean_inc(x_826); +lean_inc(x_825); +lean_inc(x_824); +lean_inc(x_823); +lean_inc(x_822); +lean_inc(x_821); +lean_inc(x_820); +lean_inc(x_819); +lean_inc(x_818); +lean_dec(x_813); +lean_inc(x_814); +x_828 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_822, x_808, x_814); +x_829 = lean_alloc_ctor(0, 10, 0); +lean_ctor_set(x_829, 0, x_818); +lean_ctor_set(x_829, 1, x_819); +lean_ctor_set(x_829, 2, x_820); +lean_ctor_set(x_829, 3, x_821); +lean_ctor_set(x_829, 4, x_828); +lean_ctor_set(x_829, 5, x_823); +lean_ctor_set(x_829, 6, x_824); +lean_ctor_set(x_829, 7, x_825); +lean_ctor_set(x_829, 8, x_826); +lean_ctor_set(x_829, 9, x_827); +x_13 = x_814; +x_14 = x_829; goto block_21; } } else { -uint8_t x_779; -lean_dec(x_758); +uint8_t x_830; +lean_dec(x_808); lean_dec(x_1); -x_779 = !lean_is_exclusive(x_762); -if (x_779 == 0) +x_830 = !lean_is_exclusive(x_812); +if (x_830 == 0) { -return x_762; +return x_812; } else { -lean_object* x_780; lean_object* x_781; lean_object* x_782; -x_780 = lean_ctor_get(x_762, 0); -x_781 = lean_ctor_get(x_762, 1); -lean_inc(x_781); -lean_inc(x_780); -lean_dec(x_762); -x_782 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_782, 0, x_780); -lean_ctor_set(x_782, 1, x_781); -return x_782; +lean_object* x_831; lean_object* x_832; lean_object* x_833; +x_831 = lean_ctor_get(x_812, 0); +x_832 = lean_ctor_get(x_812, 1); +lean_inc(x_832); +lean_inc(x_831); +lean_dec(x_812); +x_833 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_833, 0, x_831); +lean_ctor_set(x_833, 1, x_832); +return x_833; } } } else { -lean_object* x_783; -lean_dec(x_758); +lean_object* x_834; +lean_dec(x_808); lean_dec(x_2); -x_783 = lean_ctor_get(x_761, 0); -lean_inc(x_783); -lean_dec(x_761); -x_13 = x_783; +x_834 = lean_ctor_get(x_811, 0); +lean_inc(x_834); +lean_dec(x_811); +x_13 = x_834; x_14 = x_3; goto block_21; } @@ -6445,12 +6593,12 @@ goto block_21; } default: { -lean_object* x_791; +lean_object* x_842; lean_dec(x_2); -x_791 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_791, 0, x_1); -lean_ctor_set(x_791, 1, x_3); -return x_791; +x_842 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_842, 0, x_1); +lean_ctor_set(x_842, 1, x_3); +return x_842; } } block_12: @@ -6505,6 +6653,15 @@ return x_20; } } } +lean_object* l_List_mapM___main___at_Lean_Closure_collectExprAux___main___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; +x_4 = l_List_mapM___main___at_Lean_Closure_collectExprAux___main___spec__1(x_1, x_2, x_3); +lean_dec(x_2); +return x_4; +} +} lean_object* l_Lean_Closure_collectExprAux(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { @@ -6516,218 +6673,244 @@ return x_4; lean_object* l_Lean_Closure_collectExpr(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { -lean_object* x_4; uint8_t x_48; -x_48 = l_Lean_Expr_hasLevelParam(x_1); -if (x_48 == 0) -{ -uint8_t x_49; -x_49 = l_Lean_Expr_hasFVar(x_1); -if (x_49 == 0) -{ -uint8_t x_50; -x_50 = l_Lean_Expr_hasMVar(x_1); -if (x_50 == 0) -{ -lean_object* x_51; -lean_dec(x_2); -x_51 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_51, 0, x_1); -lean_ctor_set(x_51, 1, x_3); -return x_51; -} -else -{ -lean_object* x_52; -x_52 = lean_box(0); -x_4 = x_52; -goto block_47; -} -} -else -{ -lean_object* x_53; -x_53 = lean_box(0); -x_4 = x_53; -goto block_47; -} -} -else -{ -lean_object* x_54; -x_54 = lean_box(0); -x_4 = x_54; -goto block_47; -} -block_47: -{ -lean_object* x_5; lean_object* x_6; -lean_dec(x_4); -x_5 = lean_ctor_get(x_3, 3); +lean_object* x_4; lean_object* x_5; lean_object* x_6; lean_object* x_7; lean_object* x_8; uint8_t x_54; +x_4 = l_Lean_Closure_instantiateMVars(x_1, x_2, x_3); +x_5 = lean_ctor_get(x_4, 0); lean_inc(x_5); -x_6 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitExpr___spec__1(x_5, x_1); -lean_dec(x_5); -if (lean_obj_tag(x_6) == 0) +x_6 = lean_ctor_get(x_4, 1); +lean_inc(x_6); +if (lean_is_exclusive(x_4)) { + lean_ctor_release(x_4, 0); + lean_ctor_release(x_4, 1); + x_7 = x_4; +} else { + lean_dec_ref(x_4); + x_7 = lean_box(0); +} +x_54 = l_Lean_Expr_hasLevelParam(x_5); +if (x_54 == 0) { -lean_object* x_7; -lean_inc(x_1); -x_7 = l_Lean_Closure_collectExprAux___main(x_1, x_2, x_3); -if (lean_obj_tag(x_7) == 0) +uint8_t x_55; +x_55 = l_Lean_Expr_hasFVar(x_5); +if (x_55 == 0) { -uint8_t x_8; -x_8 = !lean_is_exclusive(x_7); -if (x_8 == 0) +uint8_t x_56; +x_56 = l_Lean_Expr_hasMVar(x_5); +if (x_56 == 0) { -lean_object* x_9; uint8_t x_10; -x_9 = lean_ctor_get(x_7, 1); -x_10 = !lean_is_exclusive(x_9); -if (x_10 == 0) -{ -lean_object* x_11; lean_object* x_12; lean_object* x_13; -x_11 = lean_ctor_get(x_7, 0); -x_12 = lean_ctor_get(x_9, 3); -lean_inc(x_11); -x_13 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_12, x_1, x_11); -lean_ctor_set(x_9, 3, x_13); -return x_7; +lean_object* x_57; +lean_dec(x_7); +lean_dec(x_2); +x_57 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_57, 0, x_5); +lean_ctor_set(x_57, 1, x_6); +return x_57; } else { -lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; -x_14 = lean_ctor_get(x_7, 0); -x_15 = lean_ctor_get(x_9, 0); -x_16 = lean_ctor_get(x_9, 1); -x_17 = lean_ctor_get(x_9, 2); -x_18 = lean_ctor_get(x_9, 3); -x_19 = lean_ctor_get(x_9, 4); -x_20 = lean_ctor_get(x_9, 5); -x_21 = lean_ctor_get(x_9, 6); -x_22 = lean_ctor_get(x_9, 7); -x_23 = lean_ctor_get(x_9, 8); +lean_object* x_58; +x_58 = lean_box(0); +x_8 = x_58; +goto block_53; +} +} +else +{ +lean_object* x_59; +x_59 = lean_box(0); +x_8 = x_59; +goto block_53; +} +} +else +{ +lean_object* x_60; +x_60 = lean_box(0); +x_8 = x_60; +goto block_53; +} +block_53: +{ +lean_object* x_9; lean_object* x_10; +lean_dec(x_8); +x_9 = lean_ctor_get(x_6, 4); +lean_inc(x_9); +x_10 = l_Std_HashMapImp_find_x3f___at_Lean_Closure_visitExpr___spec__1(x_9, x_5); +lean_dec(x_9); +if (lean_obj_tag(x_10) == 0) +{ +lean_object* x_11; +lean_dec(x_7); +lean_inc(x_5); +x_11 = l_Lean_Closure_collectExprAux___main(x_5, x_2, x_6); +if (lean_obj_tag(x_11) == 0) +{ +uint8_t x_12; +x_12 = !lean_is_exclusive(x_11); +if (x_12 == 0) +{ +lean_object* x_13; uint8_t x_14; +x_13 = lean_ctor_get(x_11, 1); +x_14 = !lean_is_exclusive(x_13); +if (x_14 == 0) +{ +lean_object* x_15; lean_object* x_16; lean_object* x_17; +x_15 = lean_ctor_get(x_11, 0); +x_16 = lean_ctor_get(x_13, 4); +lean_inc(x_15); +x_17 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_16, x_5, x_15); +lean_ctor_set(x_13, 4, x_17); +return x_11; +} +else +{ +lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; +x_18 = lean_ctor_get(x_11, 0); +x_19 = lean_ctor_get(x_13, 0); +x_20 = lean_ctor_get(x_13, 1); +x_21 = lean_ctor_get(x_13, 2); +x_22 = lean_ctor_get(x_13, 3); +x_23 = lean_ctor_get(x_13, 4); +x_24 = lean_ctor_get(x_13, 5); +x_25 = lean_ctor_get(x_13, 6); +x_26 = lean_ctor_get(x_13, 7); +x_27 = lean_ctor_get(x_13, 8); +x_28 = lean_ctor_get(x_13, 9); +lean_inc(x_28); +lean_inc(x_27); +lean_inc(x_26); +lean_inc(x_25); +lean_inc(x_24); lean_inc(x_23); lean_inc(x_22); lean_inc(x_21); lean_inc(x_20); lean_inc(x_19); +lean_dec(x_13); lean_inc(x_18); -lean_inc(x_17); -lean_inc(x_16); -lean_inc(x_15); -lean_dec(x_9); -lean_inc(x_14); -x_24 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_18, x_1, x_14); -x_25 = lean_alloc_ctor(0, 9, 0); -lean_ctor_set(x_25, 0, x_15); -lean_ctor_set(x_25, 1, x_16); -lean_ctor_set(x_25, 2, x_17); -lean_ctor_set(x_25, 3, x_24); -lean_ctor_set(x_25, 4, x_19); -lean_ctor_set(x_25, 5, x_20); -lean_ctor_set(x_25, 6, x_21); -lean_ctor_set(x_25, 7, x_22); -lean_ctor_set(x_25, 8, x_23); -lean_ctor_set(x_7, 1, x_25); -return x_7; +x_29 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_23, x_5, x_18); +x_30 = lean_alloc_ctor(0, 10, 0); +lean_ctor_set(x_30, 0, x_19); +lean_ctor_set(x_30, 1, x_20); +lean_ctor_set(x_30, 2, x_21); +lean_ctor_set(x_30, 3, x_22); +lean_ctor_set(x_30, 4, x_29); +lean_ctor_set(x_30, 5, x_24); +lean_ctor_set(x_30, 6, x_25); +lean_ctor_set(x_30, 7, x_26); +lean_ctor_set(x_30, 8, x_27); +lean_ctor_set(x_30, 9, x_28); +lean_ctor_set(x_11, 1, x_30); +return x_11; } } else { -lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; -x_26 = lean_ctor_get(x_7, 1); -x_27 = lean_ctor_get(x_7, 0); -lean_inc(x_26); -lean_inc(x_27); -lean_dec(x_7); -x_28 = lean_ctor_get(x_26, 0); -lean_inc(x_28); -x_29 = lean_ctor_get(x_26, 1); -lean_inc(x_29); -x_30 = lean_ctor_get(x_26, 2); -lean_inc(x_30); -x_31 = lean_ctor_get(x_26, 3); +lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; +x_31 = lean_ctor_get(x_11, 1); +x_32 = lean_ctor_get(x_11, 0); lean_inc(x_31); -x_32 = lean_ctor_get(x_26, 4); lean_inc(x_32); -x_33 = lean_ctor_get(x_26, 5); +lean_dec(x_11); +x_33 = lean_ctor_get(x_31, 0); lean_inc(x_33); -x_34 = lean_ctor_get(x_26, 6); +x_34 = lean_ctor_get(x_31, 1); lean_inc(x_34); -x_35 = lean_ctor_get(x_26, 7); +x_35 = lean_ctor_get(x_31, 2); lean_inc(x_35); -x_36 = lean_ctor_get(x_26, 8); +x_36 = lean_ctor_get(x_31, 3); lean_inc(x_36); -if (lean_is_exclusive(x_26)) { - lean_ctor_release(x_26, 0); - lean_ctor_release(x_26, 1); - lean_ctor_release(x_26, 2); - lean_ctor_release(x_26, 3); - lean_ctor_release(x_26, 4); - lean_ctor_release(x_26, 5); - lean_ctor_release(x_26, 6); - lean_ctor_release(x_26, 7); - lean_ctor_release(x_26, 8); - x_37 = x_26; -} else { - lean_dec_ref(x_26); - x_37 = lean_box(0); -} -lean_inc(x_27); -x_38 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_31, x_1, x_27); -if (lean_is_scalar(x_37)) { - x_39 = lean_alloc_ctor(0, 9, 0); -} else { - x_39 = x_37; -} -lean_ctor_set(x_39, 0, x_28); -lean_ctor_set(x_39, 1, x_29); -lean_ctor_set(x_39, 2, x_30); -lean_ctor_set(x_39, 3, x_38); -lean_ctor_set(x_39, 4, x_32); -lean_ctor_set(x_39, 5, x_33); -lean_ctor_set(x_39, 6, x_34); -lean_ctor_set(x_39, 7, x_35); -lean_ctor_set(x_39, 8, x_36); -x_40 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_40, 0, x_27); -lean_ctor_set(x_40, 1, x_39); -return x_40; -} -} -else -{ -uint8_t x_41; -lean_dec(x_1); -x_41 = !lean_is_exclusive(x_7); -if (x_41 == 0) -{ -return x_7; -} -else -{ -lean_object* x_42; lean_object* x_43; lean_object* x_44; -x_42 = lean_ctor_get(x_7, 0); -x_43 = lean_ctor_get(x_7, 1); -lean_inc(x_43); +x_37 = lean_ctor_get(x_31, 4); +lean_inc(x_37); +x_38 = lean_ctor_get(x_31, 5); +lean_inc(x_38); +x_39 = lean_ctor_get(x_31, 6); +lean_inc(x_39); +x_40 = lean_ctor_get(x_31, 7); +lean_inc(x_40); +x_41 = lean_ctor_get(x_31, 8); +lean_inc(x_41); +x_42 = lean_ctor_get(x_31, 9); lean_inc(x_42); -lean_dec(x_7); -x_44 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_44, 0, x_42); -lean_ctor_set(x_44, 1, x_43); -return x_44; +if (lean_is_exclusive(x_31)) { + lean_ctor_release(x_31, 0); + lean_ctor_release(x_31, 1); + lean_ctor_release(x_31, 2); + lean_ctor_release(x_31, 3); + lean_ctor_release(x_31, 4); + lean_ctor_release(x_31, 5); + lean_ctor_release(x_31, 6); + lean_ctor_release(x_31, 7); + lean_ctor_release(x_31, 8); + lean_ctor_release(x_31, 9); + x_43 = x_31; +} else { + lean_dec_ref(x_31); + x_43 = lean_box(0); +} +lean_inc(x_32); +x_44 = l_Std_HashMapImp_insert___at_Lean_Closure_visitExpr___spec__3(x_37, x_5, x_32); +if (lean_is_scalar(x_43)) { + x_45 = lean_alloc_ctor(0, 10, 0); +} else { + x_45 = x_43; +} +lean_ctor_set(x_45, 0, x_33); +lean_ctor_set(x_45, 1, x_34); +lean_ctor_set(x_45, 2, x_35); +lean_ctor_set(x_45, 3, x_36); +lean_ctor_set(x_45, 4, x_44); +lean_ctor_set(x_45, 5, x_38); +lean_ctor_set(x_45, 6, x_39); +lean_ctor_set(x_45, 7, x_40); +lean_ctor_set(x_45, 8, x_41); +lean_ctor_set(x_45, 9, x_42); +x_46 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_46, 0, x_32); +lean_ctor_set(x_46, 1, x_45); +return x_46; +} +} +else +{ +uint8_t x_47; +lean_dec(x_5); +x_47 = !lean_is_exclusive(x_11); +if (x_47 == 0) +{ +return x_11; +} +else +{ +lean_object* x_48; lean_object* x_49; lean_object* x_50; +x_48 = lean_ctor_get(x_11, 0); +x_49 = lean_ctor_get(x_11, 1); +lean_inc(x_49); +lean_inc(x_48); +lean_dec(x_11); +x_50 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_50, 0, x_48); +lean_ctor_set(x_50, 1, x_49); +return x_50; } } } else { -lean_object* x_45; lean_object* x_46; +lean_object* x_51; lean_object* x_52; +lean_dec(x_5); lean_dec(x_2); -lean_dec(x_1); -x_45 = lean_ctor_get(x_6, 0); -lean_inc(x_45); -lean_dec(x_6); -x_46 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_46, 0, x_45); -lean_ctor_set(x_46, 1, x_3); -return x_46; +x_51 = lean_ctor_get(x_10, 0); +lean_inc(x_51); +lean_dec(x_10); +if (lean_is_scalar(x_7)) { + x_52 = lean_alloc_ctor(0, 2, 0); +} else { + x_52 = x_7; +} +lean_ctor_set(x_52, 0, x_51); +lean_ctor_set(x_52, 1, x_6); +return x_52; } } } @@ -6804,356 +6987,605 @@ x_2 = l_Std_mkHashMapImp___rarg(x_1); return x_2; } } -lean_object* _init_l_Lean_Closure_mkClosure___closed__6() { -_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; lean_object* x_7; -x_1 = l_Lean_LocalContext_Inhabited___closed__2; -x_2 = l_Lean_Closure_mkClosure___closed__3; -x_3 = l_Lean_Closure_mkClosure___closed__4; -x_4 = l_Lean_Closure_mkClosure___closed__5; -x_5 = l_Array_empty___closed__1; -x_6 = lean_unsigned_to_nat(1u); -x_7 = lean_alloc_ctor(0, 9, 0); -lean_ctor_set(x_7, 0, x_1); -lean_ctor_set(x_7, 1, x_2); -lean_ctor_set(x_7, 2, x_3); -lean_ctor_set(x_7, 3, x_4); -lean_ctor_set(x_7, 4, x_5); -lean_ctor_set(x_7, 5, x_6); -lean_ctor_set(x_7, 6, x_5); -lean_ctor_set(x_7, 7, x_6); -lean_ctor_set(x_7, 8, x_5); -return x_7; -} -} lean_object* l_Lean_Closure_mkClosure(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, uint8_t x_5) { _start: { -lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; uint8_t x_11; +lean_object* x_6; lean_object* x_7; uint8_t x_8; x_6 = l_Std_ShareCommon_State_empty; x_7 = lean_state_sharecommon(x_6, x_3); -x_8 = lean_ctor_get(x_7, 0); -lean_inc(x_8); -x_9 = lean_ctor_get(x_7, 1); -lean_inc(x_9); -lean_dec(x_7); -x_10 = lean_state_sharecommon(x_9, x_4); -x_11 = !lean_is_exclusive(x_10); -if (x_11 == 0) +x_8 = !lean_is_exclusive(x_7); +if (x_8 == 0) { -lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_31; lean_object* x_32; lean_object* x_33; -x_12 = lean_ctor_get(x_10, 0); -x_13 = lean_ctor_get(x_10, 1); -lean_dec(x_13); -x_31 = lean_alloc_ctor(0, 2, 1); -lean_ctor_set(x_31, 0, x_1); -lean_ctor_set(x_31, 1, x_2); -lean_ctor_set_uint8(x_31, sizeof(void*)*2, x_5); -x_32 = l_Lean_Closure_mkClosure___closed__6; -lean_inc(x_31); -x_33 = l_Lean_Closure_collectExpr(x_8, x_31, x_32); -if (lean_obj_tag(x_33) == 0) +lean_object* x_9; lean_object* x_10; lean_object* x_11; uint8_t x_12; +x_9 = lean_ctor_get(x_7, 0); +x_10 = lean_ctor_get(x_7, 1); +x_11 = lean_state_sharecommon(x_10, x_4); +x_12 = !lean_is_exclusive(x_11); +if (x_12 == 0) { -lean_object* x_34; lean_object* x_35; lean_object* x_36; -x_34 = lean_ctor_get(x_33, 0); +lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; +x_13 = lean_ctor_get(x_11, 0); +x_14 = lean_ctor_get(x_11, 1); +lean_dec(x_14); +x_34 = lean_alloc_ctor(0, 1, 1); +lean_ctor_set(x_34, 0, x_2); +lean_ctor_set_uint8(x_34, sizeof(void*)*1, x_5); +x_35 = l_Lean_LocalContext_Inhabited___closed__2; +x_36 = l_Lean_Closure_mkClosure___closed__3; +x_37 = l_Lean_Closure_mkClosure___closed__4; +x_38 = l_Lean_Closure_mkClosure___closed__5; +x_39 = l_Array_empty___closed__1; +x_40 = lean_unsigned_to_nat(1u); +x_41 = lean_alloc_ctor(0, 10, 0); +lean_ctor_set(x_41, 0, x_1); +lean_ctor_set(x_41, 1, x_35); +lean_ctor_set(x_41, 2, x_36); +lean_ctor_set(x_41, 3, x_37); +lean_ctor_set(x_41, 4, x_38); +lean_ctor_set(x_41, 5, x_39); +lean_ctor_set(x_41, 6, x_40); +lean_ctor_set(x_41, 7, x_39); +lean_ctor_set(x_41, 8, x_40); +lean_ctor_set(x_41, 9, x_39); lean_inc(x_34); -x_35 = lean_ctor_get(x_33, 1); -lean_inc(x_35); -lean_dec(x_33); -x_36 = l_Lean_Closure_collectExpr(x_12, x_31, x_35); -if (lean_obj_tag(x_36) == 0) -{ -uint8_t x_37; -x_37 = !lean_is_exclusive(x_36); -if (x_37 == 0) -{ -lean_object* x_38; -x_38 = lean_ctor_get(x_36, 0); -lean_ctor_set(x_10, 1, x_38); -lean_ctor_set(x_10, 0, x_34); -lean_ctor_set(x_36, 0, x_10); -x_14 = x_36; -goto block_30; -} -else -{ -lean_object* x_39; lean_object* x_40; lean_object* x_41; -x_39 = lean_ctor_get(x_36, 0); -x_40 = lean_ctor_get(x_36, 1); -lean_inc(x_40); -lean_inc(x_39); -lean_dec(x_36); -lean_ctor_set(x_10, 1, x_39); -lean_ctor_set(x_10, 0, x_34); -x_41 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_41, 0, x_10); -lean_ctor_set(x_41, 1, x_40); -x_14 = x_41; -goto block_30; -} -} -else -{ -uint8_t x_42; -lean_dec(x_34); -lean_free_object(x_10); -x_42 = !lean_is_exclusive(x_36); -if (x_42 == 0) -{ -x_14 = x_36; -goto block_30; -} -else +x_42 = l_Lean_Closure_collectExpr(x_9, x_34, x_41); +if (lean_obj_tag(x_42) == 0) { lean_object* x_43; lean_object* x_44; lean_object* x_45; -x_43 = lean_ctor_get(x_36, 0); -x_44 = lean_ctor_get(x_36, 1); -lean_inc(x_44); +x_43 = lean_ctor_get(x_42, 0); lean_inc(x_43); -lean_dec(x_36); -x_45 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_45, 0, x_43); -lean_ctor_set(x_45, 1, x_44); -x_14 = x_45; -goto block_30; -} -} -} -else +x_44 = lean_ctor_get(x_42, 1); +lean_inc(x_44); +lean_dec(x_42); +x_45 = l_Lean_Closure_collectExpr(x_13, x_34, x_44); +if (lean_obj_tag(x_45) == 0) { -uint8_t x_46; -lean_dec(x_31); -lean_free_object(x_10); -lean_dec(x_12); -x_46 = !lean_is_exclusive(x_33); -if (x_46 == 0) -{ -x_14 = x_33; -goto block_30; -} -else -{ -lean_object* x_47; lean_object* x_48; lean_object* x_49; -x_47 = lean_ctor_get(x_33, 0); -x_48 = lean_ctor_get(x_33, 1); -lean_inc(x_48); +lean_object* x_46; lean_object* x_47; lean_object* x_48; uint8_t x_49; +x_46 = lean_ctor_get(x_45, 0); +lean_inc(x_46); +x_47 = lean_ctor_get(x_45, 1); lean_inc(x_47); -lean_dec(x_33); -x_49 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_49, 0, x_47); -lean_ctor_set(x_49, 1, x_48); -x_14 = x_49; -goto block_30; +lean_dec(x_45); +x_48 = l_Lean_Closure_getMCtx___rarg(x_47); +x_49 = !lean_is_exclusive(x_48); +if (x_49 == 0) +{ +lean_object* x_50; +x_50 = lean_ctor_get(x_48, 0); +lean_ctor_set(x_11, 1, x_50); +lean_ctor_set(x_11, 0, x_46); +lean_ctor_set(x_7, 1, x_11); +lean_ctor_set(x_7, 0, x_43); +lean_ctor_set(x_48, 0, x_7); +x_15 = x_48; +goto block_33; +} +else +{ +lean_object* x_51; lean_object* x_52; lean_object* x_53; +x_51 = lean_ctor_get(x_48, 0); +x_52 = lean_ctor_get(x_48, 1); +lean_inc(x_52); +lean_inc(x_51); +lean_dec(x_48); +lean_ctor_set(x_11, 1, x_51); +lean_ctor_set(x_11, 0, x_46); +lean_ctor_set(x_7, 1, x_11); +lean_ctor_set(x_7, 0, x_43); +x_53 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_53, 0, x_7); +lean_ctor_set(x_53, 1, x_52); +x_15 = x_53; +goto block_33; } } -block_30: +else { -if (lean_obj_tag(x_14) == 0) +uint8_t x_54; +lean_dec(x_43); +lean_free_object(x_11); +lean_free_object(x_7); +x_54 = !lean_is_exclusive(x_45); +if (x_54 == 0) { -lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; -x_15 = lean_ctor_get(x_14, 0); -lean_inc(x_15); -x_16 = lean_ctor_get(x_14, 1); +x_15 = x_45; +goto block_33; +} +else +{ +lean_object* x_55; lean_object* x_56; lean_object* x_57; +x_55 = lean_ctor_get(x_45, 0); +x_56 = lean_ctor_get(x_45, 1); +lean_inc(x_56); +lean_inc(x_55); +lean_dec(x_45); +x_57 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_57, 0, x_55); +lean_ctor_set(x_57, 1, x_56); +x_15 = x_57; +goto block_33; +} +} +} +else +{ +uint8_t x_58; +lean_dec(x_34); +lean_free_object(x_11); +lean_dec(x_13); +lean_free_object(x_7); +x_58 = !lean_is_exclusive(x_42); +if (x_58 == 0) +{ +x_15 = x_42; +goto block_33; +} +else +{ +lean_object* x_59; lean_object* x_60; lean_object* x_61; +x_59 = lean_ctor_get(x_42, 0); +x_60 = lean_ctor_get(x_42, 1); +lean_inc(x_60); +lean_inc(x_59); +lean_dec(x_42); +x_61 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_61, 0, x_59); +lean_ctor_set(x_61, 1, x_60); +x_15 = x_61; +goto block_33; +} +} +block_33: +{ +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_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; +x_16 = lean_ctor_get(x_15, 0); lean_inc(x_16); -lean_dec(x_14); -x_17 = lean_ctor_get(x_15, 0); +x_17 = lean_ctor_get(x_16, 1); lean_inc(x_17); x_18 = lean_ctor_get(x_15, 1); lean_inc(x_18); lean_dec(x_15); x_19 = lean_ctor_get(x_16, 0); lean_inc(x_19); -x_20 = l_Lean_LocalContext_getFVars(x_19); -lean_inc(x_19); -x_21 = l_Lean_LocalContext_mkForall(x_19, x_20, x_17); -lean_dec(x_17); -x_22 = l_Lean_LocalContext_mkLambda(x_19, x_20, x_18); -lean_dec(x_18); -lean_dec(x_20); -x_23 = lean_ctor_get(x_16, 4); -lean_inc(x_23); -x_24 = lean_ctor_get(x_16, 6); -lean_inc(x_24); -x_25 = lean_ctor_get(x_16, 8); -lean_inc(x_25); lean_dec(x_16); -x_26 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_26, 0, x_23); -lean_ctor_set(x_26, 1, x_21); -lean_ctor_set(x_26, 2, x_22); -lean_ctor_set(x_26, 3, x_24); -lean_ctor_set(x_26, 4, x_25); -x_27 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_27, 0, x_26); -return x_27; -} -else -{ -lean_object* x_28; lean_object* x_29; -x_28 = lean_ctor_get(x_14, 0); +x_20 = lean_ctor_get(x_17, 0); +lean_inc(x_20); +x_21 = lean_ctor_get(x_17, 1); +lean_inc(x_21); +lean_dec(x_17); +x_22 = lean_ctor_get(x_18, 1); +lean_inc(x_22); +x_23 = l_Lean_LocalContext_getFVars(x_22); +lean_inc(x_22); +x_24 = l_Lean_LocalContext_mkForall(x_22, x_23, x_19); +lean_dec(x_19); +x_25 = l_Lean_LocalContext_mkLambda(x_22, x_23, x_20); +lean_dec(x_20); +lean_dec(x_23); +x_26 = lean_ctor_get(x_18, 5); +lean_inc(x_26); +x_27 = lean_ctor_get(x_18, 7); +lean_inc(x_27); +x_28 = lean_ctor_get(x_18, 9); lean_inc(x_28); -lean_dec(x_14); -x_29 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_29, 0, x_28); -return x_29; +lean_dec(x_18); +x_29 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_29, 0, x_26); +lean_ctor_set(x_29, 1, x_24); +lean_ctor_set(x_29, 2, x_25); +lean_ctor_set(x_29, 3, x_27); +lean_ctor_set(x_29, 4, x_28); +lean_ctor_set(x_29, 5, x_21); +x_30 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_30, 0, x_29); +return x_30; +} +else +{ +lean_object* x_31; lean_object* x_32; +x_31 = lean_ctor_get(x_15, 0); +lean_inc(x_31); +lean_dec(x_15); +x_32 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_32, 0, x_31); +return x_32; } } } else { -lean_object* x_50; lean_object* x_51; lean_object* x_68; lean_object* x_69; lean_object* x_70; -x_50 = lean_ctor_get(x_10, 0); -lean_inc(x_50); -lean_dec(x_10); -x_68 = lean_alloc_ctor(0, 2, 1); -lean_ctor_set(x_68, 0, x_1); -lean_ctor_set(x_68, 1, x_2); -lean_ctor_set_uint8(x_68, sizeof(void*)*2, x_5); -x_69 = l_Lean_Closure_mkClosure___closed__6; -lean_inc(x_68); -x_70 = l_Lean_Closure_collectExpr(x_8, x_68, x_69); -if (lean_obj_tag(x_70) == 0) -{ -lean_object* x_71; lean_object* x_72; lean_object* x_73; -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 = l_Lean_Closure_collectExpr(x_50, x_68, x_72); -if (lean_obj_tag(x_73) == 0) -{ -lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; -x_74 = lean_ctor_get(x_73, 0); -lean_inc(x_74); -x_75 = lean_ctor_get(x_73, 1); -lean_inc(x_75); -if (lean_is_exclusive(x_73)) { - lean_ctor_release(x_73, 0); - lean_ctor_release(x_73, 1); - x_76 = x_73; -} else { - lean_dec_ref(x_73); - x_76 = lean_box(0); -} -x_77 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_77, 0, x_71); -lean_ctor_set(x_77, 1, x_74); -if (lean_is_scalar(x_76)) { - x_78 = lean_alloc_ctor(0, 2, 0); -} else { - x_78 = x_76; -} -lean_ctor_set(x_78, 0, x_77); -lean_ctor_set(x_78, 1, x_75); -x_51 = x_78; -goto block_67; -} -else -{ -lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; -lean_dec(x_71); -x_79 = lean_ctor_get(x_73, 0); -lean_inc(x_79); -x_80 = lean_ctor_get(x_73, 1); -lean_inc(x_80); -if (lean_is_exclusive(x_73)) { - lean_ctor_release(x_73, 0); - lean_ctor_release(x_73, 1); - x_81 = x_73; -} else { - lean_dec_ref(x_73); - x_81 = lean_box(0); -} -if (lean_is_scalar(x_81)) { - x_82 = lean_alloc_ctor(1, 2, 0); -} else { - x_82 = x_81; -} -lean_ctor_set(x_82, 0, x_79); -lean_ctor_set(x_82, 1, x_80); -x_51 = x_82; -goto block_67; -} -} -else -{ -lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; -lean_dec(x_68); -lean_dec(x_50); -x_83 = lean_ctor_get(x_70, 0); -lean_inc(x_83); -x_84 = lean_ctor_get(x_70, 1); -lean_inc(x_84); -if (lean_is_exclusive(x_70)) { - lean_ctor_release(x_70, 0); - lean_ctor_release(x_70, 1); - x_85 = x_70; -} else { - lean_dec_ref(x_70); - x_85 = lean_box(0); -} -if (lean_is_scalar(x_85)) { - x_86 = lean_alloc_ctor(1, 2, 0); -} else { - x_86 = x_85; -} -lean_ctor_set(x_86, 0, x_83); -lean_ctor_set(x_86, 1, x_84); -x_51 = x_86; -goto block_67; -} -block_67: -{ -if (lean_obj_tag(x_51) == 0) -{ -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_object* x_63; lean_object* x_64; -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 = lean_ctor_get(x_52, 0); -lean_inc(x_54); -x_55 = lean_ctor_get(x_52, 1); -lean_inc(x_55); -lean_dec(x_52); -x_56 = lean_ctor_get(x_53, 0); -lean_inc(x_56); -x_57 = l_Lean_LocalContext_getFVars(x_56); -lean_inc(x_56); -x_58 = l_Lean_LocalContext_mkForall(x_56, x_57, x_54); -lean_dec(x_54); -x_59 = l_Lean_LocalContext_mkLambda(x_56, x_57, x_55); -lean_dec(x_55); -lean_dec(x_57); -x_60 = lean_ctor_get(x_53, 4); -lean_inc(x_60); -x_61 = lean_ctor_get(x_53, 6); -lean_inc(x_61); -x_62 = lean_ctor_get(x_53, 8); +lean_object* x_62; lean_object* x_63; 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; +x_62 = lean_ctor_get(x_11, 0); lean_inc(x_62); -lean_dec(x_53); -x_63 = lean_alloc_ctor(0, 5, 0); -lean_ctor_set(x_63, 0, x_60); -lean_ctor_set(x_63, 1, x_58); -lean_ctor_set(x_63, 2, x_59); -lean_ctor_set(x_63, 3, x_61); -lean_ctor_set(x_63, 4, x_62); -x_64 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_64, 0, x_63); -return x_64; +lean_dec(x_11); +x_82 = lean_alloc_ctor(0, 1, 1); +lean_ctor_set(x_82, 0, x_2); +lean_ctor_set_uint8(x_82, sizeof(void*)*1, x_5); +x_83 = l_Lean_LocalContext_Inhabited___closed__2; +x_84 = l_Lean_Closure_mkClosure___closed__3; +x_85 = l_Lean_Closure_mkClosure___closed__4; +x_86 = l_Lean_Closure_mkClosure___closed__5; +x_87 = l_Array_empty___closed__1; +x_88 = lean_unsigned_to_nat(1u); +x_89 = lean_alloc_ctor(0, 10, 0); +lean_ctor_set(x_89, 0, x_1); +lean_ctor_set(x_89, 1, x_83); +lean_ctor_set(x_89, 2, x_84); +lean_ctor_set(x_89, 3, x_85); +lean_ctor_set(x_89, 4, x_86); +lean_ctor_set(x_89, 5, x_87); +lean_ctor_set(x_89, 6, x_88); +lean_ctor_set(x_89, 7, x_87); +lean_ctor_set(x_89, 8, x_88); +lean_ctor_set(x_89, 9, x_87); +lean_inc(x_82); +x_90 = l_Lean_Closure_collectExpr(x_9, x_82, x_89); +if (lean_obj_tag(x_90) == 0) +{ +lean_object* x_91; lean_object* x_92; lean_object* x_93; +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 = l_Lean_Closure_collectExpr(x_62, x_82, x_92); +if (lean_obj_tag(x_93) == 0) +{ +lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; +x_94 = lean_ctor_get(x_93, 0); +lean_inc(x_94); +x_95 = lean_ctor_get(x_93, 1); +lean_inc(x_95); +lean_dec(x_93); +x_96 = l_Lean_Closure_getMCtx___rarg(x_95); +x_97 = lean_ctor_get(x_96, 0); +lean_inc(x_97); +x_98 = lean_ctor_get(x_96, 1); +lean_inc(x_98); +if (lean_is_exclusive(x_96)) { + lean_ctor_release(x_96, 0); + lean_ctor_release(x_96, 1); + x_99 = x_96; +} else { + lean_dec_ref(x_96); + x_99 = lean_box(0); +} +x_100 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_100, 0, x_94); +lean_ctor_set(x_100, 1, x_97); +lean_ctor_set(x_7, 1, x_100); +lean_ctor_set(x_7, 0, x_91); +if (lean_is_scalar(x_99)) { + x_101 = lean_alloc_ctor(0, 2, 0); +} else { + x_101 = x_99; +} +lean_ctor_set(x_101, 0, x_7); +lean_ctor_set(x_101, 1, x_98); +x_63 = x_101; +goto block_81; } else { -lean_object* x_65; lean_object* x_66; -x_65 = lean_ctor_get(x_51, 0); +lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; +lean_dec(x_91); +lean_free_object(x_7); +x_102 = lean_ctor_get(x_93, 0); +lean_inc(x_102); +x_103 = lean_ctor_get(x_93, 1); +lean_inc(x_103); +if (lean_is_exclusive(x_93)) { + lean_ctor_release(x_93, 0); + lean_ctor_release(x_93, 1); + x_104 = x_93; +} else { + lean_dec_ref(x_93); + x_104 = lean_box(0); +} +if (lean_is_scalar(x_104)) { + x_105 = lean_alloc_ctor(1, 2, 0); +} else { + x_105 = x_104; +} +lean_ctor_set(x_105, 0, x_102); +lean_ctor_set(x_105, 1, x_103); +x_63 = x_105; +goto block_81; +} +} +else +{ +lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; +lean_dec(x_82); +lean_dec(x_62); +lean_free_object(x_7); +x_106 = lean_ctor_get(x_90, 0); +lean_inc(x_106); +x_107 = lean_ctor_get(x_90, 1); +lean_inc(x_107); +if (lean_is_exclusive(x_90)) { + lean_ctor_release(x_90, 0); + lean_ctor_release(x_90, 1); + x_108 = x_90; +} else { + lean_dec_ref(x_90); + x_108 = lean_box(0); +} +if (lean_is_scalar(x_108)) { + x_109 = lean_alloc_ctor(1, 2, 0); +} else { + x_109 = x_108; +} +lean_ctor_set(x_109, 0, x_106); +lean_ctor_set(x_109, 1, x_107); +x_63 = x_109; +goto block_81; +} +block_81: +{ +if (lean_obj_tag(x_63) == 0) +{ +lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; +x_64 = lean_ctor_get(x_63, 0); +lean_inc(x_64); +x_65 = lean_ctor_get(x_64, 1); lean_inc(x_65); -lean_dec(x_51); -x_66 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_66, 0, x_65); -return x_66; +x_66 = lean_ctor_get(x_63, 1); +lean_inc(x_66); +lean_dec(x_63); +x_67 = lean_ctor_get(x_64, 0); +lean_inc(x_67); +lean_dec(x_64); +x_68 = lean_ctor_get(x_65, 0); +lean_inc(x_68); +x_69 = lean_ctor_get(x_65, 1); +lean_inc(x_69); +lean_dec(x_65); +x_70 = lean_ctor_get(x_66, 1); +lean_inc(x_70); +x_71 = l_Lean_LocalContext_getFVars(x_70); +lean_inc(x_70); +x_72 = l_Lean_LocalContext_mkForall(x_70, x_71, x_67); +lean_dec(x_67); +x_73 = l_Lean_LocalContext_mkLambda(x_70, x_71, x_68); +lean_dec(x_68); +lean_dec(x_71); +x_74 = lean_ctor_get(x_66, 5); +lean_inc(x_74); +x_75 = lean_ctor_get(x_66, 7); +lean_inc(x_75); +x_76 = lean_ctor_get(x_66, 9); +lean_inc(x_76); +lean_dec(x_66); +x_77 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_77, 0, x_74); +lean_ctor_set(x_77, 1, x_72); +lean_ctor_set(x_77, 2, x_73); +lean_ctor_set(x_77, 3, x_75); +lean_ctor_set(x_77, 4, x_76); +lean_ctor_set(x_77, 5, x_69); +x_78 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_78, 0, x_77); +return x_78; +} +else +{ +lean_object* x_79; lean_object* x_80; +x_79 = lean_ctor_get(x_63, 0); +lean_inc(x_79); +lean_dec(x_63); +x_80 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_80, 0, x_79); +return x_80; +} +} +} +} +else +{ +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_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; +x_110 = lean_ctor_get(x_7, 0); +x_111 = lean_ctor_get(x_7, 1); +lean_inc(x_111); +lean_inc(x_110); +lean_dec(x_7); +x_112 = lean_state_sharecommon(x_111, x_4); +x_113 = lean_ctor_get(x_112, 0); +lean_inc(x_113); +if (lean_is_exclusive(x_112)) { + lean_ctor_release(x_112, 0); + lean_ctor_release(x_112, 1); + x_114 = x_112; +} else { + lean_dec_ref(x_112); + x_114 = lean_box(0); +} +x_134 = lean_alloc_ctor(0, 1, 1); +lean_ctor_set(x_134, 0, x_2); +lean_ctor_set_uint8(x_134, sizeof(void*)*1, x_5); +x_135 = l_Lean_LocalContext_Inhabited___closed__2; +x_136 = l_Lean_Closure_mkClosure___closed__3; +x_137 = l_Lean_Closure_mkClosure___closed__4; +x_138 = l_Lean_Closure_mkClosure___closed__5; +x_139 = l_Array_empty___closed__1; +x_140 = lean_unsigned_to_nat(1u); +x_141 = lean_alloc_ctor(0, 10, 0); +lean_ctor_set(x_141, 0, x_1); +lean_ctor_set(x_141, 1, x_135); +lean_ctor_set(x_141, 2, x_136); +lean_ctor_set(x_141, 3, x_137); +lean_ctor_set(x_141, 4, x_138); +lean_ctor_set(x_141, 5, x_139); +lean_ctor_set(x_141, 6, x_140); +lean_ctor_set(x_141, 7, x_139); +lean_ctor_set(x_141, 8, x_140); +lean_ctor_set(x_141, 9, x_139); +lean_inc(x_134); +x_142 = l_Lean_Closure_collectExpr(x_110, x_134, x_141); +if (lean_obj_tag(x_142) == 0) +{ +lean_object* x_143; lean_object* x_144; lean_object* x_145; +x_143 = lean_ctor_get(x_142, 0); +lean_inc(x_143); +x_144 = lean_ctor_get(x_142, 1); +lean_inc(x_144); +lean_dec(x_142); +x_145 = l_Lean_Closure_collectExpr(x_113, x_134, x_144); +if (lean_obj_tag(x_145) == 0) +{ +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; +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); +x_148 = l_Lean_Closure_getMCtx___rarg(x_147); +x_149 = lean_ctor_get(x_148, 0); +lean_inc(x_149); +x_150 = lean_ctor_get(x_148, 1); +lean_inc(x_150); +if (lean_is_exclusive(x_148)) { + lean_ctor_release(x_148, 0); + lean_ctor_release(x_148, 1); + x_151 = x_148; +} else { + lean_dec_ref(x_148); + x_151 = lean_box(0); +} +if (lean_is_scalar(x_114)) { + x_152 = lean_alloc_ctor(0, 2, 0); +} else { + x_152 = x_114; +} +lean_ctor_set(x_152, 0, x_146); +lean_ctor_set(x_152, 1, x_149); +x_153 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_153, 0, x_143); +lean_ctor_set(x_153, 1, x_152); +if (lean_is_scalar(x_151)) { + x_154 = lean_alloc_ctor(0, 2, 0); +} else { + x_154 = x_151; +} +lean_ctor_set(x_154, 0, x_153); +lean_ctor_set(x_154, 1, x_150); +x_115 = x_154; +goto block_133; +} +else +{ +lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; +lean_dec(x_143); +lean_dec(x_114); +x_155 = lean_ctor_get(x_145, 0); +lean_inc(x_155); +x_156 = lean_ctor_get(x_145, 1); +lean_inc(x_156); +if (lean_is_exclusive(x_145)) { + lean_ctor_release(x_145, 0); + lean_ctor_release(x_145, 1); + x_157 = x_145; +} else { + lean_dec_ref(x_145); + x_157 = lean_box(0); +} +if (lean_is_scalar(x_157)) { + x_158 = lean_alloc_ctor(1, 2, 0); +} else { + x_158 = x_157; +} +lean_ctor_set(x_158, 0, x_155); +lean_ctor_set(x_158, 1, x_156); +x_115 = x_158; +goto block_133; +} +} +else +{ +lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; +lean_dec(x_134); +lean_dec(x_114); +lean_dec(x_113); +x_159 = lean_ctor_get(x_142, 0); +lean_inc(x_159); +x_160 = lean_ctor_get(x_142, 1); +lean_inc(x_160); +if (lean_is_exclusive(x_142)) { + lean_ctor_release(x_142, 0); + lean_ctor_release(x_142, 1); + x_161 = x_142; +} else { + lean_dec_ref(x_142); + x_161 = lean_box(0); +} +if (lean_is_scalar(x_161)) { + x_162 = lean_alloc_ctor(1, 2, 0); +} else { + x_162 = x_161; +} +lean_ctor_set(x_162, 0, x_159); +lean_ctor_set(x_162, 1, x_160); +x_115 = x_162; +goto block_133; +} +block_133: +{ +if (lean_obj_tag(x_115) == 0) +{ +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; +x_116 = lean_ctor_get(x_115, 0); +lean_inc(x_116); +x_117 = lean_ctor_get(x_116, 1); +lean_inc(x_117); +x_118 = lean_ctor_get(x_115, 1); +lean_inc(x_118); +lean_dec(x_115); +x_119 = lean_ctor_get(x_116, 0); +lean_inc(x_119); +lean_dec(x_116); +x_120 = lean_ctor_get(x_117, 0); +lean_inc(x_120); +x_121 = lean_ctor_get(x_117, 1); +lean_inc(x_121); +lean_dec(x_117); +x_122 = lean_ctor_get(x_118, 1); +lean_inc(x_122); +x_123 = l_Lean_LocalContext_getFVars(x_122); +lean_inc(x_122); +x_124 = l_Lean_LocalContext_mkForall(x_122, x_123, x_119); +lean_dec(x_119); +x_125 = l_Lean_LocalContext_mkLambda(x_122, x_123, x_120); +lean_dec(x_120); +lean_dec(x_123); +x_126 = lean_ctor_get(x_118, 5); +lean_inc(x_126); +x_127 = lean_ctor_get(x_118, 7); +lean_inc(x_127); +x_128 = lean_ctor_get(x_118, 9); +lean_inc(x_128); +lean_dec(x_118); +x_129 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_129, 0, x_126); +lean_ctor_set(x_129, 1, x_124); +lean_ctor_set(x_129, 2, x_125); +lean_ctor_set(x_129, 3, x_127); +lean_ctor_set(x_129, 4, x_128); +lean_ctor_set(x_129, 5, x_121); +x_130 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_130, 0, x_129); +return x_130; +} +else +{ +lean_object* x_131; lean_object* x_132; +x_131 = lean_ctor_get(x_115, 0); +lean_inc(x_131); +lean_dec(x_115); +x_132 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_132, 0, x_131); +return x_132; } } } @@ -7275,7 +7707,7 @@ uint8_t x_35; x_35 = !lean_is_exclusive(x_31); if (x_35 == 0) { -lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; +lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; x_36 = lean_ctor_get(x_31, 0); x_37 = lean_ctor_get(x_16, 3); lean_inc(x_37); @@ -7284,124 +7716,144 @@ lean_dec(x_37); x_39 = l_Lean_mkConst(x_5, x_38); x_40 = lean_ctor_get(x_16, 4); lean_inc(x_40); -lean_dec(x_16); x_41 = lean_unsigned_to_nat(0u); x_42 = l_Array_iterateMAux___main___at_Lean_mkAppN___spec__1(x_40, x_40, x_41, x_39); lean_dec(x_40); -x_43 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_43, 0, x_42); -lean_ctor_set(x_43, 1, x_36); -lean_ctor_set(x_31, 0, x_43); +x_43 = lean_ctor_get(x_16, 5); +lean_inc(x_43); +lean_dec(x_16); +x_44 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_44, 0, x_36); +lean_ctor_set(x_44, 1, x_43); +x_45 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_45, 0, x_42); +lean_ctor_set(x_45, 1, x_44); +lean_ctor_set(x_31, 0, x_45); return x_31; } 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; -x_44 = lean_ctor_get(x_31, 0); -lean_inc(x_44); +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; +x_46 = lean_ctor_get(x_31, 0); +lean_inc(x_46); lean_dec(x_31); -x_45 = lean_ctor_get(x_16, 3); -lean_inc(x_45); -x_46 = l_Array_toList___rarg(x_45); -lean_dec(x_45); -x_47 = l_Lean_mkConst(x_5, x_46); -x_48 = lean_ctor_get(x_16, 4); -lean_inc(x_48); +x_47 = lean_ctor_get(x_16, 3); +lean_inc(x_47); +x_48 = l_Array_toList___rarg(x_47); +lean_dec(x_47); +x_49 = l_Lean_mkConst(x_5, x_48); +x_50 = lean_ctor_get(x_16, 4); +lean_inc(x_50); +x_51 = lean_unsigned_to_nat(0u); +x_52 = l_Array_iterateMAux___main___at_Lean_mkAppN___spec__1(x_50, x_50, x_51, x_49); +lean_dec(x_50); +x_53 = lean_ctor_get(x_16, 5); +lean_inc(x_53); lean_dec(x_16); -x_49 = lean_unsigned_to_nat(0u); -x_50 = l_Array_iterateMAux___main___at_Lean_mkAppN___spec__1(x_48, x_48, x_49, x_47); -lean_dec(x_48); -x_51 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_51, 0, x_50); -lean_ctor_set(x_51, 1, x_44); -x_52 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_52, 0, x_51); -return x_52; +x_54 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_54, 0, x_46); +lean_ctor_set(x_54, 1, x_53); +x_55 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_55, 0, x_52); +lean_ctor_set(x_55, 1, x_54); +x_56 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_56, 0, x_55); +return x_56; } } } else { -uint8_t x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; -x_53 = 1; -x_54 = lean_alloc_ctor(0, 3, 1); -lean_ctor_set(x_54, 0, x_20); -lean_ctor_set(x_54, 1, x_21); -lean_ctor_set(x_54, 2, x_26); -lean_ctor_set_uint8(x_54, sizeof(void*)*3, x_53); -x_55 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_55, 0, x_54); -x_56 = l_Lean_Environment_addAndCompile(x_1, x_2, x_55); -lean_dec(x_55); -if (lean_obj_tag(x_56) == 0) +uint8_t x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; +x_57 = 1; +x_58 = lean_alloc_ctor(0, 3, 1); +lean_ctor_set(x_58, 0, x_20); +lean_ctor_set(x_58, 1, x_21); +lean_ctor_set(x_58, 2, x_26); +lean_ctor_set_uint8(x_58, sizeof(void*)*3, x_57); +x_59 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_59, 0, x_58); +x_60 = l_Lean_Environment_addAndCompile(x_1, x_2, x_59); +lean_dec(x_59); +if (lean_obj_tag(x_60) == 0) { -uint8_t x_57; +uint8_t x_61; lean_dec(x_16); lean_dec(x_5); -x_57 = !lean_is_exclusive(x_56); -if (x_57 == 0) +x_61 = !lean_is_exclusive(x_60); +if (x_61 == 0) { -return x_56; +return x_60; } else { -lean_object* x_58; lean_object* x_59; -x_58 = lean_ctor_get(x_56, 0); -lean_inc(x_58); -lean_dec(x_56); -x_59 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_59, 0, x_58); -return x_59; -} -} -else -{ -uint8_t x_60; -x_60 = !lean_is_exclusive(x_56); -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; lean_object* x_67; lean_object* x_68; -x_61 = lean_ctor_get(x_56, 0); -x_62 = lean_ctor_get(x_16, 3); +lean_object* x_62; lean_object* x_63; +x_62 = lean_ctor_get(x_60, 0); lean_inc(x_62); -x_63 = l_Array_toList___rarg(x_62); -lean_dec(x_62); -x_64 = l_Lean_mkConst(x_5, x_63); -x_65 = lean_ctor_get(x_16, 4); -lean_inc(x_65); -lean_dec(x_16); -x_66 = lean_unsigned_to_nat(0u); -x_67 = l_Array_iterateMAux___main___at_Lean_mkAppN___spec__1(x_65, x_65, x_66, x_64); -lean_dec(x_65); -x_68 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_68, 0, x_67); -lean_ctor_set(x_68, 1, x_61); -lean_ctor_set(x_56, 0, x_68); -return x_56; +lean_dec(x_60); +x_63 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_63, 0, x_62); +return x_63; +} } else { -lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; -x_69 = lean_ctor_get(x_56, 0); +uint8_t x_64; +x_64 = !lean_is_exclusive(x_60); +if (x_64 == 0) +{ +lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; +x_65 = lean_ctor_get(x_60, 0); +x_66 = lean_ctor_get(x_16, 3); +lean_inc(x_66); +x_67 = l_Array_toList___rarg(x_66); +lean_dec(x_66); +x_68 = l_Lean_mkConst(x_5, x_67); +x_69 = lean_ctor_get(x_16, 4); lean_inc(x_69); -lean_dec(x_56); -x_70 = lean_ctor_get(x_16, 3); -lean_inc(x_70); -x_71 = l_Array_toList___rarg(x_70); -lean_dec(x_70); -x_72 = l_Lean_mkConst(x_5, x_71); -x_73 = lean_ctor_get(x_16, 4); -lean_inc(x_73); +x_70 = lean_unsigned_to_nat(0u); +x_71 = l_Array_iterateMAux___main___at_Lean_mkAppN___spec__1(x_69, x_69, x_70, x_68); +lean_dec(x_69); +x_72 = lean_ctor_get(x_16, 5); +lean_inc(x_72); lean_dec(x_16); -x_74 = lean_unsigned_to_nat(0u); -x_75 = l_Array_iterateMAux___main___at_Lean_mkAppN___spec__1(x_73, x_73, x_74, x_72); -lean_dec(x_73); -x_76 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_76, 0, x_75); -lean_ctor_set(x_76, 1, x_69); -x_77 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_77, 0, x_76); -return x_77; +x_73 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_73, 0, x_65); +lean_ctor_set(x_73, 1, x_72); +x_74 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_74, 0, x_71); +lean_ctor_set(x_74, 1, x_73); +lean_ctor_set(x_60, 0, x_74); +return x_60; +} +else +{ +lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; +x_75 = lean_ctor_get(x_60, 0); +lean_inc(x_75); +lean_dec(x_60); +x_76 = lean_ctor_get(x_16, 3); +lean_inc(x_76); +x_77 = l_Array_toList___rarg(x_76); +lean_dec(x_76); +x_78 = l_Lean_mkConst(x_5, x_77); +x_79 = lean_ctor_get(x_16, 4); +lean_inc(x_79); +x_80 = lean_unsigned_to_nat(0u); +x_81 = l_Array_iterateMAux___main___at_Lean_mkAppN___spec__1(x_79, x_79, x_80, x_78); +lean_dec(x_79); +x_82 = lean_ctor_get(x_16, 5); +lean_inc(x_82); +lean_dec(x_16); +x_83 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_83, 0, x_75); +lean_ctor_set(x_83, 1, x_82); +x_84 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_84, 0, x_81); +lean_ctor_set(x_84, 1, x_83); +x_85 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_85, 0, x_84); +return x_85; } } } @@ -7462,8 +7914,6 @@ l_Lean_Closure_mkClosure___closed__4 = _init_l_Lean_Closure_mkClosure___closed__ lean_mark_persistent(l_Lean_Closure_mkClosure___closed__4); l_Lean_Closure_mkClosure___closed__5 = _init_l_Lean_Closure_mkClosure___closed__5(); lean_mark_persistent(l_Lean_Closure_mkClosure___closed__5); -l_Lean_Closure_mkClosure___closed__6 = _init_l_Lean_Closure_mkClosure___closed__6(); -lean_mark_persistent(l_Lean_Closure_mkClosure___closed__6); return lean_mk_io_result(lean_box(0)); } #ifdef __cplusplus